LR的controller的Vuser的线程和进程

上一篇 / 下一篇  2012-05-07 16:45:42 / 个人分类:性能测试

  用户可以再Controller的run time setting中选择Vuser的运行方式:多线程/多进程。多进程和多线程的区别是:

  Controller将使用驱动程序mdrv运行Vuser。如果按进程方式运行每个Vuser,则对于每个Vuser实例,都将启动一个mdrv进程。多个mdrv进程会占用大量内存及其他系统资源,这就限制了可以在任一负载生成器上运行的Vuser的数量。如果选择按线程方式运行,在默认情况下,Controller为每50个vuser仅启动一个mdrv.exe进程,而每个vuser都按线程运行,这些线程vuser将共享父进程的内存段。这就节省了大量内存空间,从而可以再一个负载生成器上运行更多的Vuser。

  但任何选择都是有两面性的。选择线程方式运行Vuser会带来一些安全问题。因为线程的资源是从进程资源中分配出来的,因此同一个进程中的多个线程会有共享的内存空间,这样可能会引起多个线程的同步问题,调度不好,就会出现问题。比如A线程要用的资源必须等待B线程释放,而B也在等待其他资源释放才能继续。这就是有些网友碰见的问题:同一个测试场景,用线程并发就会超时失败或报错,而用进程并发就没错。{摘自【性能测试从零开始】}


TAG:

 

评分:0

我来说两句

日历

« 2024-05-15  
   1234
567891011
12131415161718
19202122232425
262728293031 

数据统计

  • 访问量: 27109
  • 日志数: 26
  • 建立时间: 2011-05-07
  • 更新时间: 2012-07-20

RSS订阅

Open Toolbar