免费注册 查看新帖 |

Chinaunix

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

哪位老大帮忙看一下问题出在那里:(有关进程管理方面的) [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2003-05-24 19:48 |只看该作者 |倒序浏览
我是在SCO UNIX5。0。5下面开发的
    有五个进程交互工作每一个进程都阻塞地读队列的数据。
我做压力测试时第一个进程所读的队列里数据是满的(这个进程所读队列里的数据是由一个专门的发包程序来写队列的,发的是固定包速度很快,而这个进程的处理速度比其他的进程处理来得慢,而其他进程所处理的数据是在他处理完了再组一个包并放在另外的队列里由其他的进程处理),其他的进程的处理的速度很快,他们所读的队列一般很少或是为空。    在测试过程中我用sar -u 1 6 进程观察的结果如下  
        idle :100%  100%   98%   100%    68%   0%
为什么出现这种情况呢?照理只要第一个进程所读的队列里有数据,系统就不应该这样啊?    我想是不是通过进程调度来解决,是怎样解决呢?
     谢谢先了!

论坛徽章:
0
2 [报告]
发表于 2003-05-24 20:23 |只看该作者

哪位老大帮忙看一下问题出在那里:(有关进程管理方面的)

第一个进程读了以后就分别送给其余的四队列?

论坛徽章:
0
3 [报告]
发表于 2003-05-24 20:39 |只看该作者

哪位老大帮忙看一下问题出在那里:(有关进程管理方面的)

不是,根据业务区分后,对应放在另外两个队列里由另外两个进程读,我做了这样的测试:当第一个进程从队列里读数据做处理后没有往上面所说的那两个队列里读的话,好象没有这种情况,
       我想是不是需要作一下低级调度(提高CPU的利用率),还是别的方法解决?
     非常希望能得到各位高手的提示。

论坛徽章:
0
4 [报告]
发表于 2003-05-24 22:16 |只看该作者

哪位老大帮忙看一下问题出在那里:(有关进程管理方面的)

对不起:   “当第一个进程从队列里读数据做处理后没有往上面所说的那两个队列里读的话,好象没有这种情况,

应该是 ”往上面所说的那两个队列里写“

论坛徽章:
0
5 [报告]
发表于 2003-05-26 17:36 |只看该作者

哪位老大帮忙看一下问题出在那里:(有关进程管理方面的)

我想问题出在你的压力测试的方法上
前面100%的CPU利用率,应该是你的测试包写入程序作用,占用了大部分的CPU利用率;
到后来,CPU下降,因为你的队列里塞满了消息,甚至可能队列的缓存区已经溢出,这是写包程序肯定要慢下来,同时你的读包程序也由于队列的消息塞满的原因,取的速度也明显变慢,甚至无法读取报文。
所以,应该改进你的压力测试方法,也就是你的发包程序应该控制一下流量。

论坛徽章:
0
6 [报告]
发表于 2003-05-26 17:51 |只看该作者

哪位老大帮忙看一下问题出在那里:(有关进程管理方面的)

你第一个处理进程速度慢是什么原因呢?
是不是用sleep人为降低了处理速度呢?如果是这样,你的测试结果就很正常。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP