一、Tomcat8优化

  Tomcat服务器在JavaEE项目中使用率非常高,所以在生产环境对Tomcat的优化也变得非常重要了。
  对于Tomcat的优化,主要是从2个方面入手,一是,Tomcat自身的配置,另一个是Tomcat所运行的jvm虚拟机的调优。

二、Tomcat配置优化

1、环境

  虚拟机IP:192.168.33.136

2、部署安装Tomcat8

  下载:https://tomcat.apache.org/download-80.cgi

  

3、上传tomcat压缩包到/usr/local

  

4、切换到/usr/local目录进行解压

cd /usr/local/

  

tar -zxvf apache-tomcat-8.5..tar.gz 

  

5、 配置Tomcat用户账号和密码

  5.1 cd 到apache-tomcat-8.5.34/conf/的文件夹下 找到tomcat-users.xml文件

cd apache-tomcat-8.5./conf/

  

  5.2 修改tomcat-users.xml文件

<role rolename="manager"/> 
<role rolename="manager-gui"/>
<role rolename="admin"/>
<role rolename="admin-gui"/>
<user username="tomcat" password="tomcat" roles="admin-gui,admin,manager-gui,manager"/>

  

  

6、修改context.xml文件  将<Valve>的内容注释掉

  tomcat7:配置了tomcat用户就可以登录系统

    tomcat8:还需要修改context.xml配置文件,否则访问不了,提示403

cd ../webapps/manager/META-INF/ 

  

vi context.xml

  

7、启动Tomcat

前提关闭防火墙

  关闭防火墙:systemctl stop firewalld.service 
  禁用防火墙:systemctl disable firewalld.service

切换目录:cd /usr/local/apache-tomcat-8.5.34/bin/

启动命令:./startup.sh
        或
       ./startup.sh && tail -f ../logs/catalina.out

  

报错情况:

  

 启动报错原因:

  因为启动tomcat会调用tomcat安装文件中的startup.bat,而它调用了catalina.bat则调用了setclasspath.bat。因此需要在setclasspath.bat的开头手动声明环境变量

 解决方案:

  修改bin目录下的setclasspath.sh,添加JAVA_HOME和JRE_HOME两个环境变量,两个环境变量路径为您安装的java JDK的路径

  

export JAVA_HOME=/usr/java/jdk1..0_144
export JRE_HOME=/usr/java/jre1..0_144

  

重启Tomcat:

  

8、浏览器进行测试访问  http://192.168.33.136:8080/

  

9、Server Status进行登陆

  

登陆成功显示服务信息:

  

三、禁用AJP连接

  在服务状态页面中可以看到,默认状态下会启用AJP服务,并且占用8009端口
  

1、什么是AJP

  AJP(Apache JServer Protocol)
  AJPv13协议是面向包的。WEB服务器和Servlet容器通过TCP连接来交互;为了节省SOCKET创建的昂贵代价,WEB服务器会尝试维护一个永久TCP连接到servlet容器,并且在多个请求和响应周期过程会重用连接。

  

  我们一般是使用Nginx+tomcat的架构,所以用不着AJP协议,所以把AJP连接器禁用。

2、修改conf下的server.xml文件  将AJP服务禁用掉

vi server.xml

  

  

3、重启tomcat

./shutdown.sh
./startup.sh

  

4、访问查看  看到AJP服务已经不存在了

  

四、执行器(线程池)

  在tomcat中每一个用户请求都是一个线程,所以可以使用线程池提高性能。

1、修改server.xml文件

<Executor name="tomcatThreadPool" 
    namePrefix="catalina-exec-"
    maxThreads=""
    minSpareThreads=""
  prestartminSpareThreads="true"
  maxQueueSize=""/>

  

参数说明:
  maxThreads:最大并发数,默认设置 200,一般建议在 500 ~ 1000,根据硬件设施和业务来判断
  minSpareThreads:Tomcat 初始化时创建的线程数,默认设置 25
  prestartminSpareThreads: 在 Tomcat 初始化的时候就初始化 minSpareThreads 的参数值,如果不等于 true,minSpareThreads 的值就没啥效果了
  maxQueueSize:最大的等待队列数,超过则拒绝请求

2、在Connector中设置executor属性指向上面的执行器

    <Connector executor="tomcatThreadPool" port="" protocol="HTTP/1.1"
connectionTimeout=""
redirectPort="" />

  

3、重启tomcat

./shutdown.sh
./startup.sh

  

4、访问查看

  在页面中显示最大线程数为-1,这个是正常的,仅仅是显示的问题,实际使用的指定的值。

  

五、3种运行模式

1、tomcat的运行模式有3种

1.1 bio

  默认的模式,性能非常低下,没有经过任何优化处理和支持.

1.2 nio

  nio(new I/O),是Java SE 1.4及后续版本提供的一种新的I/O操作方式(即java.nio包及其子包)。Java nio是一个基于缓冲区、并能提供非阻塞I/O操作的Java API,因此nio也被看成是non-blocking I/O的缩写。它拥有比传统I/O操作(bio)更好的并发运行性能。

1.3 apr

  安装起来最困难,但是从操作系统级别来解决异步的IO问题,大幅度的提高性能.
  推荐使用nio,不过,在tomcat8中有最新的nio2,速度更快,建议使用nio2. 

2、设置nio2

2.1 修改server.xml文件

    <Connector executor="tomcatThreadPool" port=""         protocol="org.apache.coyote.http11.Http11Nio2Protocol"
connectionTimeout=""
redirectPort="" />

  

2.2 重启tomcat

./shutdown.sh
./startup.sh

  

2.3 访问查看  可以看到已经设置为nio2了

  

Tomcat8优化的更多相关文章

  1. Tomcat8优化--Apache JMeter测试

    一.部署测试java web项目(压力测试环境搭建) 1.mysql环境 #切换到mysql目录 cd /usr/local/mysql #查看mysql环境 rpm -qa | grep -i my ...

  2. Tomcat8史上最全优化实践

    Tomcat8史上最全优化实践 1.Tomcat8优化 1.1.Tomcat配置优化 1.1.1.部署安装tomcat8 1.1.2 禁用AJP连接 1.1.3.执行器(线程池) 1.1.4 3种运行 ...

  3. JVM优化(下)

    14.Tomcat8优化之G1牢记收集器的测试结果以及小结: jmeter测试:(1)tomcat未做任何优化:(2)禁用AJP:(3)启用连接池:(4)设置最大线程数1000,初始线程数200:(5 ...

  4. 想理解JVM看了这篇文章,就知道了!

    前言 ​ 本章节属于Java进阶系列,前面关于设计模式讲解完了,有兴趣的童鞋可以翻看之前的博文,后面会讲解JVM的优化,整个系列会完整的讲解整个java体系与生态相关的中间件知识.本次将对jvm有更深 ...

  5. 大型Java进阶专题(十一) 深入理解JVM (下)

    前言 ​ 前面我们了解了JVM相关的理论知识,这章节主要从实战方面,去解读JVM. 类加载机制 ​ Java源代码经过编译器编译成字节码之后,最终都需要加载到虚拟机之后才能运行.虚拟机把描述类的数据从 ...

  6. 类加载机制+JVM调优实战+代码优化

    类加载机制 Java源代码经过编译器编译成字节码之后,最终都需要加载到虚拟机之后才能运行.虚拟机把描述类的数据从 Class 文件加载到内存,并对数据进行校验.转换解析和初始化,最终形成可以被虚拟机直 ...

  7. JVM调优2-远程监控

    监控远程JVM VisualJVM不仅是可以监控本地jvm进程,还可以监控远程的jvm进程,需要借助于JMX技术实现. 什么是JMX JMX(Java Management Extensions,即J ...

  8. Tomcat8安装, 安全配置与性能优化(转)

    一.Tomcat 安装 官网:http://tomcat.apache.org/ Tomcat8官网下载地址:http://tomcat.apache.org/download-80.cgi 为了便于 ...

  9. Tomcat8安装, 安全配置与性能优化

    一.Tomcat 安装 官网:http://tomcat.apache.org/ Tomcat8官网下载地址:http://tomcat.apache.org/download-80.cgi 为了便于 ...

随机推荐

  1. intel windows caffe加速

    网址: https://github.com/BeFreeRoad/intel_caffe_windows 将intel caffe从linux平台移植到windows平台. 性能: 在虚拟机上测试可 ...

  2. VisualStudioAddIn2017.vsix的下载安装和使用

    本加载项是用于Visual Studio的,下载以后按照如下步骤进行安装: 完全退出Visual Studio 把下载了的文件解压缩,会产生一个VisualStudioAddIn2017.vsix文件 ...

  3. leetcode第36题:有效的数独

    解题思路:按行,列,3*3方格读取元素,存入字典中.若字典中该元素的值大于1,则返回false,否则返回true. class Solution: def isValidSudoku(self, bo ...

  4. 【Java集合】试读LinkedList源码

    LinkedList的本质是双向链表.(01) LinkedList继承于AbstractSequentialList,并且实现了Dequeue接口. (02) LinkedList包含两个重要的成员 ...

  5. Mysql————基本sql语句

    mysql中的基本语法有四种: 1.DDL语句:(用CREAT和DROP操作的语句) 用于创建.修改.和删除数据库内的数据结构,如:1:创建和删除数据库(CREATE DATABASE || DROP ...

  6. elasticsearch用法

    基本原理 搜索引擎的索引 倒排序 由value查找key 数据库的索引 由key查找value 用于解决分库分表后的排序分页 like查找 性能问题 日志库的全文搜索 spring集成时使用的不是re ...

  7. java中字符串相等判断

    字符串的判断有2种: 1.判断地址是否相等  用:== 2.判断值是否相等  用:equals方法 Object类作为所有类的超类,而Object类的equals方法是直接比较地址的,源码如下: pu ...

  8. Qt LNK1158无法运行rc.exe解决办法

    找出电脑上的rc.exe ,发现在C:\Program Files (x86)\Windows Kits\10\bin\10.0.xxxx.0\x86 路径下. 找出电脑上的rc.exe ,发现在C: ...

  9. VS2010发布,IIS实际目录,无法修改只读状态解难决办法

    VS2010发布网站后,无法修改只读状态 CMS简单的主页生成失败,其他的修改操错也应该无法执行 只在常规里修改无效. 网上得答案 1.鼠标右键点击文件夹 2.点击属性 3.在“常规”标签页中,取消“ ...

  10. spring boot 创建定时任务

    @Scheduled默认创建的线程是单线程,任务的执行会受到上一个任务的影响,创建定时任务也比较简单 123456789101112 @Component@Configuration //1.主要用于 ...