由于SIGTERM,我的自定义安全管理器目前阻止优雅的关闭。将显示以下消息:
Java (TM)64位服务器VM警告:异常HotSpot java.lang.SecurityException发生向处理程序发送信号SIGTERM可能需要强制终止VM
我应该怎么做才能使关闭由于SIGTERMS,但没有更多?
发布于 2012-06-01 20:52:28
如果省略调用-Djava.security.debug=all,您的实现可能已经禁用了super.checkAccess中的全部调试信息。如果您首先在SecurityManager实现中编写
public void checkAccess(ThreadGroup g) {
System.out.println("Access for " + g);
super.checkAccess(g);
}
public void checkAccess(Thread t) {
System.out.println("Access for " + t);
super.checkAccess(t);
}与-Djava.security.debug=all一起运行时,您将获得有关要允许的checkAccess调用和向策略文件添加权限的信息。我总结如下:
Access for java.lang.ThreadGroup[name=system,maxpri=10]
Permission (java.lang.RuntimePermission modifyThreadGroup)
[...]
Access for Thread[SIGTERM handler,9,system]
Permission (java.lang.RuntimePermission modifyThread)
[...]
java.security.Permissions@133c5982 (
(java.lang.RuntimePermission exitVM)
(java.io.FilePermission /path/to/current/working/directory/- read)
)因此,您可以使用SIGTERM中的以下代码对SecurityManager信号进行更严格的处理
public void checkAccess(ThreadGroup g) {
System.out.println("Access for " + g);
if ("system".equals(g.getName())) {
// will checkPermission java.lang.RuntimePermission "modifyThreadGroup"
super.checkAccess(g);
} else {
throw new SecurityException("Access denied to " + g);
}
}
public void checkAccess(Thread t) {
System.out.println("Access for " + t);
if ("SIGTERM handler".equals(t.getName())) {
// will checkPermission java.lang.RuntimePermission "modifyThread"
super.checkAccess(t);
} else {
throw new SecurityException("Access denied to " + t);
}
}还可以在java.security.policy文件中授予以下权限:
grant {
permission java.lang.RuntimePermission "modifyThreadGroup";
permission java.lang.RuntimePermission "modifyThread";
permission java.lang.RuntimePermission "exitVM";
};完整的信息是可用的这里,但是做好这件事并不明显,尝试修复方法仍然是最快的方法。
https://stackoverflow.com/questions/9050805
复制相似问题