zoukankan      html  css  js  c++  java
  • Nginx和Tomcat优化

    1)、nginx优化

    这里只说nginx的简单优化,即让nginx处理html静态文件,图片,css,js等非动态文件,讲jsp文件交给tomcat处理,这样的话可以减轻tomcat的压力,再说对于这些静态文件来说,不是tomcat的强项,而是nginx的强项。

    请在nginx.conf中添加如下配置

    location ~ .*.(gif|jpg|jpeg|png|bmp|ico)$ {
    root /www/; #即图片存在的根路径
    expires 30d;
    }

    location ~ .*.(js|css)?$ {
    root /www/;#即图文件存在的根路径
    expires 10h;
    }

    还可以将worker_processes  2; #处理线程更改为cpu的倍数,即cpu*2。最后附上详细饿nginx配置文件供参考

    2)、tomcat优化,

    1、修改tomcat的并发线程和默认处理方式为nio

    这里以tomcat7为例,修改tomcat/conf/server.xml中Connector节点为

        <Connector port="8080" protocol="org.apache.coyote.http11.Http11NioProtocol"
                  maxThreads="1000" minSpareThreads="25" maxSpareThreads="250"
                  enableLookups="false" redirectPort="8443" acceptCount="300" connectionTimeout="20000" disableUploadTimeout="true"/>  

    2、tomcat的几种connector方式简介

    Tomcat的四种基于HTTP协议的Connector性能比较
    <Connector port="8081" protocol="org.apache.coyote.http11.Http11NioProtocol"                          

    connectionTimeout="20000" redirectPort="8443"/>
    <Connector port="8081" protocol="HTTP/1.1" connectionTimeout="20000"
                   redirectPort="8443"/>
    <Connector executor="tomcatThreadPool"
                   port="8081" protocol="HTTP/1.1"
                   connectionTimeout="20000"
                   redirectPort="8443" />
    <Connector executor="tomcatThreadPool"
                   port="8081" protocol="org.apache.coyote.http11.Http11NioProtocol"
                   connectionTimeout="20000"
                   redirectPort="8443" />
    我们姑且把上面四种Connector按照顺序命名为 NIO, HTTP, POOL, NIOP
    为了不让其他因素影响测试结果,我们只对一个很简单的jsp页面进行测试,这个页面仅仅是输出一个Hello World。假设地址是 http://tomcat1/test.jsp
    我们依次对四种Connector进行测试,测试的客户端在另外一台机器上用ab命令来完成,测试命令为: ab -c 900 -n 2000 http://tomcat1/test.jsp ,最终的测试结果如下表所示(单位:平均每秒处理的请求数):

    NIO HTTP POOL NIOP
    281 65 208 365
    666 66 110 398
    692 65 66 263
    256 63 94 459
    440 67 145 363

    由这五组数据不难看出,HTTP的性能是很稳定,但是也是最差的,而这种方式就是Tomcat的默认配置。NIO方式波动很大,但没有低于280 的,NIOP是在NIO的基础上加入线程池,可能是程序处理更复杂了,因此性能不见得比NIO强;而POOL方式则波动很大,测试期间和HTTP方式一样,不时有停滞。
    由于linux的内核默认限制了最大打开文件数目是1024,因此此次并发数控制在900。
    尽管这一个结果在实际的网站中因为各方面因素导致,可能差别没这么大,例如受限于数据库的性能等等的问题。但对我们在部署网站应用时还是具有参考价值的

  • 相关阅读:
    Cocos Creator 使用protobufjs
    Java操作MongoDB:连接&增&删&改&查
    MongoDB 权限控制
    SpringBoot 文件上传、下载、设置大小
    Java HashMap 遍历、删除、排序
    Java分割字符串
    在Windows下解决git ERROR: Permission to XXX.git denied to user
    阿里云域名+github建立网站
    Creazy Ideas 智能汽车和智能交通
    Windows上安装运行Hadoop
  • 原文地址:https://www.cnblogs.com/zr-hh199610/p/8708549.html
Copyright © 2011-2022 走看看