代码层面
- IO对象或者数据库的连接对象
- 使用好后,需要close或clear掉
try{使用Connection或IO等对象} catch(Exception){异常处理} finally{关闭对象}
- 当我们使用好对象时,应该把它设为null,这样可以尽快撤销这个对象上的强引用,从而提升这块对象的回收时间
- String对象属于不可变对象,避免频繁操作,尤其是循环或者多线程
- 应该使用StringBuffer或StringBuilder来替代String
- 当我们在使用好集合对象时,应该及时把它clear掉,撤销list的强引用
List<String> list = new ArrayList<String>(); list.celar();
- 如果我们合理的使用软引用和弱引用,从而减少对象上的强引用,那么可以提升对象的回收时间
运行参数
- Xms 设置程序启动时的初始堆大小,
- 比如 -Xms 500M。
- Xmx 设置程序能获得的最大堆的大小
- 比如 -Xmx 1G。假设有如下配置:java -Xms 500M -Xmx 1G SyncupData,则说明在该程序启动时,可以得到500M内存,随着程序扩展,它最多可以得到1G内存
- Xss 设置每个线程栈的大小
- 比如 -Xss 128k。JDK5以后,每个线程栈大小默认是1M,在相同物理内存下,减少这个值能创建更多的线程,这个值如果没必要,别轻易改动这个值。
- Xmn 设置堆内存年轻代的大小为2G
- 比如 -Xmn 2G。此值对系统性能影响较大,推荐配置为整个堆的3/8。如果没必要,别轻易改动整个值。
- XX:PermSize 设置堆内存持久代的初始值
- 比如通过 -XX:PermSize=256M把初始值设为256M。这个值如果没特殊需求,一般别改动。
- XX:MaxPermSize 设置堆内存持久代的最大值
- 比如通过 -XX:MaxPermSize=512M,可以设置最大值为512M,轻易别改动。
- XX:NewRation 设置年轻区与年老区的比值
- 一般设置为4, -XX:NewRation=4。
注意事项
- 一定要先穷尽代码级别的调优技巧,随后再考虑调整运行器参数
- 由于调整运行参数会导致一些不可测的问题,应该先在测试环境上做一个全面测试
- 在调整参数时应当留有余量,一步步提升 256M-512M-1g