免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 5196 | 回复: 14
打印 上一主题 下一主题

[CPU及多核] 在多核计算机上,线程和进程调度的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-12-21 22:43 |只看该作者 |正序浏览
     在一台4核的计算机上,我做了两个测试程序A,B,在A上面创建4个线程,B上面创建4个进程,每个进程和线程中执行一样的函数,做循环的i++操作。用top观察运行情况,在运行A的过程中cpu使用率接近400%,运行B的过程中创建的4个进程的CPU使用率都接近100%。在进程的运行过程中,只能有一个上下文环境,在一个事件点上就只能运行一个进程(是不是这里我理解错了),怎么能够使4个进程都并行的运行起来呢?如果没有并行的运行,那么4个进程的CPU怎么都是100%呢?

论坛徽章:
0
15 [报告]
发表于 2014-05-21 16:18 |只看该作者
内核是自动识别进程是否有临界资源吗?是怎么做到的?

论坛徽章:
0
14 [报告]
发表于 2014-05-19 12:46 |只看该作者
线程和进程在linux内核中的调度管理方式是一样的,二者的区别是共用了一些内存空间。
但在多核系统且每个CPU核自带L1高缓存的系统中尤其要注意,传统的单核程序中如果包含了静态变量,在多核系统中容易被搞乱!

论坛徽章:
9
程序设计版块每日发帖之星
日期:2016-02-13 06:20:00数据库技术版块每日发帖之星
日期:2016-06-15 06:20:00数据库技术版块每日发帖之星
日期:2016-06-16 06:20:00数据库技术版块每日发帖之星
日期:2016-06-18 06:20:00程序设计版块每日发帖之星
日期:2016-06-27 06:20:00程序设计版块每日发帖之星
日期:2016-07-09 06:20:00IT运维版块每日发帖之星
日期:2016-07-15 06:20:00IT运维版块每日发帖之星
日期:2016-07-27 06:20:00程序设计版块每日发帖之星
日期:2016-08-18 06:20:00
13 [报告]
发表于 2013-12-25 12:40 |只看该作者
线程 就是  进程的一种
在那种木有mmu的cpu OS上,两者完全等价

论坛徽章:
16
2015亚冠之吉达阿赫利
日期:2015-08-17 11:21:462015年迎新春徽章
日期:2015-03-04 09:58:11酉鸡
日期:2014-12-07 09:06:19水瓶座
日期:2014-11-04 14:23:29天秤座
日期:2014-03-02 08:57:52双鱼座
日期:2014-02-22 13:07:56午马
日期:2014-02-14 11:08:18双鱼座
日期:2014-02-13 11:09:37卯兔
日期:2014-02-06 15:10:34子鼠
日期:2014-01-20 14:48:19戌狗
日期:2013-12-19 09:37:46射手座
日期:2013-12-19 09:33:47
12 [报告]
发表于 2013-12-25 09:08 |只看该作者
恩,没看到区分。

论坛徽章:
6
金牛座
日期:2013-10-08 10:19:10技术图书徽章
日期:2013-10-14 16:24:09CU十二周年纪念徽章
日期:2013-10-24 15:41:34狮子座
日期:2013-11-24 19:26:19未羊
日期:2014-01-23 15:50:002015年亚洲杯之阿联酋
日期:2015-05-09 14:36:15
11 [报告]
发表于 2013-12-25 09:06 |只看该作者
回复 9# tempname2
线程间有一定相关度,可能会使调度器认为它们最好运行在同一CPU上,比如为了提高cache命中率。

CFS调度算法貌似没有区分吧

   

论坛徽章:
16
2015亚冠之吉达阿赫利
日期:2015-08-17 11:21:462015年迎新春徽章
日期:2015-03-04 09:58:11酉鸡
日期:2014-12-07 09:06:19水瓶座
日期:2014-11-04 14:23:29天秤座
日期:2014-03-02 08:57:52双鱼座
日期:2014-02-22 13:07:56午马
日期:2014-02-14 11:08:18双鱼座
日期:2014-02-13 11:09:37卯兔
日期:2014-02-06 15:10:34子鼠
日期:2014-01-20 14:48:19戌狗
日期:2013-12-19 09:37:46射手座
日期:2013-12-19 09:33:47
10 [报告]
发表于 2013-12-25 07:35 |只看该作者
回复 9# tempname2

貌似不区分的。


   

论坛徽章:
2
CU十二周年纪念徽章
日期:2013-10-24 15:41:34处女座
日期:2013-12-27 22:22:41
9 [报告]
发表于 2013-12-25 00:57 |只看该作者
回复 8# 瀚海书香

线程间有一定相关度,可能会使调度器认为它们最好运行在同一CPU上,比如为了提高cache命中率。

论坛徽章:
6
金牛座
日期:2013-10-08 10:19:10技术图书徽章
日期:2013-10-14 16:24:09CU十二周年纪念徽章
日期:2013-10-24 15:41:34狮子座
日期:2013-11-24 19:26:19未羊
日期:2014-01-23 15:50:002015年亚洲杯之阿联酋
日期:2015-05-09 14:36:15
8 [报告]
发表于 2013-12-23 11:06 |只看该作者
回复 1# jhl19880722
内核在做调度的时候不区分线程和进程。top -H

   

论坛徽章:
15
射手座
日期:2014-02-26 13:45:082015年迎新春徽章
日期:2015-03-04 09:54:452015年辞旧岁徽章
日期:2015-03-03 16:54:15羊年新春福章
日期:2015-02-26 08:47:552015年亚洲杯之卡塔尔
日期:2015-02-03 08:33:45射手座
日期:2014-12-31 08:36:51水瓶座
日期:2014-06-04 08:33:52天蝎座
日期:2014-05-14 14:30:41天秤座
日期:2014-04-21 08:37:08处女座
日期:2014-04-18 16:57:05戌狗
日期:2014-04-04 12:21:33技术图书徽章
日期:2014-03-25 09:00:29
7 [报告]
发表于 2013-12-23 08:44 |只看该作者
jhl19880722 发表于 2013-12-21 22:43
在一台4核的计算机上,我做了两个测试程序A,B,在A上面创建4个线程,B上面创建4个进程,每个进程和线程 ...

线程和进程的调度方式是一样的,你看到的top 400%,应该是因为top命令的Irix和线程模式吧,top执行后按H和I,就可以看到区别了。
另外,每个进程都有独立的上下文,4个进程可同时在4个核上执行(当然,还取决于是否有临界资源)
  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP