首页 > 解决方案 > 在 Jenkins 日志之外记录 Jenkins 操作

问题描述

我想在 var/jenkins/logs (Jenkins 的默认日志位置)之外的单独文件中记录一些 INFO 消息,但我找不到任何工作示例。

登录 Jenkins 日志很简单:

static final Logger LOGGER = Logger.getLogger([YOUR_CLASS_NAME].class.getName());
LOGGER.log(Level.INFO, [MESSAGE]);

但我不确定如何将消息记录在单独的文件中。

任何帮助深表感谢!

回复后的补充

我要记录的上下文在我编写的自定义插件中,我基本上用我的自定义比较器覆盖了 Jenkins 中的默认比较器。根据某些标准,作业在构建队列中被视为比其他作业更优先。

@Override
public int compare(Queue.BuildableItem lhs, Queue.BuildableItem rhs) {
    if (shouldBePrioritized(lhs) && !shouldBePrioritized(rhs)) {
        LOGGER.log(Level.INFO, "[BQP] Comparing " + lhs.task.getName() + "and " + rhs.task.getName() + ". Result: " + lhs.task.getName());
        return -1;
    }
    if (shouldBePrioritized(rhs) && !shouldBePrioritized((lhs))) {
        LOGGER.log(Level.INFO, "[BQP] Comparing " + lhs.task.getName() + "and " + rhs.task.getName() + ". Result: " + rhs.task.getName());
        return 1;
    }
    LOGGER.log(Level.INFO, "[BQP] Comparing " + lhs.task.getName() + "and " + rhs.task.getName() + ". Result: equal");
    return super.compare(lhs, rhs);
}

我目前使用此 LOGGER.log() 将比较记录到 Jenkins 日志中,但我想将比较记录在运行 Jenkins 的 Docker 容器所在的 VM 上的单独文件中,但我认为这超出了问题。现在,如果我设法将该信息记录在 Jenkins 容器内的文件中,那就没问题了。

谢谢!

标签: javajenkinslogging

解决方案


您必须为您获得的 Logger 添加一个自定义处理程序。

static final LOGGER = createLogger();

private static Logger createLogger() {
    Logger logger = Logger.getLogger(MyClass.class.getName());
    FileHandler handler = new FileHandler("/tmp/mylog.log", 1024 * 1024, 10, true); // You can use any variable as a first argument, including some constants from other classes too!
    handler.setFormatter(new SimpleFormatter());
    logger.addHandler(handler);
    return logger;
}

文档在这里解释了这一点(在 Groovy 中,但语法在 Java 中基本相同,除了行尾的分号)。

如果您使用要编写日志的上下文(插件?自定义挂钩?)更新您的问题,那么也许我们可以帮助您获得更具体的问题答案。另外,请透露一些您的真实代码并告诉我们您卡在哪里。


推荐阅读