java - 如何从ModelNode结果中获取特定对象

标签 java jboss wildfly application-server

我与ModelControllerClient一起获取有关Wildfly服务器中使用的记录器的一些信息。 我想要一个所有记录器名称的列表。

这是我获取有关记录器的所有信息的方式:

ModelNode op = new ModelNode();
op.get("operation").set("read-resource");

ModelNode address = op.get("address");
address.add("subsystem", "logging");
address.add("logger", "*");

ModelNode result = client.execute(op);

这是我得到的 ModelNode 结果的一个小例子。

{
        "address" => [
            ("subsystem" => "logging"),
            ("logger" => "jacorb")
        ],
        "outcome" => "success",
        "result" => {
            "category" => "jacorb",
            "filter" => undefined,
            "filter-spec" => undefined,
            "handlers" => undefined,
            "level" => "WARN",
            "use-parent-handlers" => true
        }
    },
    {
        "address" => [
            ("subsystem" => "logging"),
            ("logger" => "jacorb.config")
        ],
        "outcome" => "success",
        "result" => {
            "category" => "jacorb.config",
            "filter" => undefined,
            "filter-spec" => undefined,
            "handlers" => undefined,
            "level" => "ERROR",
            "use-parent-handlers" => true
        }
    },

我只想获取“logger”/“category”的值。

我尝试通过以下方式获取记录器的名称:

result.get("logger");

但它返回“未定义”。我想问题是我有多个名为“logger”的对象。当我尝试使用“类别”时,也会发生同样的情况。

最佳答案

您需要首先读取结果。在简单的情况下,它将是 result.get("result", "logger")。您还可以使用 Operations API 并执行类似 Operations.readResult(result).get("logger") 的操作。

如果您只想要记录器名称,这里有一个示例:

try (ModelControllerClient client = ModelControllerClient.Factory.create("localhost", 9990)) {
    final ModelNode address = Operations.createAddress("subsystem", "logging");
    final ModelNode op = Operations.createOperation(ClientConstants.READ_CHILDREN_NAMES_OPERATION, address);
    op.get(ClientConstants.CHILD_TYPE).set("logger");
    final ModelNode result = client.execute(op);
    if (Operations.isSuccessfulOutcome(result)) {
        final List<ModelNode> loggerNames = Operations.readResult(result).asList();
        for (ModelNode loggerName : loggerNames) {
            System.out.printf("logger=%s%n", loggerName.asString());
        }
    } else {
        System.err.printf("Failed to get the logger names: %s%n", Operations.getFailureDescription(result).asString());
    }
}

如果您想要完整的描述,您可以使用read-children-resource操作。

WildFly 文档还有一个关于 using the ModelControllerClient 的部分和 ModelNode and ModelType API。

关于java - 如何从ModelNode结果中获取特定对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54788954/

相关文章:

java - 如何先更新变量然后在java中执行其余代码

java - 除非明确注释,否则不会发现 CDI bean

java - 如何在PeriodicSizeRotatingFileHandler JBoss 7中使用带有日期的文件名?

java - JBoss中如何知道某个模块依赖于哪些模块?

caching - Wildfly infinispan Web 缓存容器的用途是什么?

java - 添加 jai 作为 wildfly 模块

java - 如何通过我们的程序在运行时注册新的 JNDI 名称?

java - 我该怎么做才能让我的程序不出现 IndexOutOfBounds 错误?

Wildfly 中的 Spring Boot Websockets

java - 如何将 .min() 或 .max() 作为流的方法参数?