확장 Log4j 지원 JNDI 데이터 원본
4918 단어 log4j
log4j.rootLogger=INFO,db
# log4j JNDI
log4j.appender.db=com.qdgswx.log4j.ds.JndiDSAppender
log4j.appender.db.jndiName=wstjndi
log4j.appender.db.BufferSize=1
log4j.appender.db.sql=insert into wx_log (openid,nsrsbh,logtype,classname,methodname,oprtime,loglevel,content) values ('%X{openid}','%X{nsrsbh}','%X{logtype}','%C','%M','%d{yyyy-MM-dd HH:mm:ss}','%p','%m')
log4j.appender.db.layout=org.apache.log4j.PatternLayout
확장 클래스 JndiDSAppender.java
public class JndiDSAppender extends JDBCAppender {
protected DataSource ds = null;
protected String jndiName;
public void setJndiName(String jndiName) {
this.jndiName = jndiName;
}
protected synchronized void init() {
if (ds != null) {
return;
}
try {
InitialContext context = new InitialContext();
ds = (DataSource) context.lookup(jndiName);
} catch (NamingException e) {
this.errorHandler.error(e.getMessage());
}
}
@Override
protected Connection getConnection() throws SQLException {
while(ds==null){
init();
}
Connection conn = ds.getConnection();
conn.setAutoCommit(true);
return conn;
}
@Override
protected void closeConnection(Connection conn) {
try {
if(conn!=null&&!conn.isClosed()) {
conn.close();
}
} catch (SQLException e) {
this.errorHandler.error(e.getMessage());
}
}
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Spring Boot에서 log4j 로깅 방법Spring Boot은 모든 내부 로그에 Commons Logging을 사용하지만, 기본 설정은 Java Util Logging, Log4J, Log4J2, Logback과 같은 일반적인 로그를 지원합니다.각 Log...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.