jvm优化_day03

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

2.配置tomcat的管理状态,用来查看tomcat的配置,
2.1打开apache-tomcat-8.5.34/conf/tomcat-users.xml
<!--
	在第44行写入如下内容:
-->
<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"/>
2.2如果是tomcat7,配置了tomcat用户就可以登录系统了,但是tomcat8中不行,还需要修改另一个配置文件,否则访问不了,提示403;
打开webapps/manager/META-INF/context.xml
<!--注释value标签-->
<Context antiResourceLocking="false" privileged="true" >
  	<!--Valve className="org.apache.catalina.valves.RemoteAddrValve"
         allow="127\.\d+\.\d+\.\d+|::1|0:0:0:0:0:0:0:1" />-->
  <Manager sessionAttributeValueClassNameFilter="java\.lang\.(?:Boolean|Integer|Long|Number|String)|org\.apache\.catalina\.filters\.CsrfPreventionFilter\$LruCache(?:\$1)?|java\.util\.(?:Linked)?HashMap"/>
</Context>
2.3打开浏览器,访问localhost:8080,点击Server Status即可查看tomcat的配置信息

3.tomcat优化方案:
* 方案一: 禁用AJP协议服务
	AJP服务是tomcat提供的一个面向长连接的服务,即建立一次连接后,通过类似于管道进行吞吐,但是AJP服务必须使用apache的服务器,而我们通常使用的服务器是:nginx + tomcat,因此AJP服务对我们来说是鸡肋,因此禁用
使用方式:
	修改conf/server.xml,注释掉116行的AJP服务
<!--
	<Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />
-->
* 方案二: 配置执行器(线程池)
	配置执行器后,Server Status页面中的Max Thrad始终为-1,这仅仅是显示的问题,实际上是生效的
使用方式:
	修改conf/server.xml,配置Executor线程池(打开57,58行的注释),并引用在Connector标签上引用
	<!--将注释打开并添加一些额外参数,参数说明:
        maxThreads:最大并发数,默认设置 200,一般建议在 500 ~ 1000,根据硬件设施和业务来判断
        minSpareThreads:Tomcat 初始化时创建的线程数,默认设置 25
        prestartminSpareThreads: 在 Tomcat 初始化的时候就初始化 minSpareThreads 的参数值,如果不等于 true,minSpareThreads 的值就会失效
        maxQueueSize,最大的等待队列数,超过则拒绝请求-->
<Executor name="tomcatThreadPool" namePrefix="catalina-exec-"
        maxThreads="500" minSpareThreads="50" prestartminSpareThreads="true" maxQueueSize="100"/>	

	<!--在第70行的Connector标签内引用执行器-->
<Connector executor="tomcatThreadPool"  port="8080" protocol="HTTP/1.1"
               connectionTimeout="20000"
               redirectPort="8443" />
* 方案三: 设置tomcat运行模式
tomcat的运行模式有3种:推荐使用nio,不过,在tomcat8中有最新的nio2,速度更快,建议使用nio2
1. bio
   默认的模式,性能非常低下,没有经过任何优化处理和支持.
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)更好的并发运行性能。
3. apr
   安装起来最困难,但是从操作系统级别来解决异步的IO问题,大幅度的提高性能.
	<!--修改conf/server.xml第70行中的protocol属性值-->
<Connector executor="tomcatThreadPool"  port="8080" protocol="org.apache.coyote.http11.Http11Nio2Protocol"
               connectionTimeout="20000"
               redirectPort="8443" />
* 方案四: 调整JVM运行参数
<!--
	在bin/startup.sh(或者startup.bat)文件中添加tomcat下的jvm启动参数,在第20行添加
-->
	方式一:设置并行垃圾回收器,调整年轻代大小并使用GCEasy比较结果,最终找出合适值
#年轻代、老年代均使用并行收集器,初始堆内存64M,最大堆内存512M
JAVA_OPTS="-XX:+UseParallelGC -XX:+UseParallelOldGC -Xms64m -Xmx512m -XX:+PrintGCDetails -XX:+PrintGCTimeStamps -XX:+PrintGCDateStamps -XX:+PrintHeapAtGC -Xloggc:h:/logs/gc.log"
	方式二:设置G1垃圾回收器
#设置了最大停顿时间100毫秒,初始堆内存128m,最大堆内存1024m
JAVA_OPTS="-XX:+UseG1GC -XX:MaxGCPauseMillis=100 -Xms128m -Xmx1024m -XX:+PrintGCDetails -XX:+PrintGCTimeStamps -XX:+PrintGCDateStamps -XX:+PrintHeapAtGC -Xloggc:h:/logs/gc.log"

4.使用JMeter进行压力测试
下载地址:http://jmeter.apache.org/download_jmeter.cgi
打开bin/jmeter.bat,主要查看聚合报告
代码优化
1.通过javap命令查看.class字节码文件的内容
    javap -help   # 查看所有的javap命令的参数
    javap用法: javap <options> <classes>
    eg: javap -v Test1.class > H:/Test1.txt
2.内容大致分为4个部分:
第一部分:显示了生成这个class的java源文件、版本信息、生成时间等。
第二部分:显示了该类中所涉及到常量池,共35个常量。
第三部分:显示该类的构造器,编译器自动插入的。
第四部分:显示了main方的信息
3.i++++i的区别:
	i++先从本地变量表读取i的值,并压栈到操作栈中,再对本地变量表中的i的值+1,然后把操作栈中的值存入到本地变量表,因此本地变量表保存的值为2,1
 	++i先对本地变量表的值+1,再从本地变量表读取i的值,压栈到操作栈中,再弹栈道本地变量表,因此本地变量表的值为2,2
4.字符串拼接优化:
	String a = "a";
	String b = "b";
	String c = a + b ;
jvm底层会对用"+"拼接的对象创建一个StringBuilder,然后调用sb.append()方法来做字符串拼接,但是没执行一次"+",就会new 一个StringBuilder,因此"+"号的效率不如手动new StringBuidler5.代码优化建议
5.1 尽可能使用局部变量
5.2 尽量减少对变量的重复计算
5.3 尽量采用懒加载的策略,即在需要的时候才创建
5.4 异常不应该用来控制程序流程
5.5 不要将数组声明为public static final
5.6 不要创建一些不使用的对象,不要导入一些不使用的类
5.7 程序运行过程中避免使用反射
5.8 使用数据库连接池和线程池
5.9 容器初始化时尽可能指定长度
5.10 ArrayList随机遍历快,LinkedList添加删除快
5.11 使用Entry遍历Map
5.12 不要手动调用System.gc();
5.13 String尽量少用正则表达式
5.14 日志的输出要注意级别
5.15 对资源的close()建议分开操作
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值