JAVA性能调优

程序设计优化

减少MYSQL,REDIS访问
异步,批量
减少事务
REDIS大对象

tomcat优化

pstree -p [pid] | wc -l

参数:
server.tomcat.accept-count:等待队列长度,默认100
server.tomcat.max-connections:最大可被连接数,默认10000
server.tomcat.max-threads:最大工作线程数,默认200
server.tomcat.min-spare-threads:最小工作线程数,默认10

JVM优化

JAVA_OPTS="-server -Xmx4g -Xms4g -Xmn256m -Xss256k -XX:+DisableExplicitGC -XX:+UseConcMarkSweepGC -XX:+CMSParallelRemarkEnabled -XX:LargePageSizeInBytes=128m -XX:+UseFastAccessorMethods -XX:+UseCMSInitiatingOccupancyOnly -XX:CMSInitiatingOccupancyFraction=70 -Duser.timezone=GMT+8"

如果各项参数设置合理,系统没有超时日志出现,GC频率不高,GC耗时不高,那么没有必要进行GC优化;如果GC时间超过1〜3 秒,或者频繁G C ,则必须优化。如果满足下面的指标,则一般不需要进行调优:
■ Minor GC执行时间不到50ms;
■ Minor GC执行不频繁,约10秒一次;
■ Full GC执行时间不到1s;
■ Full GC执行频率不算频繁,不低于10分钟1次。

jstat -gccause pid 2000
老年代内存统计:jstat -gcoldcapacity pid
老年代垃圾回收统计;jstat -gcold pid
新生代内存统计:jstat -gcnewcapacity pid
新生代垃圾回收统计:jstat -gcnew pid

数据库优化

MYSQL:
连接数:show variables like ‘max_connections’;
线程数:show global status like ‘thread%’;
文件打开数:show global status like ‘open_files’;
表打开数:show global status like ‘open%tables%’;
临时表:show global status like ‘created_tmp%’;
表锁:show global status like ‘table_locks%’;
表扫描:show global status like ‘handler_read%’;
索引缓冲区:show variables like ‘key_buffer_size’;
排序使用情况:show global status like ‘sort%’;
查询缓存:show global status like ‘qcache%’;
慢查询; show variables like ‘%slow%’;

REDIS:
内存使用情况:info memory
命令执行分布和时间 info commandstats
慢命令 slowlog get
连接数 info clients
内存碎片率
最大内存
分片

操作系统优化

ulimit –n 查看用户单一进程最大文件打开数
cat /proc/sys/fs/file-max 所有用户
netstat -nat | grep -i “80” | wc –l 查看当前 80端口连接数
netstat -na | awk ‘/^tcp/ {++S[$NF]} END {for(a in S) print a, S[a]} ‘ 当前tcp链接状态

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值