Jmeter运行原理

        最起初接触Jmeter的时候,就感觉好神秘的样子,始终不了解Jmeter到底是什么东东, 慢慢的才了解了,

        本文内容摘自《全栈性能测试修炼宝典Jmeter实战》,大家有兴趣可以看看这本书,还是比较全面的

       下面我们来了解Jmeter的运行原理.

        接触过LoadRunner的读者都知道,LoadRunner 可以选择是以进程方式还是以线程方式来运行,在Jmeter中我们是以线程的方式来运行的,由于Jmeter是运行在JVN虚拟机上的,每个进程的开销比LoadRunner的进程开销要大,如果以进程的方式来运行的话,每台负载机上的进程数量就不会允许太多,当我们要大量并发时就需要大量的负载机,这显然是不经济的,再者Java也是支持多线程的,所以JMeter选择了以线程方式来运行.

          JMeter通过线程组来驱动多个线程,(类似LoadRunner 中的虚拟用户)运行测试脚本对被测服务器发生负载,每个负载机上都可以运行多个线程组,如图此计划中就有两个线程组,JMeter运行场景不仅可以在GUI(图形用户界面)方式中完成,还可以使用命令行,而且命令行运行的方式对于负载机的资源消耗会更小

Jmeter运行原理_第1张图片

   

       JMeter基本原理是建立一个线程池,多线程运行去延期产生大量负载,在运行过程中通过断言来验证结果的正确性,通过监听器来记录测试结果

      JMeter可以作为Web服务器与浏览器之间的代理网关,以便捕获浏览器的请求和Web服务器的响应,这样就很容易地生成性能测试脚本, 有了性能测试脚本,JMeter就可以通过线程组来模拟真实用户对Web服务器的访问压力

      我也不太了解进程和线程到底有什么?????????

     以下均来着网上某大神,我只是知识的搬运工……

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

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

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

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

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

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

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

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

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

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

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

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

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

感觉有点复杂,我明天再请教下其他小伙伴吧!

你可能感兴趣的:(jmeter)