gpt4 book ai didi

java - Tomcat JMX 连接 - 身份验证失败

转载 作者:搜寻专家 更新时间:2023-11-01 03:13:38 25 4
gpt4 key购买 nike

我在为 JMX 设置 Tomcat 时遇到了一些问题。我添加了以下属性

  CATALINA_OPTS="-Dcom.sun.management.jmxremote.port=18070      -Dcom.sun.management.jmxremote.password.file=$CATALINA_BASE/conf/jmxremote.password      -Dcom.sun
.management.jmxremote.ssl=false"

并已将 jmxremote.password 文件添加到 conf 目录中。我编写了一个连接到在端口 18070 上运行的 JMX 服务器的客户端工具。当我运行客户端程序时,出现以下错误。

    Exception in thread "main" java.lang.SecurityException: Authentication failed! Credentials required
at com.sun.jmx.remote.security.JMXPluggableAuthenticator.authenticationFailure(JMXPluggableAuthenticator.java:193)
at com.sun.jmx.remote.security.JMXPluggableAuthenticator.authenticate(JMXPluggableAuthenticator.java:145)
at sun.management.jmxremote.ConnectorBootstrap$AccessFileCheckerAuthenticator.authenticate(ConnectorBootstrap.java:185)
at javax.management.remote.rmi.RMIServerImpl.doNewClient(RMIServerImpl.java:213)
at javax.management.remote.rmi.RMIServerImpl.newClient(RMIServerImpl.java:180)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)
at sun.rmi.server.UnicastServerRef.dispatch(UnicastServerRef.java:305)
at sun.rmi.transport.Transport$1.run(Transport.java:159)
at java.security.AccessController.doPrivileged(Native Method)
at sun.rmi.transport.Transport.serviceCall(Transport.java:155)
at sun.rmi.transport.tcp.TCPTransport.handleMessages(TCPTransport.java:535)
at sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run0(TCPTransport.java:790)
at sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run(TCPTransport.java:649)
at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:885)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:907)
at java.lang.Thread.run(Thread.java:619)
at sun.rmi.transport.StreamRemoteCall.exceptionReceivedFromServer(StreamRemoteCall.java:255)
at sun.rmi.transport.StreamRemoteCall.executeCall(StreamRemoteCall.java:233)
at sun.rmi.server.UnicastRef.invoke(UnicastRef.java:142)
at javax.management.remote.rmi.RMIServerImpl_Stub.newClient(Unknown Source)
at javax.management.remote.rmi.RMIConnector.getConnection(RMIConnector.java:2312)
at javax.management.remote.rmi.RMIConnector.connect(RMIConnector.java:277)
at javax.management.remote.JMXConnectorFactory.connect(JMXConnectorFactory.java:248)
at com.bt.c21sc.c21tkprobe.accessors.C21TkProbeJmxDAO.connect(Unknown Source)
at com.bt.c21sc.c21tkprobe.service.C21TkProbeBD.execute(Unknown Source)
at com.bt.c21sc.c21tkprobe.C21AppserverProbe.main(Unknown Source)

如果我将 CATALINA_OPTS 属性更改为

CATALINA_OPTS="-Dcom.sun.management.jmxremote.port=18070 -Dcom.sun.management.jmxremote.password.file=$CATALINA_BASE/conf/jmxremote.password -Dcom.sun
.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false"

然后它工作正常。我认为我感到困惑的是什么被归类为远程访问。我正在远离 Tomcat 实例运行客户端程序,但 Tomcat 和客户端工具都在同一台机器上(即不同的虚拟机但相同的环境)。如果我从另一台机器远程访问 JMX 服务器,我想我必须配置远程身份验证。

远程访问是指从本地或远程的任何 VM 访问 JMX 服务器吗?

编辑

谢谢。我发现问题在于,即使我在 jmxremort.password 和 jmxremote.access 文件中提供了用户名和密码,我仍然必须从客户端提供用户名和密码。

你是对的,如果在本地运行,我不必提供用户凭据。我已经证明了这一点,因为我可以通过 Jconsole 访问 Tomcat 的 JVM。

我正在以编程方式访问它,所以我必须提供如下所示的 URL 服务:jmx:rmi:///jndi/rmi://localhost:9004/jmxrmi

然后我得到 jmx 服务器,如下所示。

url = new JMXServiceURL(urlString);         
Hashtable<String, String[]> env = new Hashtable<String, String[]>();
String[] credentials = new String[] {user,pass};
env.put(JMXConnector.CREDENTIALS, credentials);
jmxc = JMXConnectorFactory.connect(url,env);
mbsc = jmxc.getMBeanServerConnection();

如果我在本地访问这个,我会怎么做?我知道如果没有用户凭据,它就无法在本地工作,因为这就是我发现我需要提供的方式。如果 Jconsole 或 visualvm 可以连接到它,那么必须有一种不同的方法允许检索 Tomcat jmx 服务器而无需提供端口号。

URL 包含一个端口号。如果我以编程方式访问 JMX 服务器,我将如何在不指定端口号的情况下访问它?

顺便说一句,我正在使用 Tomcat 5.5 和 JDK 1.6

谢谢

最佳答案

远程访问

远程访问意味着从另一台机器访问,通过另一台 VM 在本地访问 don't have to setup JMX [注1]。您可以通过启动一个没有 JMX 的 Java 应用程序来尝试,然后在同一台机器上启动 VisualVM。启动的应用程序应出现在“本地”下(在 VisualVM 中)。

如异常状态:身份验证失败!需要凭据你提供了用户名和密码吗? ;) 我想你做到了......

可能的解决方案

如果你这样做了,那么你应该尝试从 CATALINA_OPTS 中删除 $CATALINA_BASE 并输入一个硬编码值,看看这是否是根本问题。

例子:

CATALINA_OPTS="-Dcom.sun.management.jmxremote.port=18070 -Dcom.sun.management.jmxremote.password.file=/opt/tomcat6/conf/jmxremote.password -Dcom.sun.management.jmxremote.ssl=false"

如果可行,请尝试这样:

CATALINA_OPTS="-Dcom.sun.management.jmxremote.port=18070
-Dcom.sun.management.jmxremote.password.file=`echo $CATALINA_BASE`/conf/jmxremote.password
-Dcom.sun.management.jmxremote.ssl=false"

[注 1]:这里说:“在以前的 Java SE 平台版本中,要允许 JMX 客户端访问本地 Java VM,您必须设置以下系统属性 (com.sun.management .jmxremote) 当你启动 Java VM 或 Java 应用程序时。设置此属性注册 Java VM 平台的 MBean 并通过私有(private)接口(interface)发布远程方法调用 (RMI) 连接器,以允许 JMX 客户端应用程序监视本地 Java 平台,即,与JMX客户端运行在同一台机器上的Java VM。在Java SE 6平台中,不再需要设置这个系统属性。在Java SE 6平台上启动的任何应用程序都将支持Attach API,并且因此将在需要时自动提供给本地监控和管理。”

关于java - Tomcat JMX 连接 - 身份验证失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4679877/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com