关于LR的进程和线程问题

进程和线程的区别是什么?
简而言之,一个程序至少有一个进程,一个进程至少有一个线程. 线程的划分尺度小于进程,使得多线程程序的并发性高。另外,进程在执行过程中拥有独立的内存单元,而多个线程共享内存,从而极大地提高了程序的运行效率。

线程在执行过程中与进程还是有区别的。每个独立的线程有一个程序运行的入口、顺序执行序列和程序的出口。但是线程不能够独立执行,必须依存在应用程序中,由应用程序提供多个线程执行控制。

从逻辑角度来看,多线程的意义在于一个应用程序中,有多个执行部分可以同时执行。但操作系统并没有将多个线程看做多个独立的应用,来实现进程的调度和管理以及资源分配。这就是进程和线程的重要区别。

简单举例:使用10个VU用户并发

当使用进程并发时,在任务管理器中会出现10个mdrv进程

当使用线程并发,只会出现一个mmdrv进程(一个进程可以支持50VU的线程并发)

所以:使用多线程的方法能使每台负载生成器运行更多的VU

(但是只有支持线程安全的协议,才能使用Loadrunner的VU并发方式。

以下协议不能支持线程并发Sybase-Dblib,Infomix,Tuxedo,and PeopleSoft-Tuxedo)

进程方式和线程方式的优缺点:

选择按照进程方式运行, 每个用户都将启动一个mmdrv进程,多个mmdrv进程会占用大量内存及其他系统资源,这就限制了可以在任一负载生成器上运行的并发用户数的数量,因为负载机的资源(内存及其他系统资源)是有限的。

扫描二维码关注公众号,回复: 5900179 查看本文章

选择按照线程方式运行,在默认情况下,controller为每50个用户仅启动一个mdrv进程,而每个用户都按线程方式来运行,这些线程用户将共享父进程的内存段,这就节省了大量内存空间,从而可以在一个负载生成器上运行更多的用户。

选择线程方式虽然可以减少启动的mmdrv进程数,减少了内存的占用,但是也容易出现一个问题,例如,同一个测试场景,用线程并发就会出现超时失败或报错,而用进程并发就没错。为什么呢?因为线程的资源是从进程资源中分配出来的,因此同一个进程中的多个线程会有共享的内存空间,假设a线程要用资源就必须等待b线程释放,而b线程也在等待其他资源释放才能继续,这样就会出现这个问题。

所以如果在并发时出现报错,可尝试下修改并发用户运行方式。

LR设置虚拟用户运行方式的方法:

虚拟用户以线程还是进程的方式运行,对被测服务器的压力是完全不同的,loadrunner中有3个地方涉及到虚拟用户的运行方式,分别是:

1、在Vug->run-time settings->miscellane->multithreading中可以设置虚拟用户是以线程还是进程的方式运行

2、在controller中设置场景时,是以单场景模式运行还是以场景组方式运行,在这两种不同的运行方式下,虚拟用户的运行方式也是不同的

3、在controller中使用IP欺骗时,在专家模式下的tools->options->general->multiple IP address mode中也可以选择每个IP是以线程还是进程方式运行。

再介绍一下这三个设置线程和进程之间的关系:

l run-time settings中的设置与controller中单场景和场景组的关系:

虚拟用户是以线程还是进程方式运行是在Vug->run-time settings中设置的;

controller中如果使用单场景运行,那么该场景中无论有多少个脚本、多少个负载生成器,运行这些脚本的虚拟用户均依照Vug->run-time settings中设置的线程还是进程方式运行;

但是如果在controller中如果以场景组方式运行时,每个场景组均会作为一个进程被启动,而每个组中的用户又是按照Vug->run-time settings中设置的线程还是进程方式运行。

lcontroller中使用IP欺骗时

如果选择的是进程方式:

1、如果这个ip是在单场景中,那么有几个不同的ip负载生成器就会启动几个进程,每个负载生成器的虚拟用户的运行方式仍然按照Vug->run-time settings中设置的线程还是进程方式运行

2、如果是在场景组中运行,这就要看场景组是如何设置的了,有两种情况:

a、每个场景组中添加一个虚拟ip,这时运行每个场景组时只启动一个进程

b、每个场景组中添加多个虚拟ip,这时运行每个场景组时,每个场景组启动一个进程,每个ip启动一个进程,每个ip的虚拟用户的运行方式按照Vug->run-time settings中设置的线程还是进程方式运行

如果选择的是线程方式:

1、如果这个ip是在单场景中,那么对于不同的ip的负载生成器只会启动一个进程,每个负载生成器的虚拟用户的运行方式仍然按照Vug->run-time settings中设置的线程还是进程方式运行

2、如果是在场景组中运行,每个场景组启动一个进程,所有ip以线程的方式在组进程中运行,每个ip的虚拟用户的运行方式按照Vug->run-time settings中设置的线程还是进程方式运行

猜你喜欢

转载自blog.csdn.net/weixin_41918841/article/details/89314007