博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
jmx : ClientCommunicatorAdmin Checker-run
阅读量:5020 次
发布时间:2019-06-12

本文共 2120 字,大约阅读时间需要 7 分钟。

今天遇到一个问题:

执行bat,关闭jmx的时候,由于程序关闭之后又去连接了一次,cmd窗口报错,类似:

2013-7-11 15:58:05 ClientCommunicatorAdmin restart

警告: Failed to restart: java.io.IOException: Failed to get a RMI stub: javax.naming.ServiceUnavailableException [Root exception is java.rmi.ConnectException: Connection refused to host: 10.10.4.18; nested exception is:
 java.net.ConnectException: Connection refused: connect]
2013-7-11 15:58:06 RMIConnector RMIClientCommunicatorAdmin-doStop
警告: Failed to call the method close():java.rmi.ConnectException: Connection refused to host: 10.10.4.18; nested exception is:
 java.net.ConnectException: Connection refused: connect
2013-7-11 15:58:06 ClientCommunicatorAdmin Checker-run
警告: Failed to check connection: java.net.ConnectException: Connection refused: connect
2013-7-11 15:58:06 ClientCommunicatorAdmin Checker-run

 

这个是非常奇怪的现象,也不知道底层jdk是怎么实现的:

一个线程A从某处p开启了另外的线程B,B抛出的异常,A在p处可以B的异常捕获吗???

什么情况下可以,什么情况下不可以呢? 跟操作系统多核单核相关吗?

 

 

搜索了很多个网站 ,最后在 找到答案。(看来还是要花时间深入jdk源码进去才行啊, 不要有害怕心理,不要一不懂就问,有时候答案是自己稍微深究就出来的了!)

尽管如此,也是非常不顺利的,因为项目代码中有多处使用了JMXConnectorFactory.connect(serviceurl, m); 这样的操作,而且分散开来了。 我开始只改了一个地方,导致问题一直没解决。一下子也非常难得确定到底哪次调用引起的, 因为有好几个后台进程, 而且远程调试非常不方便所以没用,每次都是打印日志来调试,很耗时间。。。

主管检查后发现说, 这样:m.put("jmx.remote.x.client.connection.check.period", 0L);  不好,不能这么搞! 这个是心跳请求,每一分钟检查jmx是否还有连接,设置为0L之后呢就没有了检查, 可能导致前台状态显示不正确,风险,,,,。。 会吗, 我认为不是这样的,不是每次都会重新连接jmx查询的吗,, 可是。。。 我晕, ,

另外一种方法是设置logging.properties文件(因为jmx用的是jdk的logging),把level改成severe,这样就可以屏蔽所有的warn,类似

logger.warning("RMIClientCommunicatorAdmin-doStop",

                        "Failed to call the method close():" + ioe);

, 不过他又说不能更改第三方的文件。。。 (大公司做事如此的麻烦谨慎。。。)

重新修改原先代码逻辑?麻烦。。。

重定向 system。out 。。?

 

 

 

奇怪的是win7就不报错,但是2008就会有这个,怎么搞就搞不定, 也不知道底层什么原因。—— 莫非就是cpu单核多核引起的多线程问题?

。。。

后来有怀疑是jdk升级引起的, 从jdk1.7.0.1_17到了jdk1.7.0.1_45(最新版好像是47), oracle确实有对rmi/jmx相关参数做修改,把 -Djava.rmi.server.useCodebaseOnly从默认true设置了false

以为这个会有影响。

 

后来还是证明我的想法是错的,跟jre版本无关,而是 win7下的版本和2008上的版本并不相同引起的。

新版本中执行shutdown的时候

1 先关闭jvm1(异步)、

2 然后关闭jvm2(异步),

3 关闭jvm2的时候先尝试获取jvm上的jmx连接资源connector,

4 jvm1真正关闭,connector抛出异常!

就是这个原因!

posted on
2014-02-11 01:09 阅读(
...) 评论(
...)

转载于:https://www.cnblogs.com/FlyAway2013/p/3543755.html

你可能感兴趣的文章
20189210 移动开发平台第六周作业
查看>>
java之hibernate之基于外键的双向一对一关联映射
查看>>
java之aop
查看>>
java之spring mvc之页面跳转
查看>>
java之spring mvc之Restful风格开发及相关的配置
查看>>
json编码解码方法
查看>>
.Net使用SignalR实现实时推送功能
查看>>
如何更改已经pushed的commit的注释信息(How to change the pushed commit message)
查看>>
Git 版本回退的几种操作方法
查看>>
Linux新建用户,切换后只显示$问题
查看>>
Linux 批量添加用户
查看>>
Excel 不同文件、sheet 关联引用(vlookup函数)
查看>>
ELK 错误: retrying failed action with response code: 403, kibana无log显示
查看>>
rxjs一句话描述一个操作符(1)
查看>>
第一次独立上手多线程高并发的项目的心路历程
查看>>
ServiceStack 介绍
查看>>
Centos7下载和安装教程
查看>>
无谓的通宵加班之后的思索
查看>>
S1的小成果:MyKTV系统
查看>>
从setting文件导包
查看>>