- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我们使用 slf4j 和 logback 来登录我们的 Java EE Web 应用程序。最近,为了将这些库移动到 glassfish 应用服务器中的一个公共(public)位置(特别是 glassfish\lib 目录),我们进行了一些配置更改。我们在 web.xml 文件中进行了更改以添加 JNDI 条目并重命名为 logback.xml
至 logback-<context-name>.xml
如 here 中所述. logback-<context-name>.xml
放在WEB-INF\classes目录下。
此更改后,hibernate 和 http-client 库的日志记录默认为 Debug模式,因此需要进行大量日志记录。根记录器具有 INFO 日志级别,并且没有为 hibernate 和 http 客户端库定义特定的记录器。
如果我还原此更改,即删除 web.xml 中的 jndi 条目并将配置文件重命名为 logback.xml,则只会按预期记录 INFO 日志。
对可能出现的问题有什么建议吗?
谢谢。
更新
在进一步排除故障时,我发布了 hibernate 和 apache 客户端库使用在初始化期间创建的默认记录器上下文。此记录器上下文的根日志级别设置为 DEBUG。我们使用 JNDI 作为上下文选择器。
奇怪的是,当 ConnectionManager 类(hibernate 类 - org.hibernate.jdbc.ConnectionManager)尝试实例化记录器时,在运行时找不到上下文名称。记录器实例创建调用 ContextJNDISelector.getLoggerContext() 方法。此方法执行 JNDI 查找但未找到该条目。
我通过在 servlet 上下文监听器中生成一个线程以每 3 秒打印一次 JNDI 条目 (java:comp/env/logback/context-name) 来进一步排除故障。来自线程的日志表明 JNDI 条目始终存在。
知道为什么当 ContextJNDISelector 查询时在 JNDI 中找不到 contextName 吗?
最佳答案
这似乎是个问题,因为应用程序使用了 EJB。应用程序服务器 (glassfish) 在实际设置日志上下文之前加载 EJB。因此,一些库的日志消息被记录在 DEBUG 级别下。在记录器周围使用包装器类解决了这个问题。包装类延迟了记录器的创建,直到它第一次使用。
public class LogWrapper {
private Class loggerClass;
private Logger logger;
public LogWrapper(Class loggerClass) {
this.loggerClass = loggerClass; //lazy logging context creation (to avoid issues with static instances in EJBs which get loaded on startup before logging ctx name is actually set)
}
/**
* For lazy init of logger, on first actual use, so the logger context will be correctly set even when used by EJBs (loaded by classloader too soon, before logging context is actually set)
*/
private Logger getLogger() {
if (logger == null) {
logger = LoggerFactory.getLogger(loggerClass);
loggerClass = null;
}
return logger;
}
public void info(String message) {
getLogger().info(message);
}
关于java - 某些第三方库的 Logback 默认为 Debug模式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17611813/
这个问题不太可能帮助任何 future 的访问者;它只与一个小的地理区域、一个特定的时间点或一个非常狭窄的情况有关,这些情况并不普遍适用于互联网的全局受众。为了帮助使这个问题更广泛地适用,visit
class Person def name puts "Doharey" end end puts Person.class #=> this out puts Class puts
在 PHP 中,($myvariable==0)当 $myvariable 为零时,表达式的值为真;当 $myvariable 为 null 时,此表达式的值也为 true。如何排除第二种情况?我的意
正文 Oracle的一顿猛如虎操作,让开发者彻底失去了Java EE。Eclipse基金会则自立门户,另起炉灶开启Jakarta EE项目。 对于Jakarta EE,从它
我是 python 新手,建议我使用 Canopy。我正在努力跟进 with this tutorial ,但我陷入了 mahotas.imread 行。我收到一个错误,说以这个结尾: Full er
上下文是我们想要跟踪应用程序的用户行为,因为它具有不同的功能。 为此,我们创建了一个自定义 Angular Directive(指令),例如myFunctionality并将 HTML 部分包装到此指
我正在尝试在文本字段中实现 google Places api 的自动完成功能。这是我的代码: $(document).ready(function() { initialize(){ v
我在 Glassfish 3.1.1 中配置了一个新的 jdbcRealm 并打开了 FINEST 日志记录,当我尝试使用用户名和密码登录时,我得到以下信息。它提示我的 Web 应用程序映射到的领域是
问题是,即使我将线程设置为“thrd.IsBackground = false”,iis 也不认为它正在运行,即使这是一个长时间运行的进程。如果我不关闭应用程序池的空闲关闭,它将关闭,因为它认为它是空
我正在使用 OpenJDK 8(从 https://jdk.java.net/java-se-ri/8 下载并解压,添加到 PATH),并且遇到了证书错误。 经过调查,我意识到 cacerts 存在问
我基于 Firebase 制作了简单的后期制作项目。我将帖子保存到 Firebase 中,如下所示: let data = UIImageJPEGRepresentation(newPostImage
我觉得还是先说明情况比较好。 情况 我正在编写一些软件来过滤 Set 的 File。 过滤器如下:如果文件未隐藏,则将其添加到新的 Set。 问题在于 File.isHidden() 的当前行为如下:
我创建了一个 C++ DLL 函数,它使用多个数组来处理最终的图像数据。我正在尝试通过引用传递这些数组,进行计算,然后通过预分配数组中的引用将输出传回。在该函数中,我使用了 Intel Perform
我在 python 中有一个小应用程序,除了这个小问题之外,它工作得很好:它应该连续运行一个循环,直到用户通过按钮告诉它停止,但是当我点击开始按钮时,Windows 告诉我它不是回应。现在,如果我编写
代码运行正常,但我怎么会得到这个错误日志 错误日志: 08-28 08:44:24.281: E/MediaPlayer(32454): mOnVideoSizeChangedListener is
我有一个使用 Karma+Jasmine 和 JSHint 的 Grunt 设置。每当我在我的规范文件上运行 JSHint 时,我都会收到一系列“未定义”错误,其中大部分是针对 Jasmine 的内置
将以下代码保存到文件中,Ubuntu 14.04 正确地意识到它是 bash: #!/usr/bin/env bash awk '{print $1 $2}' my_file 然而,向 awk 添加关
以下代码返回 false import inspect print(inspect.isbuiltin(map)) 但是 map 功能在"built-in" functions下列出. 为什么会这样?
这是一段常见的示例代码: while (1) { print "foo\n"; } 永远打印“foo”。 perl foo.pl foo foo foo ... 和 while (0) { p
我对 Haskell 比较陌生,来自 F#(一种 Microsoft 语言)。 我已经从脚手架创建了一个 Yesod 项目,稍微玩了一下,调整了一些东西,但随后它停止工作,并显示此错误消息(在所有模块
我是一名优秀的程序员,十分优秀!