优化参数

  1. -XX:CICompilerCount=6
  2. -server
  3. -XX:+UnlockDiagnosticVMOptions
  4. -XX:+LogVMOutput
  5. -Djava.net.preferIPv4Stack=true
  6. -Djava.awt.headless=true
  7. -Dibm.stream.nio=true
  8. -Djava.net.preferIPv4Stack=true

命令实例:

  1. nohup java -Xms500m -Xmx500m -Xmn250m -Xss256k -server -XX:+HeapDumpOnOutOfMemoryError -jar $JAR_PATH/test-0.0.1-SNAPSHOT.jar --spring.profiles.active=daily -verbose:class &

说明:

--spring.profiles.active=daily, 这个可以在spring-boot启动中指定系统变量,多环境(测试、预发、线上配置)的区分
在排查jar包冲突时,可以指定启动的-verbose:class 打印出启动的应用实际加载类的路径,来排查来源。
jvm堆设值:-Xms500m -Xmx500m -Xmn250m -Xss256k
nohup 不挂断地运行命令;& 在后台运行 ,一般两个一起用。 eg:nohup command &
-server:服务器模式,在多个CPU时性能佳,启动慢但性能好,能合理管理内存。
-XX:+HeapDumpOnOutOfMemoryError:在堆溢出时保存快照
可以用 java -X命令在终端查询所有的java堆参数:

  1. -Xmixed 混合模式执行 (默认)
  2. -Xint 仅解释模式执行
  3. -Xbootclasspath:<用 : 分隔的目录和 zip/jar 文件>
  4. 设置搜索路径以引导类和资源
  5. -Xbootclasspath/a:<用 : 分隔的目录和 zip/jar 文件>
  6. 附加在引导类路径末尾
  7. -Xbootclasspath/p:<用 : 分隔的目录和 zip/jar 文件>
  8. 置于引导类路径之前
  9. -Xdiag 显示附加诊断消息
  10. -Xnoclassgc 禁用类垃圾收集
  11. -Xincgc 启用增量垃圾收集
  12. -Xloggc:<file> GC 状态记录在文件中 (带时间戳)
  13. -Xbatch 禁用后台编译
  14. -Xms<size> 设置初始 Java 堆大小
  15. -Xmx<size> 设置最大 Java 堆大小
  16. -Xss<size> 设置 Java 线程堆栈大小
  17. -Xprof 输出 cpu 配置文件数据
  18. -Xfuture 启用最严格的检查, 预期将来的默认值
  19. -Xrs 减少 Java/VM 对操作系统信号的使用 (请参阅文档)
  20. -Xcheck:jni JNI 函数执行其他检查
  21. -Xshare:off 不尝试使用共享类数据
  22. -Xshare:auto 在可能的情况下使用共享类数据 (默认)
  23. -Xshare:on 要求使用共享类数据, 否则将失败。
  24. -XshowSettings 显示所有设置并继续
  25. -XshowSettings:all
  26. 显示所有设置并继续
  27. -XshowSettings:vm 显示所有与 vm 相关的设置并继续
  28. -XshowSettings:properties
  29. 显示所有属性设置并继续
  30. -XshowSettings:locale
  31. 显示所有与区域设置相关的设置并继续
  32. -X 选项是非标准选项, 如有更改, 恕不另行通知。

以下选项为 Mac OS X 特定的选项:

  1. -XstartOnFirstThread
  2. 在第一个 (AppKit) 线程上运行 main() 方法
  3. -Xdock:name=<应用程序名称>"
  4. 覆盖停靠栏中显示的默认应用程序名称
  5. -Xdock:icon=<图标文件的路径>
  6. 覆盖停靠栏中显示的默认图标

-server和-client具体说明:

  1. -server:一定要作为第一个参数,在多个 CPU 时性能佳,还有一种叫 -client 的模式,特点是启动速度比较快,但运行时性能和内存管理效率不高,通常用于客户端应用程序或开发调试,在 32 位环境下直接运行 Java 程序默认启用该模式。Server 模式的特点是启动速度比较慢,但运行时性能和内存管理效率很高,适用于生产环境,在具有 64 位能力的 JDK 环境下默认启用该模式,可以不配置该参数。

-XX:+HeapDumpOnOutOfMemoryError:

  1. 该配置会把快照保存在user.dir中,比如你用tomcat启动,那应该是在tomcatbin目录下<br />当然,也可以通过XX:HeapDumpPath=./java_pid.hprof来显示指定路径<br />此外,OnOutOfMemoryError参数允许用户指定当出现oom时,指定某个脚本来完成一些动作,比如邮件知会
  1. $ java -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/tmp/heapdump.hprof -XX:OnOutOfMemoryError ="sh ~/cleanup.sh" MyApp