3

jboss 7.1.3で私の(はるかに大きい)*.earの展開状態を監視する小さな「ウォッチドッグ」*.warを書き込もうとしています

*.earの正確なデプロイ状態を取得するにはどうすればよいですか?

私はこれを行うことができることを知っています (jboss MSC クラスを使用):

ServiceContainer sc = CurrentServiceContainer.getServiceContainer(); //jboss msc
ServiceController earController = sc.getService(Services.deploymentUnitName("my.ear"));
return "my.ear - "+earController.getMode()+"-"+earController.getState()+"-"+earController.getSubstate();

しかし、これにより、展開が失敗した場合でも、すべて緑色になります。たとえば、@PostConstruct メソッド (ブートの一部として呼び出される) が例外をスローする @Startup @Singleton があるとします。この時点で、デプロイは論理的に失敗しました (初期化で例外がスローされました) が、jboss は.ear をデプロイ済みとしてマークします - デプロイ ディレクトリのマーカー ファイル ( .isDeploying --> *.deployed) とコントローラーからの値の両方を使用します。その上。

jboss には、依存関係が欠落しているサービスのリストを保持する ContainerStateMonitor クラスがあります。それを取得する方法。

私が見つけた最も近いものはこれでした:

sc.getService(org.jboss.as.serverServices.JBOSS_SERVER_CONTROLLER).getService()

これにより、そのデータを保持するコントローラー (一時) フィールドを持つServerServiceのインスタンスが取得されます。しかし、それはすべて私的な分野であり、私は本当に反射に頼りたくありません.

だから私の質問は - そのデータを取得する方法はありますか? jboss は明らかに、どの @Singletons がデプロイに失敗したか、どの @EJB が依存関係を欠いているか、どのデータソースが接続に失敗したかなどを知っていますが、それに到達する方法はありますか? MSC である必要はありません。JMX (jboss 7 では MSC にマップされるだけだと思いますが) またはその他の API である可能性があります。

4

1 に答える 1

3

管理 APIを使用して、結果を確認できます。

コードは次のようになります。

import java.net.InetAddress;

import org.jboss.as.controller.client.ModelControllerClient;
import org.jboss.as.controller.client.helpers.ClientConstants;
import org.jboss.as.controller.client.helpers.Operations;
import org.jboss.dmr.ModelNode;

public class ClientExample {

    public static void main(final String[] args) throws Exception {
        final ModelControllerClient client = ModelControllerClient.Factory.create(InetAddress.getLocalHost(), 9999);
        try {
            final ModelNode address = new ModelNode().setEmptyList();
            address.add("deployment", "jboss-as-helloworld.war");
            final ModelNode op = Operations.createReadResourceOperation(address, true);
            op.get(ClientConstants.INCLUDE_RUNTIME).set(true);
            final ModelNode outcome = client.execute(op);
            if (Operations.isSuccessfulOutcome(outcome)) {
                System.out.println(outcome);
            } else {
                System.err.printf("Operation failure: %s%n", Operations.getFailureDescription(outcome));
            }
        } finally {
            client.close();
        }
    }
}

注意: API の 7.2.0.Final バージョンを使用しています。これは、古いバージョンの JBoss AS7、JBoss EAP 6.x、および WildFly で動作するはずです。

これは次のような結果を出力します

{
    "outcome" => "success",
    "result" => {
        "content" => [{"hash" => bytes {
            0xab, 0x77, 0x61, 0x49, 0x4b, 0x30, 0x3b, 0x4f,
            0xd7, 0x80, 0x13, 0x5a, 0x6c, 0x48, 0x1e, 0x3d,
            0xb3, 0xbe, 0xc1, 0xc2
        }}],
        "enabled" => true,
        "name" => "jboss-as-helloworld.war",
        "persistent" => true,
        "runtime-name" => "jboss-as-helloworld.war",
        "status" => "OK",
        "subdeployment" => undefined,
        "subsystem" => {"web" => {
            "active-sessions" => 0,
            "context-root" => "/jboss-as-helloworld",
            "duplicated-session-ids" => 0,
            "expired-sessions" => 0,
            "max-active-sessions" => 0,
            "rejected-sessions" => 0,
            "session-avg-alive-time" => 0,
            "session-max-alive-time" => 0,
            "sessions-created" => 0,
            "virtual-host" => "default-host",
            "servlet" => {"org.jboss.as.quickstarts.helloworld.HelloWorldServlet" => {
                "load-time" => 0L,
                "maxTime" => 9223372036854775807L,
                "min-time" => 0L,
                "processingTime" => 0L,
                "requestCount" => 0,
                "servlet-class" => "org.jboss.as.quickstarts.helloworld.HelloWorldServlet",
                "servlet-name" => "org.jboss.as.quickstarts.helloworld.HelloWorldServlet"
            }}
        }}
    }
}

または、ステータスだけが必要な場合は、上記の例を少し変更して次のようにします。

final ModelNode op = Operations.createReadAttributeOperation(address, "status");
final ModelNode outcome = client.execute(op);
if (Operations.isSuccessfulOutcome(outcome)) {
    System.out.println(Operations.readResult(outcome).asString());
} else {
    System.err.printf("Operation failure: %s%n", Operations.getFailureDescription(outcome));
}
于 2013-04-30T22:50:48.103 に答える