免费注册 查看新帖 |

Chinaunix

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

prstat 的nlwp参数 [复制链接]

论坛徽章:
1
2015年迎新春徽章
日期:2015-03-04 09:49:03
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-09-04 15:20 |只看该作者 |倒序浏览
bash-3.00# prstat -a\r\n   PID USERNAME  SIZE   RSS STATE  PRI NICE      TIME  CPU PROCESS/NLWP       \r\n25515 mxq       473M  266M sleep   59    0   0:02:25 0.1% java/253\r\n26854 mxq      1177M  443M sleep   59    0   0:01:08 0.1% java/222\r\n   381 root     3344K 2032K sleep   59    0   0:00:35 0.1% top/1\r\n17602 root     3704K 2144K cpu2    59    0   0:00:00 0.0% prstat/1\r\n26240 mxq        59M   44M sleep   59    0   0:00:26 0.0% Far/1009\r\n25365 mxq       110M   54M sleep   59    0   0:00:25 0.0% rmire/27\r\n26400 mxq       383M   96M sleep   59    0   0:00:43 0.0% java/23\r\n27000 mxq       222M   70M sleep   59    0   0:00:14 0.0% java/26\r\n   373 oracle    376M  362M sleep   59    0   0:04:00 0.0% oracle/1\r\n26632 mxq       617M  393M sleep   59    0   0:00:45 0.0% java/27\r\n26056 mxq       987M  275M sleep   59    0   0:00:42 0.0% java/41\r\n   369 oracle    378M  364M sleep   59    0   0:03:22 0.0% oracle/1\r\n   363 oracle    379M  364M sleep   59    0   0:03:09 0.0% oracle/11\r\n25986 mxq      7216K 4784K sleep   59    0   0:00:06 0.0% omim/3\r\n   353 oracle    377M  363M sleep   59    0   0:02:08 0.0% oracle/1\r\n27031 root     1448K 1168K sleep   59    0   0:00:01 0.0% local.sh/1\r\n   120 root     4704K 3400K sleep   59    0   0:00:56 0.0% nscd/25\r\n26437 root     1448K 1168K sleep   59    0   0:00:01 0.0% local.sh/1\r\n26412 mxq      9616K 7368K sleep   59    0   0:00:01 0.0% snmpd/1\r\n   371 oracle    379M  365M sleep   59    0   0:00:46 0.0% oracle/1\r\n   383 oracle    389M  374M sleep   59    0   0:00:09 0.0% oracle/11\r\n23984 root     3128K 2280K sleep   59    0   0:00:00 0.0% bash/1\r\n23515 root     3640K 2296K sleep   59    0   0:00:00 0.0% in.telnetd/1\r\n\r\n使用prstat可以看到系统运行的详细知识。也能看出系统的状态。发现问题。其中nlwp表示轻量线程数。\r\n我发现如果我的某一个应当进程效率低,这个nlwp就非常高,有可能到几千,如果我的系统的性能好,这个数量就比较少,才几十。基本说明是等待结束的线程数,是否可以这样理解?\r\n一般我也会参考这个参数来优化系统性能。

论坛徽章:
2
双鱼座
日期:2014-02-23 12:10:03操作系统版块每日发帖之星
日期:2015-12-17 06:20:00
2 [报告]
发表于 2007-09-04 15:31 |只看该作者
NLWP是进程的轻量级进程,主要用于进程间通信。几个相同根源的进程是共享一个轻量级进程的,这样进程在互相切换时,就不必调用每个进程的上下文,从而大大提高了系统的速度。\r\n上下文进程可以分成多个线程在多个CPU上同时运行,上下文就是线程在虚拟内存中的堆栈中的线程的环境。如果要从一个线程切换到另外一个线程,主要的办法就是切换2个线程的上下文。而原来的线程和他的上下文则被保存起来等待下次调用或者优先级高的线程执行完毕后再切换回原来执行的线程,以继续执行。

论坛徽章:
0
3 [报告]
发表于 2007-09-04 15:34 |只看该作者
NLWP\r\nThe number of lwps in the process\r\n\r\n楼主应该先了解一下关于LWP的知识也许就会明白一些了.\r\nLWP是轻权进程的意识,这里你可以认为它就是CPU,用户空间的线程一旦获得了LWP,也就是说它获得了可执行能力,它可以随时被操作系统调度。\r\n,用户空间的thread和内核空间的LWP并不是一对一的关系,而是N对M的关系,那么由那个线程获得LWP,这个调度的完成是由线程库来完成的,而不需要内核的参与,也就是这种方式的线程上下文切换比较快,并且很明显这种方式更节省内核资源,solaris根据一定的策略提供一个LWP池,供上面更多的线程分享,这种线程就是所说的unbound线程。\r\n用户空间的线程thread和LWP是one-to-one的对应关系,每一个线程都有一个永久的LWP为它服务,很明显这种方式的线程的实时调度性要好,但是这种线程的上下文切换需要KERNEL的参与,并且由于LWP本身是消耗操作系统资源的,因此这种方式要比上面的那种方式浪费资源,这种方式的线程就是所谓的bound线程。\r\n \r\none-level:solaris上可选实现模型\r\n这种模型其实就是提供一致的线程和LWP的one-to-one对应关系,而没有thread和LWP的N对M的关系,很显然one-level模型要更耗系统资源,但是可能会提高程序的效率。\r\n对于要重新编译的程序,可以加上编译选项-R /usr/lib/lwp来采用one-level模型,对于已经编译好的程序,那么在LD_LIBRARY_PATH环境变量设置加上/usr/lib/lwp即可。

论坛徽章:
0
4 [报告]
发表于 2007-09-04 17:49 |只看该作者
我晕了,我是这样理解的:\r\n根据珠老大的几个相同根源的进程是共享一个轻量级进程得出NLWP数字越少性能越好,而根据风大哥的NLWP是cpu的数目即可执行能力得出的是NLWP数字越大性能越好。\r\n可是楼主的实际应用是NLWP数字越少性能越好!

论坛徽章:
1
2015年迎新春徽章
日期:2015-03-04 09:49:03
5 [报告]
发表于 2007-09-04 21:00 |只看该作者
是啊,我也没有看明白。\r\nNLWP\r\nThe number of lwps in the process\r\n这个number是id号码,数字,还是指数量?total count of?\r\n明白这个起码就好理解了。

论坛徽章:
0
6 [报告]
发表于 2007-09-05 09:19 |只看该作者
可不可以这样理解,对于风大哥的“NLWP是cpu的数目即可执行能力”得出相同ID的线程如果需要的cpu的数量多则说明系统机器性能不好或应用需要更多的优化,呵呵\r\nnumber是数量或数目即多少吧!

论坛徽章:
0
7 [报告]
发表于 2007-09-05 10:42 |只看该作者
我晕.最佳答案居然是man.\r\n\r\nLWP是轻权进程的意识,这里你可以认为它就是CPU,用户空间的线程一旦获得了LWP,也就是说它获得了可执行能力,它可以随时被操作系统调度。\r\n,用户空间的thread和内核空间的LWP并不是一对一的关系,而是N对M的关系,那么由那个线程获得LWP,这个调度的完成是由线程库来完成的,而不需要内核的参与,也就是这种方式的线程上下文切换比较快,并且很明显这种方式更节省内核资源,solaris根据一定的策略提供一个LWP池,供上面更多的线程分享,这种线程就是所说的unbound线程。\r\n\r\n和蜘蛛回答的差不多吗?提高了上下文的切换.

论坛徽章:
1
2015年迎新春徽章
日期:2015-03-04 09:49:03
8 [报告]
发表于 2007-09-05 11:09 |只看该作者
哈哈只在乎能否有好的知识,那个分数是无所谓的了。可以再开一个帖子给大家发分数。\r\n其实都想颁给两个老大,可是一个分数不能掰成两半。\r\n那就是说,那个数量少可能预示着系统性能会好,如果多,可能会预示性能需要优化?

论坛徽章:
1
2015年迎新春徽章
日期:2015-03-04 09:49:03
9 [报告]
发表于 2007-09-05 22:51 |只看该作者
那大家谁总结一下,我的这个说法是否正确?或者接近正确?

论坛徽章:
1
2015年迎新春徽章
日期:2015-03-04 09:49:03
10 [报告]
发表于 2007-10-19 15:20 |只看该作者
那大家分析一下,虽然明白了原理,但是如果那个nlwp是那么多,现在我的某个应用可能是7000多了,不知道代表什么?是否代表有zombie的线程?\r\n我看了一下oracle,如果分配的session数为250,有时候就能看到oracle的nlwp为258,从来没有更多过。说明oracle在这方面控制得好。\r\n但是对于我们自己开发的应用服务器,如果达到7000了,那说明有zombie的吧?
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP