从shell脚本调用JMX MBean方法

Dou*_*kem 95 java sysadmin jmx

是否有任何库允许我从shell脚本调用JMX MBean方法.我们通过JMX公开了一些操作/管理命令,我们可以让我们的管理员使用JConsole或VisualVM,但有些任务最好留给自动化.在那个自动化中,我们希望能够在运行的服务器上调用JMX MBean方法,最好是从shell脚本调用.

Dou*_*kem 101

以下命令行JMX实用程序可用:

  1. jmxterm - 似乎是功能最全的实用程序.
  2. cmdline-jmxclient - 在WebArchive项目中使用似乎非常简单(自2006年以来没有开发它看起来像)
  3. Groovy脚本和JMX - 提供了一些非常强大的JMX功能,但需要groovy和其他库设置.
  4. JManage命令行功能 - (缺点是它需要一个正在运行的JManage服务器来代理命令)

Groovy JMX示例:

import java.lang.management.*
import javax.management.ObjectName
import javax.management.remote.JMXConnectorFactory as JmxFactory
import javax.management.remote.JMXServiceURL as JmxUrl

def serverUrl = 'service:jmx:rmi:///jndi/rmi://localhost:9003/jmxrmi'
String beanName = "com.webwars.gameplatform.data:type=udmdataloadsystem,id=0"
def server = JmxFactory.connect(new JmxUrl(serverUrl)).MBeanServerConnection
def dataSystem = new GroovyMBean(server, beanName)

println "Connected to:\n$dataSystem\n"

println "Executing jmxForceRefresh()"
dataSystem.jmxForceRefresh();
Run Code Online (Sandbox Code Playgroud)

cmdline-jmxclient示例:

如果你有

  • MBean:com.company.data:type = datasystem,id = 0

通过一个名为的操作:

  • jmxForceRefresh()

然后你可以编写一个简单的bash脚本(假设你下载cmdline-jmxclient-0.10.3.jar并放入与你的脚本相同的目录):

#!/bin/bash

cmdLineJMXJar=./cmdline-jmxclient-0.10.3.jar
user=yourUser
password=yourPassword
jmxHost=localhost
port=9003

#No User and password so pass '-'
echo "Available Operations for com.company.data:type=datasystem,id=0"
java -jar ${cmdLineJMXJar} ${user}:${password} ${jmxHost}:${port} com.company.data:type=datasystem,id=0

echo "Executing XML update..."
java -jar ${cmdLineJMXJar} - ${jmxHost}:${port} com.company.data:type=datasystem,id=0 jmxForceRefresh
Run Code Online (Sandbox Code Playgroud)


Ala*_*ack 18

我开发了jmxfuse,它将JMX Mbeans暴露为具有与/ proc fs类似功能的Linux FUSE文件系统.它依靠Jolokia作为JMX的桥梁.公开属性和操作以进行读写.

http://code.google.com/p/jmxfuse/

例如,要读取属性:

me@oddjob:jmx$ cd log4j/root/attributes
me@oddjob:jmx$ cat priority
Run Code Online (Sandbox Code Playgroud)

写一个属性:

me@oddjob:jmx$ echo "WARN" > priority
Run Code Online (Sandbox Code Playgroud)

调用操作:

me@oddjob:jmx$ cd Catalina/none/none/WebModule/localhost/helloworld/operations/addParameter
me@oddjob:jmx$ echo "myParam myValue" > invoke
Run Code Online (Sandbox Code Playgroud)


小智 11

Syabru Nagios的JMX插件是为了从Nagios的使用,但不要求Nagios的,是命令行使用非常方便:

~$ ./check_jmx -U service:jmx:rmi:///jndi/rmi://localhost:1099/JMXConnector --username myuser --password mypass -O java.lang:type=Memory -A HeapMemoryUsage -K used 
JMX OK - HeapMemoryUsage.used = 445012360 | 'HeapMemoryUsage used'=445012360;;;;
Run Code Online (Sandbox Code Playgroud)


tek*_*aul 7

可能最容易用Java编写它

import javax.management.*;
import javax.management.remote.*;

public class JmxInvoke {

    public static void main(String... args) throws Exception {

        JMXConnectorFactory.connect(new JMXServiceURL(args[0]))
            .getMBeanServerConnection().invoke(new ObjectName(args[1]), args[2], new Object[]{}, new String[]{})


    }

}
Run Code Online (Sandbox Code Playgroud)

这将编译为单个.class,并且不需要服务器或任何复杂的maven包装中的依赖项.

叫它

javac JmxInvoke.java
java -cp . JmxInvoke [url] [beanName] [method]
Run Code Online (Sandbox Code Playgroud)


小智 5

有点冒险,但您可以使用来自 JMX 控制台的表单中的值、其 URL 和 http 身份验证(如果需要)运行 curl POST 命令:

curl -s -X POST --user 'myuser:mypass'
  --data "action=invokeOp&name=App:service=ThisServiceOp&methodIndex=3&arg0=value1&arg1=value1&submit=Invoke"
  http://yourhost.domain.com/jmx-console/HtmlAdaptor
Run Code Online (Sandbox Code Playgroud)

注意:方法索引可能会随着软件的变化而变化。并且 Web 表单的实现可能会发生变化。

以上基于您要执行的操作的 JMX 服务页面的来源:

http://yourhost.domain.com/jmx-console/HtmlAdaptor?action=inspectMBean&name=YourJMXServiceName
Run Code Online (Sandbox Code Playgroud)

表格来源:

form method="post" action="HtmlAdaptor">
   <input type="hidden" name="action" value="invokeOp">
   <input type="hidden" name="name" value="App:service=ThisServiceOp">
   <input type="hidden" name="methodIndex" value="3">
   <hr align='left' width='80'>
   <h4>void ThisOperation()</h4>
   <p>Operation exposed for management</p>
    <table cellspacing="2" cellpadding="2" border="1">
        <tr class="OperationHeader">
            <th>Param</th>
            <th>ParamType</th>
            <th>ParamValue</th>
            <th>ParamDescription</th>
        </tr>
        <tr>
            <td>p1</td>
           <td>java.lang.String</td>
         <td> 
            <input type="text" name="arg0">
         </td>
         <td>(no description)</td>
        </tr>
        <tr>
            <td>p2</td>
           <td>arg1Type</td>
         <td> 
            <input type="text" name="arg1">
         </td>
         <td>(no description)</td>
        </tr>
    </table>
    <input type="submit" value="Invoke">
</form>
Run Code Online (Sandbox Code Playgroud)