java – 在Apache Tomcat应用程序中,MBean字段是否需要易失/同步才能使JMX更新出现在其他线程中?

我一直在我们的Spring Web应用程序中公开bean,以防我们需要动态地进行配置更改.最近我一直在审查并发性,我开始想知道当你通过JMX改变其中一个bean时,其他线程会发生什么?

JMX是否有某种方法可以强制刷新内存模型,因此您不必担心使字段易失/同步以确保其他线程看到更改?

当Tomcat创建一个新线程来处理请求时,即使该字段不是线程安全的,该线程也会看到更改,对吗?因此,除非我需要更改以立即在当前请求线程中生效,否则有任何理由担心并发问题?

解决方法:

JMX处理程序不是特殊线程.需要在其他线程中看到的任何更改都需要标记为volatile或synchronized.

// this needs to be volatile because another thread is accessing it
private volatile boolean shutdown;
...

@JmxOperation(description = "Shutdown the server")
public void shutdownSystem() {
   // this is set by the JMX connection thread
   shutdown = true;
}

也就是说,通常JMX值是统计数据或配置设置,我不介意在下一个内存屏障被越过时懒惰地更新.这适用于计数器和其他调试信息以及布尔值和仅由JMX设置的其他值,尽管它们由其他线程使用.在这些情况下,我没有将字段标记为易变,并且还没有咬过我们.因人而异.

仅供参考,@ JmxOperation注释来自my SimpleJmx library.

上一篇:java.lang.SecurityException:期望存根中的sun.rmi.server.UnicastRef2远程引用


下一篇:Linux下执行jmeter脚本