シェル スクリプトから JMX MBean メソッドを呼び出せるライブラリはありますか。JMX を介して一部の操作/管理コマンドを公開し、管理者に JConsole または VisualVM を使用させることもできますが、一部のタスクは自動化に任せたほうがよいでしょう。その自動化では、実行中のサーバーで、できればシェル スクリプトから JMX MBean メソッドを呼び出せるようにしたいと考えています。
9 に答える
次のコマンド ライン JMX ユーティリティを使用できます。
- jmxterm - 最も完全な機能を備えたユーティリティのようです。
- cmdline-jmxclient - WebArchive プロジェクトで使用されているものは非常に骨の折れるように見えます (2006 年以降は開発されていないようです)
- Groovy スクリプトと JMX - 非常に強力な JMX 機能を提供しますが、groovy およびその他のライブラリのセットアップが必要です。
- 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();
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
/proc fs と同様の機能を持つ Linux FUSE ファイルシステムとして JMX Mbeans を公開する jmxfuse を開発しました。JMX へのブリッジとしてJolokiaに依存しています。属性と操作は、読み取りと書き込みのために公開されます。
http://code.google.com/p/jmxfuse/
たとえば、属性を読み取るには:
me@oddjob:jmx$ cd log4j/root/attributes
me@oddjob:jmx$ cat priority
属性を書き込むには:
me@oddjob:jmx$ echo "WARN" > priority
操作を呼び出すには:
me@oddjob:jmx$ cd Catalina/none/none/WebModule/localhost/helloworld/operations/addParameter
me@oddjob:jmx$ echo "myParam myValue" > invoke
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;;;;
少し危険ですが、JMXコンソールのフォームの値、そのURL、およびhttp認証(必要な場合)を使用してcurlPOSTコマンドを実行できます。
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
注意:メソッドインデックスは、ソフトウェアの変更に伴って変更される場合があります。また、Webフォームの実装が変更される可能性があります。
上記は、実行する操作のJMXサービスページのソースに基づいています。
http://yourhost.domain.com/jmx-console/HtmlAdaptor?action=inspectMBean&name=YourJMXServiceName
フォームのソース:
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>
JManageを見てください。MBean メソッドを実行し、コマンド ラインから属性を取得/設定できます。
jmx4perlも参照してください。リモート Java EE サーバーの MBean への Java レス アクセスを提供します。ただし、小さなエージェント サーブレットをターゲット プラットフォームにインストールする必要があります。これにより、JSON ペイロードを使用して HTTP 経由で安静な JMX アクセスが提供されます。(バージョン 0.50 では、JSR-160 プロキシを実装することでエージェントレス モードが追加されます)。
利点は、ローカルの Java JVM を起動する場合に比べて起動時間が短く、使いやすいことです。jmx4perl には、独自のスクリプトで簡単に使用できる Perl モジュールの完全なセットが付属しています。
use JMX::Jmx4Perl;
use JMX::Jmx4Perl::Alias; # Import certains aliases for MBeans
print "Memory Used: ",
JMX::Jmx4Perl
->new(url => "http://localhost:8080/j4p")
->get_attribute(MEMORY_HEAP_USED);
一般的な MBean/属性/操作の組み合わせ (ほとんどの MXBean など) にエイリアスを使用することもできます。追加機能 (Nagios プラグイン、複雑な属性タイプへの XPath のようなアクセスなど) については、jmx4perl のドキュメントを参照してください。
@Dougnukemの回答は私を大いに助けてくれました。私は Groovy アプローチを採用しました (groovy 2.3.3 を使用)。
Dougnukem コードにいくつかの変更を加えました。これは Java 7 で動作し、10 秒ごとに 2 つの属性を stdout に出力します。
package com.my.company.jmx
import groovy.util.GroovyMBean;
import javax.management.remote.JMXServiceURL
import javax.management.remote.JMXConnectorFactory
import java.lang.management.*
class Monitor {
static main(args) {
def serverUrl = 'service:jmx:rmi:///jndi/rmi://localhost:5019/jmxrmi'
String beanName = "Catalina:type=DataSource,class=javax.sql.DataSource,name=\"jdbc/CommonDB\""
println "numIdle,numActive"
while(1){
def server = JMXConnectorFactory.connect(new JMXServiceURL(serverUrl))
//make sure to reconnect in case the jvm was restrated
server.connect()
GroovyMBean mbean = new GroovyMBean(server.MBeanServerConnection, beanName)
println "${mbean.numIdle},${mbean.numActive}"
server.close()
sleep(10000)
}
}
}
このコードを maven-compiler-plugin を使用して jar にコンパイルすると、groovy-all.jar のみをインストールする必要がなくなります。以下は、関連するプラグインの定義と依存関係です。
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<compilerId>groovy-eclipse-compiler</compilerId>
<source>1.7</source>
<target>1.7</target>
</configuration>
<dependencies>
<dependency>
<groupId>org.codehaus.groovy</groupId>
<artifactId>groovy-eclipse-compiler</artifactId>
<version>2.8.0-01</version>
</dependency>
<dependency>
<groupId>org.codehaus.groovy</groupId>
<artifactId>groovy-eclipse-batch</artifactId>
<version>2.3.4-01</version>
</dependency>
</dependencies>
</plugin>
</plugins>
</build>
<dependencies>
<dependency>
<groupId>org.codehaus.groovy</groupId>
<artifactId>groovy-all</artifactId>
<version>2.4.3</version>
</dependency>
</dependencies>
バットまたはシェルでラップすると、データが標準出力に出力されます。
bashのような環境についてはよくわかりません。リモートサーバーでMBeanを呼び出すJavaのいくつかの単純なラッパープログラム(プログラム引数を使用)を試すことができます。次に、シェルスクリプトからこれらのラッパーを呼び出すことができます
PythonやPerlのようなものを使用できる場合は、Webサービスを介してJMX操作を公開できるJSR-262に興味があるかもしれません。これはJava7に含まれる予定ですが、リファレンス実装のリリース候補を使用できる可能性があります