これは、このスレッドで説明されている問題に非常に近いように見え、同様のクラスの読み込みの問題が疑われます。ログバックのロード方法logback.xml
(より正確には、ログバックが取得する方法ClassLoader
)が原因で、構成ファイルの取得に失敗し、デフォルトにフォールバックする可能性がありますBasicConfiguration
。
コードをどのようにパッケージ化するかはわかりませんが、推奨される回避策はlogback.xml
、EARライブラリにを含めることです。EARパッケージを使用していない場合は、logback.xml
ファイルを配置する場所を確認するために使用されるクラスローダーを特定してみてください。
最後に、これはログバックで問題になる可能性があります。ただし、課題追跡システムは確認していません。
更新: warパッケージを使用する場合は、委任する前に最初に子クラスローダーを使用するようにGlassFishを構成してみてください。でsun-web.xml
:
<sun-web-app>
<class-loader delegate="false"/>
</sun-web-app>
更新:私は私の側で少しテストをしました、そして...私はあなたの問題を再現することができません。次の構造を持つJavaEE6Webアプリケーションのプロジェクトを作成しました。
$ツリーサンプル
サンプル
|-pom.xml
`-src
`-メイン
|-java
| `-com
| `-stackoverflow
| `-q2418355
| |-SimpleEJB.java
| `-SimpleServlet.java
|-リソース
| `-logback.xml
`-webapp
|-META-INF
| `-MANIFEST.MF
|-WEB-INF
| `-lib
`-index.jsp
私のpom.xmlは次のようになります:
<?xml version="1.0" encoding="UTF-8"?>
<project xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"
xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<modelVersion>4.0.0</modelVersion>
<groupId>com.stackoverflow.q2418355</groupId>
<artifactId>sample</artifactId>
<version>1.0-SNAPSHOT</version>
<packaging>war</packaging>
<name>sample Maven Webapp</name>
<url>http://maven.apache.org</url>
<dependencies>
<dependency>
<groupId>javax</groupId>
<artifactId>javaee-api</artifactId>
<version>6.0</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.7</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-classic</artifactId>
<version>0.9.18</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.5.11</version>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>2.0.2</version>
<configuration>
<source>1.6</source>
<target>1.6</target>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-war-plugin</artifactId>
<version>2.1-beta-1</version>
<configuration>
<failOnMissingWebXml>false</failOnMissingWebXml>
</configuration>
</plugin>
</plugins>
<finalName>sample</finalName>
</build>
</project>
のコードSimpleEJB.java
は次のとおりです。
package com.stackoverflow.q2418355;
import javax.ejb.Stateless;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
@Stateless
public class SimpleEJB {
private static Logger logger = LoggerFactory.getLogger(SimpleEJB.class);
public String sayHello(String name) {
logger.debug(">> sayHello()");
logger.debug("<< sayHello()");
return "Hello " + name + "!!!";
}
}
のコードSimpleServlet.java
は次のとおりです。
package com.stackoverflow.q2418355;
import java.io.IOException;
import java.io.PrintWriter;
import javax.ejb.EJB;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
@WebServlet(urlPatterns = { "/SimpleServlet" })
public class SimpleServlet extends HttpServlet {
@EJB
SimpleEJB bean;
private static Logger logger = LoggerFactory.getLogger(SimpleServlet.class);
@Override
public void doGet(HttpServletRequest request, HttpServletResponse response) throws IOException {
logger.debug(">> doGet()");
PrintWriter out = response.getWriter();
out.println("<html><body>");
out.println("<h2>Serving at: " + request.getContextPath() + "</h2>");
out.println("<h2>Invoking EJB: " + bean.sayHello("Duke") + "</h2>");
out.println("</body></html>");
logger.debug("<< doGet()");
}
}
のコードindex.jsp
は次のとおりです。
<html>
<body>
<h2>Hello World!</h2>
Invoke the Servlet by clicking <a href="SimpleServlet">here</a>.
</body>
</html>
そして私のようにlogback.xml
見えます:
<configuration>
<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
<layout class="ch.qos.logback.classic.PatternLayout">
<Pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</Pattern>
</layout>
</appender>
<appender name="FILE" class="ch.qos.logback.core.FileAppender">
<File>/tmp/logs/testFile.log</File>
<Append>true</Append>
<layout class="ch.qos.logback.classic.PatternLayout">
<Pattern>%-4relative [%thread] %-5level %logger{35} - %msg%n</Pattern>
</layout>
</appender>
<logger name="com.stackoverflow.q2418355" level="TRACE"/>
<root level="debug">
<appender-ref ref="STDOUT" />
<appender-ref ref="FILE" />
</root>
</configuration>
logback.xml
サーブレットを呼び出すと、適切にロードされ、次のトレース(ログファイルから取得)が取得されます。
10913 [http-thread-pool-8080-(1)] DEBUG com.stackoverflow.q2418355.SimpleServlet - >> doGet()
10928 [http-thread-pool-8080-(1)] DEBUG com.stackoverflow.q2418355.SimpleEJB - >> sayHello()
10928 [http-thread-pool-8080-(1)] DEBUG com.stackoverflow.q2418355.SimpleEJB - << sayHello()
10932 [http-thread-pool-8080-(1)] DEBUG com.stackoverflow.q2418355.SimpleServlet - << doGet()
また、EJBを独自のJARにパッケージ化してデプロイしWEB-INF/lib
、同じ結果を取得してみましたが、正常に機能します。明らかな違いを見つけることができますか?たぶん、あなたのアプリの簡略化されたバージョンをアップロードしてください(バグレポートBTWに必要になる可能性が非常に高いです)。
GlassFish v3をEclipse3.5で実行しています(GlassFish v3プラグインを使用)。