用户可以再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也在等待其他资源释放才能继续。这就是有些网友碰见的问题:同一个测试场景,用线程并发就会超时失败或报错,而用进程并发就没错。{摘自【性能测试从零开始】}