51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 4821|回复: 15
打印 上一主题 下一主题

[原创] LoadRunner如何测试Tomcat服务器的用户容量

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2011-12-15 16:32:27 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
RT  看了不少资料但是还是不清楚怎么用LR进行测试
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏
回复

使用道具 举报

该用户从未签到

2#
发表于 2011-12-16 09:12:32 | 只看该作者
关注中……
回复 支持 反对

使用道具 举报

该用户从未签到

3#
发表于 2011-12-16 09:12:38 | 只看该作者
关注中……
回复 支持 反对

使用道具 举报

该用户从未签到

4#
发表于 2011-12-16 14:43:53 | 只看该作者
关注中、、、、
回复 支持 反对

使用道具 举报

该用户从未签到

5#
发表于 2011-12-16 17:11:37 | 只看该作者
关注中、、、、
回复 支持 反对

使用道具 举报

  • TA的每日心情
    郁闷
    2015-6-16 14:29
  • 签到天数: 1 天

    连续签到: 1 天

    [LV.1]测试小兵

    6#
    发表于 2011-12-17 10:36:10 | 只看该作者
    你关注几个点, maxThreads="600" minSpareThreads="100" maxSpareThreads="300",设计个简单页面,然后进行并发测试。用户等级以20%递增,看看tomcat服务终端显示,是否有错误。一般报两个,一个是线程繁忙,一个就是out of memory。
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    开心
    2015-12-11 09:58
  • 签到天数: 38 天

    连续签到: 2 天

    [LV.5]测试团长

    7#
    发表于 2011-12-17 17:13:01 | 只看该作者
    看资料了,就按资料上说的实践一下,再提问题就会慢慢知道了!
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    8#
    发表于 2011-12-18 20:48:06 | 只看该作者
    回复 6# 森林一木


        支持;
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    9#
    发表于 2011-12-19 09:41:24 | 只看该作者
    回复 6# 森林一木


        请教一下啊,按着您的方法,我查看了一下我所在web项目的Tomcat配置文件server.xml
    发现<!--
        <Executor name="tomcatThreadPool" namePrefix="catalina-exec-"
            maxThreads="150" minSpareThreads="4"/>
    被禁掉了
    那我接下来该如何测试Tomcat呢
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    10#
    发表于 2011-12-23 16:39:27 | 只看该作者
    学习中
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    11#
    发表于 2011-12-23 17:54:46 | 只看该作者
    回复 6# 森林一木

    还有一个重要的参数:
    1、超时时间的设置,如果设置的超时间长了,性能的差别很大 ;
    2、内存的参数
    3、硬件的配置(CPU,IO)
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    12#
    发表于 2011-12-24 22:38:32 | 只看该作者
    本帖最后由 逝水流年 于 2011-12-25 00:17 编辑

    Tomcat 我只测试过一个简单的应用,下面附上我之前看的参数的设置建议。 那时只是帮一个同事简单测了下,做了一些对比测试。Tomcat 只用过一次不是很熟 说下那时的做法,可能有些地方不对,望高手能指正。先明白里面参数的作用,connector的maxThreads
    minSpareThreads, maxSpareThreads    keepAliveTimeout   这几个参数 的设置  你要考虑到上面部署的web应用,访问是相对比较平缓还是变化很剧烈。 你可以先对并发用户数有个估算,然后设置maxTheads的值,用LR压下看,关注下CPU的状态以及TPS   如果CPU中的S有点高,应该是线程数设置过大,导致操作系统内核的时间比例有点高,适当降低maxThreads。但是也不能设置太低,不然CPU等系统资源得不到充分的利用,如果你的请求比较轻,maxThreads在CPU的S不高的情况可以设置大些,但是对于请求比较重的话,maxThreads尽量往小点设置。  其他的maxSpareThreads  ,minSpareThreads 以及 keepAliveTimeout   的设置要根据应用类型来,访问比较平稳的话 尽量往小的方向设置,要是访问变化太大,maxSpareThreads  ,minSpareThreads 可以稍微往大的方向设置,方向是避免频繁的创建thread和销毁thread ,导致CPU的S比例过高,从而影响性能,操作系统的S比例不能过高(个人觉得5%以内合适)。  总的方向是朝着最大化利用CPU等资源,同时也能支持一定量的高并发。其他的一些网络的参数设置,是不是按默认值来设定,以及是否需要调整,需要监控下网络的情况再诊断。 这是我的一些想法,由于只测试了一次,tomcat也基本不怎么用, 不知道是不是你所说的测试Tomcat 服务器的用户容量。我的理解是CPU等资源充分利用,响应时间合理前提下能支持的最大并发用户数。如果不是,继续交流。
    的connector

    Tomcat性能参数设置

    1、修改启动时内存参数:

    在Tomcat上运行j2ee项目代码时,经常会出现内存溢出的情况,解决办法是在系统参数中增加系统参数:

    window下, 在catalina.bat最前面:
    set JAVA_OPTS=-XX:PermSize=64M -XX:MaxPermSize=128m -Xms512m -Xmx1024m;-Duser.timezone=GMT+08;
    一定加在catalina.bat最前面。

    linux下,在catalina.sh最前面增加:
    JAVA_OPTS="-XX:PermSize=64M -XX:MaxPermSize=128m -Xms512m -Xmx1024m -Duser.timezone=Asia/Shanghai"

    注意:前后二者区别,有无set,有无双引号。


    2、线程池配置(Tomcat6下)
    使用线程池,用较少的线程处理较多的访问,可以提高tomcat处理请求的能力。使用方式:
    首先。打开/conf/server.xml,增加
    <Executor name="tomcatThreadPool" namePrefix="catalina-exec-"
            maxThreads="500" minSpareThreads="20" maxIdleTime="60000" />
    最大线程500(一般服务器足以),最小空闲线程数20,线程最大空闲时间60秒。
    然后,修改<Connector ...>节点,增加executor属性,如:
    <Connector executor="tomcatThreadPool"
                   port="80"
    protocol="HTTP/1.1"
    maxThreads="600"
    minSpareThreads="100"
    maxSpareThreads="300"
                   connectionTimeout="60000"
                   keepAliveTimeout="15000"
                   maxKeepAliveRequests="1"
                   redirectPort="443"
                   ....../>
    maxThreads:Tomcat可创建的最大的线程数,每一个线程处理一个请求;
    minSpareThreads:最小备用线程数,tomcat启动时的初始化的线程数;
    maxSpareThreads:最大备用线程数,一旦创建的线程超过这个值,Tomcat就会关闭不再需要的socket线程;
    acceptCount:指定当所有可以使用的处理请求的线程数都被使用时,可以放到处理队列中的请求数,就是被排队的请求数,超过这个数的请求将拒绝连接。
    connnectionTimeout:网络连接超时,单位:毫秒。设置为0表示永不超时,这样设置有隐患的。通常可设置为30000毫秒。
    enableLookups:是否允许DNS查询

    注意:可以多个connector公用1个线程池。

    3、调整连接相关Connector的参数:
    <Connector executor="tomcatThreadPool"
                   port="80" protocol="HTTP/1.1"
                   connectionTimeout="60000"
                   keepAliveTimeout="15000"
                   maxKeepAliveRequests="1"
                   redirectPort="443"
                   maxHttpHeaderSize="8192" URIEncoding="UTF-8" enableLookups="false" acceptCount="100" disableUploadTimeout="true"/>

    参数说明:

            * connectionTimeout - 网络连接超时,单位:毫秒。设置为0表示永不超时,这样设置有隐患的。通常可设置为30000毫秒。
            * keepAliveTimeout - 长连接最大保持时间(毫秒)。此处为15秒。
            * maxKeepAliveRequests - 最大长连接个数(1表示禁用,-1表示不限制个数,默认100个。一般设置在100~200之间) the maximum number of HTTP requests that can be held in the pipeline until the connection is closed by the server. Setting this attribute to 1 disables HTTP/1.0 keep-alive, as well as HTTP/1.1 keep-alive and pipelining. Setting this to -1 allows an unlimited number of pipelined or keep-alive HTTP requests. If not specified, this attribute is set to 100.
            * maxHttpHeaderSize - http请求头信息的最大程度,超过此长度的部分不予处理。一般8K。
            * URIEncoding - 指定Tomcat容器的URL编码格式。
            * acceptCount - 指定当所有可以使用的处理请求的线程数都被使用时,可以放到处理队列中的请求数,超过这个数的请求将不予处理,默认为10个。defines the maximum queue length for incoming connection requests when all possible request processing threads are in use. Any requests received when the queue is full are refused. The default value is 10.
            * disableUploadTimeout - 上传时是否使用超时机制
            * enableLookups - 是否反查域名,取值为:true或false。为了提高处理能力,应设置为false
            * bufferSize - defines the size (in bytes) of the buffer to be provided for input streams created by this connector. By default, buffers of 2048 bytes are provided.
            * maxSpareThreads - 做多空闲连接数,一旦创建的线程超过这个值,Tomcat就会关闭不再需要的socket线程 the maximum number of unused request processing threads that are allowed to exist until the thread pool starts stopping the unnecessary threads. The default value is 50.
            * maxThreads - 最多同时处理的连接数,Tomcat使用线程来处理接收的每个请求。这个值表示Tomcat可创建的最大的线程数。。 the maximum number of request processing threads to be created by this Connector, which therefore determines the maximum number of simultaneous requests that can be handled. If not specified, this attribute is set to 200.
            * minSpareThreads - 最小空闲线程数,Tomcat初始化时创建的线程数 the number of request processing threads that are created when this Connector is first started. The connector will also make sure it has the specified number of idle processing threads available. This attribute should be set to a value smaller than that set for maxThreads. The default value is 4.
            * minProcessors - 最小空闲连接线程数,用于提高系统处理性能,默认值为10。(用于Tomcat4中)
            * maxProcessors - 最大连接线程数,即:并发处理的最大请求数,默认值为75。(用于Tomcat4中)


    备注:
    Tomcat4中可以通过修改minProcessors和maxProcessors的值来控制线程数。
    在Tomcat5+主要对以下参数调整
    maxThreads
    Tomcat使用线程来处理接收的每个请求。这个值表示Tomcat可创建的最大的线程数。
    acceptCount
    指定当所有可以使用的处理请求的线程数都被使用时,可以放到处理队列中的请求数,超过这个数的请求将不予处理。
    connnectionTimeout
    网络连接超时,单位:毫秒。设置为0表示永不超时,这样设置有隐患的。通常可设置为30000毫秒。
    minSpareThreads
    Tomcat初始化时创建的线程数。
    maxSpareThreads
    一旦创建的线程超过这个值,Tomcat就会关闭不再需要的socket线程。  


    4、负载均衡、集群的配置
    Tomcat6支持分布式部署,可以实现集群功能,提高响应能力。

    5、
    利用JMX监控Tomcat运行情况,需要手工调整启动参数,如下:
    打开cataline.bat,增加一行
    set JAVA_OPTS=%JAVA_OPTS% -Dcom.sun.management.jmxremote.port=10090 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager -Djava.util.logging.config.file="%CATALINA_BASE%\conf\logging.properties"

    linux下修改cataline.sh:
    JAVA_OPTS="-Dcom.sun.management.jmxremote.port=10090 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager -Djava.util.logging.config.file=%CATALINA_BASE\conf\logging.properties"
    注意JDK\jre\lib\management\management.properties文件必须存在。

    重新启动tomcat节点,然后用jconsole连接(此处端口wei10090)

    6、Tomcat增加一个应用
    在server.xml的Host标签中增加行
    <Context displayName="OA" docBase="/app/web-apps/GACWP" path="" />
    path代表上下文名称,空表示是根路径。
    回复 9# ymwang119
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    13#
    发表于 2011-12-25 00:52:53 | 只看该作者
    为什么我24号22.38分回复的内容不见了,前几天也发现了类似的问题,是不是本网站出现了数据丢失,还是数据不同步,奇怪了??
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    14#
    发表于 2011-12-25 11:47:36 | 只看该作者
    本帖最后由 逝水流年 于 2011-12-25 12:19 编辑

    tomcat我只用过一次,是帮一个同事测的TT(memory cache)的现学了下,工作中也基本不怎么用,下面附上那次测试的一些感受,可能有些地方描述的不合理。忘高手指正

    LoadRunner如何测试Tomcat服务器的用户容量
    一.测试策略
    1.        先明白server.xml 配置文件中各种参数的作用,明白那些设置是需要调整的,下面会附上参数的具体作用。
    2.        先在tomcat上部署web应用,然后设置heap的size,注意32位和64位的区别。32的寻址空间最大3G限制 还需要预留一部分给permsize,64位的可以设置很大。但是太大会增加每次GC的持续时间,heapsize也并不是越大越好,够用就行,你可以通过测试得到一个合理的值,避免出现OOM,同时尽量把GC对系统性能的影响降到最低
    3.        部署好应用,heap设置好了以后,先估计个并发用户数,可以稍微设置大一些,500以上应该是没问题的,用LR去压一下,监控CPU的状态,如果CPU的S比例占的比较高,说明线程数设置大了,线程调度过于频繁,然后开始调小线程数,但是也不能设置太低,不然CPU等系统资源得不到充分的利用,如果你的请求比较轻,maxThreads在CPU的S不高的情况可以设置大些,但是对于请求比较重的话,maxThreads尽量往小点设置。  其他的maxSpareThreads  ,minSpareThreads 以及 keepAliveTimeout   的设置要根据应用类型来,访问比较平稳的话 尽量往小的方向设置,要是访问变化太大,maxSpareThreads  ,minSpareThreads 可以稍微往大的方向设置,方向是避免频繁的创建thread和销毁thread ,导致CPU的S比例过高,从而影响性能,操作系统的S比例不能过高(个人觉得5%以内合适)。总的方向是朝着最大化利用CPU等资源,同时也能支持一定量的高并发。其他的一些网络的参数设置,是不是按默认值来设定,以及是否需要调整,需要监控下网络的情况再诊断。 这是我的一些想法,由于只测试了一次,tomcat也基本不怎么用, 不知道是不是你所说的测试Tomcat 服务器的用户容量。我的理解是在系统的状态正常,响应时间合理的前提下,tomcat能支持的最大并发数。
    二.        Tomcat性能参数
    默认参数不适合生产环境使用,因此需要修改一些参数
    1、修改启动时内存参数:
    在Tomcat上运行j2ee项目代码时,经常会出现内存溢出的情况,解决办法是在系统参数中增加系统参数:
    window下, 在catalina.bat最前面:
    set JAVA_OPTS=-XX:PermSize=64M -XX:MaxPermSize=128m -Xms512m -Xmx1024m;-Duser.timezone=GMT+08;
    一定加在catalina.bat最前面。
    linux下,在catalina.sh最前面增加:
    JAVA_OPTS="-XX:PermSize=64M -XX:MaxPermSize=128m -Xms512m -Xmx1024m -Duser.timezone=Asia/Shanghai"
    注意:前后二者区别,有无set,有无双引号。
    2、线程池配置(Tomcat6下)
    使用线程池,用较少的线程处理较多的访问,可以提高tomcat处理请求的能力。使用方式:
    首先。打开/conf/server.xml,增加
    <Executor name="tomcatThreadPool" namePrefix="catalina-exec-"
            maxThreads="500" minSpareThreads="20" maxIdleTime="60000" />
    最大线程500(一般服务器足以),最小空闲线程数20,线程最大空闲时间60秒。
    然后,修改<Connector ...>节点,增加executor属性,如:
    <Connector executor="tomcatThreadPool"
                   port="80"
    protocol="HTTP/1.1"
    maxThreads="600"
    minSpareThreads="100"
    maxSpareThreads="300"
                   connectionTimeout="60000"
                   keepAliveTimeout="15000"
                   maxKeepAliveRequests="1"
                   redirectPort="443"
                   ....../>
    maxThreads:Tomcat可创建的最大的线程数,每一个线程处理一个请求;
    minSpareThreads:最小备用线程数,tomcat启动时的初始化的线程数;
    maxSpareThreads:最大备用线程数,一旦创建的线程超过这个值,Tomcat就会关闭不再需要的socket线程;
    acceptCount:指定当所有可以使用的处理请求的线程数都被使用时,可以放到处理队列中的请求数,就是被排队的请求数,超过这个数的请求将拒绝连接。
    connnectionTimeout:网络连接超时,单位:毫秒。设置为0表示永不超时,这样设置有隐患的。通常可设置为30000毫秒。
    enableLookups:是否允许DNS查询
    注意:可以多个connector公用1个线程池。
    3、调整连接相关Connector的参数:
    <Connector executor="tomcatThreadPool"
                   port="80" protocol="HTTP/1.1"
                   connectionTimeout="60000"
                   keepAliveTimeout="15000"
                   maxKeepAliveRequests="1"
                   redirectPort="443"
                   maxHttpHeaderSize="8192" URIEncoding="UTF-8" enableLookups="false" acceptCount="100" disableUploadTimeout="true"/>
    参数说明:
    •        connectionTimeout - 网络连接超时,单位:毫秒。设置为0表示永不超时,这样设置有隐患的。通常可设置为30000毫秒。
    •        keepAliveTimeout - 长连接最大保持时间(毫秒)。此处为15秒。
    •        maxKeepAliveRequests - 最大长连接个数(1表示禁用,-1表示不限制个数,默认100个。一般设置在100~200之间) the maximum number of HTTP requests that can be held in the pipeline until the connection is closed by the server. Setting this attribute to 1 disables HTTP/1.0 keep-alive, as well as HTTP/1.1 keep-alive and pipelining. Setting this to -1 allows an unlimited number of pipelined or keep-alive HTTP requests. If not specified, this attribute is set to 100.
    •        maxHttpHeaderSize - http请求头信息的最大程度,超过此长度的部分不予处理。一般8K。
    •        URIEncoding - 指定Tomcat容器的URL编码格式。
    •        acceptCount - 指定当所有可以使用的处理请求的线程数都被使用时,可以放到处理队列中的请求数,超过这个数的请求将不予处理,默认为10个。defines the maximum queue length for incoming connection requests when all possible request processing threads are in use. Any requests received when the queue is full are refused. The default value is 10.
    •        disableUploadTimeout - 上传时是否使用超时机制
    •        enableLookups - 是否反查域名,取值为:true或false。为了提高处理能力,应设置为false
    •        bufferSize - defines the size (in bytes) of the buffer to be provided for input streams created by this connector. By default, buffers of 2048 bytes are provided.
    •        maxSpareThreads - 做多空闲连接数,一旦创建的线程超过这个值,Tomcat就会关闭不再需要的socket线程 the maximum number of unused request processing threads that are allowed to exist until the thread pool starts stopping the unnecessary threads. The default value is 50.
    •        maxThreads - 最多同时处理的连接数,Tomcat使用线程来处理接收的每个请求。这个值表示Tomcat可创建的最大的线程数。。 the maximum number of request processing threads to be created by this Connector, which therefore determines the maximum number of simultaneous requests that can be handled. If not specified, this attribute is set to 200.
    •        minSpareThreads - 最小空闲线程数,Tomcat初始化时创建的线程数 the number of request processing threads that are created when this Connector is first started. The connector will also make sure it has the specified number of idle processing threads available. This attribute should be set to a value smaller than that set for maxThreads. The default value is 4.
    •        minProcessors - 最小空闲连接线程数,用于提高系统处理性能,默认值为10。(用于Tomcat4中)
    •        maxProcessors - 最大连接线程数,即:并发处理的最大请求数,默认值为75。(用于Tomcat4中)
    备注:
    Tomcat4中可以通过修改minProcessors和maxProcessors的值来控制线程数。
    在Tomcat5+主要对以下参数调整
    maxThreads
    Tomcat使用线程来处理接收的每个请求。这个值表示Tomcat可创建的最大的线程数。
    acceptCount
    指定当所有可以使用的处理请求的线程数都被使用时,可以放到处理队列中的请求数,超过这个数的请求将不予处理。
    connnectionTimeout
    网络连接超时,单位:毫秒。设置为0表示永不超时,这样设置有隐患的。通常可设置为30000毫秒。
    minSpareThreads
    Tomcat初始化时创建的线程数。
    maxSpareThreads
    一旦创建的线程超过这个值,Tomcat就会关闭不再需要的socket线程。  
    4、负载均衡、集群的配置
    Tomcat6支持分布式部署,可以实现集群功能,提高响应能力
    5、
    利用JMX监控Tomcat运行情况,需要手工调整启动参数,如下:
    打开cataline.bat,增加一行
    set JAVA_OPTS=%JAVA_OPTS% -Dcom.sun.management.jmxremote.port=10090 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager -Djava.util.logging.config.file="%CATALINA_BASE%\conf\logging.properties"
    linux下修改cataline.sh:
    JAVA_OPTS="-Dcom.sun.management.jmxremote.port=10090 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager -Djava.util.logging.config.file=%CATALINA_BASE\conf\logging.properties"
    注意JDK\jre\lib\management\management.properties文件必须存在。
    重新启动tomcat节点,然后用jconsole连接(此处端口wei10090)
    6、Tomcat增加一个应用
    在server.xml的Host标签中增加行
    <Context displayName="OA" docBase="/app/web-apps/GACWP" path="" />
    path代表上下文名称,空表示是根路径。
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    15#
    发表于 2011-12-28 17:45:51 | 只看该作者
    进来一起聊聊
    软件测试开发(已满)
    172709641  软件测试开发联盟①
    51570236    软件测试开发联盟②
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    16#
    发表于 2011-12-29 09:23:17 | 只看该作者
    学习中。。。。。。
    回复 支持 反对

    使用道具 举报

    本版积分规则

    关闭

    站长推荐上一条 /1 下一条

    小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

    GMT+8, 2024-11-16 00:50 , Processed in 0.076949 second(s), 25 queries .

    Powered by Discuz! X3.2

    © 2001-2024 Comsenz Inc.

    快速回复 返回顶部 返回列表