picked up java_tool_options:_理解环境变量 JAVA_TOOL_OPTIONS

JAVA_TOOL_OPTIONS是何物

有些应用不方便设置JVM参数,如命令行应用、通过JNI(Java Native Interface)API调用虚拟机的应用、脚本嵌入虚拟机中的应用等。这种情况环境变量JAVA_TOOL_OPTIONS就非常有用了,它会被JNI API的JNI_CreateJavaVM函数使用。

df4c0b00aa0869f791e2a531ab87850b.png

Note:

在有些场景为了安全考虑环境变量JAVA_TOOL_OPTIONS是被禁用的,比如Solaris系统中但有效用户ID或组ID不是实际ID时则禁用此环境变量。

因为JAVA_TOOL_OPTIONS是被被JNI_CreateJavaVM调用的,顾名思义是创建VM,因此有些参数是不能被设置的如选择虚拟机运行模式-client或-server。

各种OPTIONS的区别

也许你经常遇到JAVA_OPTS、_JAVA_OPTIONS和JAVA_TOOL_OPTIONS,那么他们有什么不同呢?

JAVA_OPTS:常用于一些应用的配置,如Tomcat,但它一般不作为环境变量,也不能被JVM识别的,是那些应用的自定义配置;

_JAVA_OPTIONS:也是作为环境变量来替代命令行参数的,但它是JVM厂家自定义的,可以覆盖JAVA_TOOL_OPTIONS,但各厂家的不同,_JAVA_OPTIONS是Oracle的JVM,而IBM的则是用IBM_JAVA_OPTIONS。

JAVA_TOOL_OPTIONS:是标准的,所有虚拟机都能识别和应用的。

如果想验证上面的不同也不难,如果设置了JVM能识别的环境变量,JVM会有"Picked up"的提示的,如:

export JAVA_OPTS=zhaiqiafneng

export JAVA_TOOL_OPTIONS="-Xmx512m -Xms64m"

java -version

JVM会打印:

Picked up JAVA_TOOL_OPTIONS: -Xmx512m -Xms64m

java version "1.8.0_101"

Java(TM) SE Runtime Environment (build 1.8.0_101-b13)

Java HotSpot(TM) 64-Bit Server VM (build 25.101-b13, mixed mode)

可见JAVA_TOOL_OPTIONS能被JVM识别,而JAVA_OPTS不能被识别。

可以通过设置-Xmx的值触发“Too small initial heap”异常连检测覆盖(当然你也可以通过其他方式):

export JAVA_TOOL_OPTIONS="-Xmx512m -Xms64m"

export _JAVA_OPTIONS="-Xmx1k -Xms1k"

java -version

JVM会打印

Picked up JAVA_TOOL_OPTIONS: -Xmx512m -Xms64m

Picked up _JAVA_OPTIONS: -Xmx1k -Xms1k

Error occurred during initialization of VM

Too small initial heap

可见_JAVA_OPTIONS覆盖了JAVA_TOOL_OPTIONS.

解决的经典问题

JAVA_TOOL_OPTIONS用于解决的经典问题是使用命令行导致中文乱码,如:

........

/HController.java:181: error: unmappable character for encoding GBK

// ��?后的发�??

^

/HController.java:181: error: unmappable character for encoding GBK

// ��?后的发�??

^

.......

通过设置环境变量JAVA_TOOL_OPTIONS="-Dfile.encoding=UTF-8"一般可以解决,如果不能解决,就要根据你具体的编码来设置下就好。

更多原创文章可关注我的个人博客:宅前疯 或微信公众账号:zhaiqianfeng

Arthas(阿尔萨斯)是阿里巴巴开源的Java诊断工具,深受开发者喜爱。 当你遇到以下类似问题而束手无策时,Arthas 可以帮助你解决: 这个类从哪个 jar 包加载的?为什么会报各种类相关的 Exception? 我改的代码为什么没有执行到?难道是我没 commit?分支搞错了? 遇到问题无法在线上 debug,难道只能通过加日志再重新发布吗? 线上遇到某个用户的数据处理有问题,但线上同样无法 debug,线下无法重现! 是否有一个全局视角来查看系统的运行状况? 有什么办法可以监控到JVM的实时运行状态? 怎么快速定位应用的热点,生成火焰图? Arthas支持JDK 6+,支持Linux/Mac/Windows,采用命令行交互模式,同时提供丰富的Tab自动补全功能,进一步方便进行问题的定位和诊断。   Arthas开源的Java诊断工具 更新日志: v3.5.1 Add vmtool command Remove the useless resetClassFileTransformer in Enhancer 对于非chunk response,返回标准的content-length字段 The jvm command may throw exception: java.lang.NullPointerException jad的一个小小的显示问题 bug remove env JAVA_TOOL_OPTIONS 去掉默认配置项 arthas.enhanceLoaders=java.lang.ClassLoader ,避免attach后导致系统负载飙升 Thread -n -1 不能正常工作 bug 当找不到java进程时,提示不清晰,应该提示用户执行jps命令 增加一个 ognl 的在线,可编辑的示例,帮助用户自己调试 ognl表达式 当Object输出时,可能会抛出异常,打印 ERROR DATA!!! exception message: null 把 arthas-demo 改名为 math-game ,避免新用户感到疑惑 arthas spring boot starter启动失败后,没有打印具体出错端口
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值