java - 在 Domino Java 代理中使用记录器

标签 java logging lotus-domino javaagents

我想避免在 Java 代理中使用字符串缓冲区和 System.out.println。

我想使用java.util.Logger。

当我使用

登录时
logger.info("logger started")

Domino 服务器控制台中的输出

[0FDC:000D-1258] 06/07/2018 03:13:57 PM  Agent Manager: Agent  error: Jun 07, 2018 3:13:57 PM TransferDocsToServerNSF NotesMain INFO: logger started.

请注意,使用 Level.INFO 时,Domino 平台在输出之前添加了“代理错误”

然后我尝试将 .logp 与 Level.FINE 一起使用,但没有显示任何输出。

logger.setLevel(Level.ALL); or logger.setLevel(Level.FINE);
logger.logp(Level.FINE,this.getClass().getSimpleName(),"main","logger started.");

输出:无输出。任何低于 Level.INFO 的内容都不会打印。

如何定位 Domino 日志记录以显示 Level.FINE?

而且,我可以为 Domino 的 INFO 做些什么,才能不将所有 Level.INFO 视为错误?

最佳答案

在服务器上编辑此文件后,我能够打印不同级别的日志记录:

(服务器安装)IBM/Domino/jvm/lib/logging.properties

# Default global logging level.
# This specifies which kinds of events are logged across
# all loggers.  For any given facility this global level
# can be overriden by a facility specific level
# Note that the ConsoleHandler also has a separate level
# setting to limit messages printed to the console.
.level= FINEST

# Limit the message that are printed on the console to INFO and above.
java.util.logging.ConsoleHandler.level = FINEST

测试Java代码

logger = Logger.getLogger("com.xpagesbeast");
logger.setUseParentHandlers(false); //do not use the global logger (avoid two outputs per log)

创建一个自定义处理程序(如果不存在),请观看我们的此处,您可以创建多个 JVM 将跟踪的处理程序。

if(logger.getHandlers().length == 0){
    System.out.println("Adding a new handler"); 
    consoleHandler = new ConsoleHandler();
    logger.addHandler(consoleHandler);
}               

logger.getHandlers()[0].setLevel(Level.INFO);
logger.severe("test severe logging " + logger.getName());
logger.warning("test warning logging " + logger.getName());
logger.info("test info logging " + logger.getName());
logger.finer("test finer logging " + logger.getName());
logger.finest("test finest logging " + logger.getName());

现在我可以在数据库或环境变量中设置调试标志,并根据需要指定详细的日志记录级别。

例如,如果我想调试应用程序,我可以在应用程序读取的数据库中设置一个值,该值确定处理程序将使用的日志记录级别。

关于java - 在 Domino Java 代理中使用记录器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50749752/

相关文章:

java - Log4j2:如果已存在,则记录到不同的文件

c# - 使用 DI 在 Azure Function 中使用 ILogger

xpages - 注释错误 : Entry not found in index when reading view entries

java - Lotus Domino Java API session 创建和取消

java - spring data neo4j 4.2.0.RELEASE自定义查询问题

java - 如何使用 Jsoup 获取表单验证码图像?

java - docker-java 使用 -rm 标志运行容器

java - 在Java中创建日期对象最有效的方法是什么

c - 尽管 G_MESSAGES_DEBUG 设置为 all,GLib 仍不打印信息或调试日志级别

c#-2.0 - Interop.Domino dll 线程安全吗?