기본 콘텐츠로 건너뛰기

[spring] log4j 설정 및 사용법



























log4j에서 사용하는 log 레벨은 여섯단계이다. 
TRACE으로 설정하면 모든 레벨의 로그가 전부 기록되지만
FATAL으로 설정하면 FATAL보다 하위수준의 로그는 기록되지 않는다. 


Log4j 설정 

log4j를 사용하기 위해 pom.xml과 web.xml에 다음처럼 추가한다. 

- Log4j Maven dependencies
  1. <dependencies>
  2. <dependency>
  3. <groupId>org.apache.logging.log4j</groupId>
  4. <artifactId>log4j-api</artifactId>
  5. <version>2.0-beta6</version>
  6. </dependency>
  7. <dependency>
  8. <groupId>org.apache.logging.log4j</groupId>
  9. <artifactId>log4j-core</artifactId>
  10. <version>2.0-beta6</version>
  11. </dependency>
  12. </dependencies>


- Web.xml
<listener>
    <listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
</listener>
<context-param>
    <param-name>log4jConfigLocation</param-name>
    <param-value>/WEB-INF/config/log4j.properties</param-value>
</context-param>




log4j.properties
# Log4j Setting file
log4j.rootLogger=INFO, console, logfile

# Console log
log4j.appender.console=org.apache.log4j.ConsoleAppender
log4j.appender.console.layout=org.apache.log4j.PatternLayout
log4j.appender.console.layout.ConversionPattern=%-5p %l - %m%n

# Daily file log
log4j.appender.logfile=org.apache.log4j.DailyRollingFileAppender
log4j.appender.logfile.File=${catalina.home}/logs/changpd.log
log4j.appender.logfile.DatePattern='.'yyyy-MM-dd
log4j.appender.logfile.layout=org.apache.log4j.PatternLayout
log4j.appender.logfile.layout.ConversionPattern=[%d{HH:mm:ss}][%-5p](%F:%L) - %m%n

# log level and appender
log4j.logger.com.changpd=DEBUG, console
log4j.logger.com.changpd.Test=INFO, logfile
log4j는 위처럼 text형식말고도 xml형식으로도 사용가능하다.
log4j.xml로 검색하면 쉽게 찾을수 있음.

# Log4j Setting file
log4j.rootLogger=INFO, console
log4j 기본 설정이다.
기본적으로 INFO 수준 이상의 로그만 console을 통해 출력.

console에 대한 설정작업
# Console log
log4j.appender.console=org.apache.log4j.ConsoleAppender
log4j.appender.console.layout=org.apache.log4j.PatternLayout
log4j.appender.console.layout.ConversionPattern=%-5p %l - %m%n
마지막 아랫줄에서 사용하는 log4j 옵션의 설명은 아래와 같다.
 %p  debug, info, warn, error, fatal 등의 priority 가 출력된다.  
 %m  로그내용이 출력됩니다 
 %d  로깅 이벤트가 발생한 시간을 기록합니다.
     포맷은 %d{HH:mm:ss, SSS}, %d{yyyy MMM dd HH:mm:ss, SSS}같은 형태로 사용하며 
     SimpleDateFormat에 따른 포맷팅을 하면 된다 
 %t  로그이벤트가 발생된 쓰레드의 이름을 출력합니다.  
 %%  % 표시를 출력하기 위해 사용한다.  
 %n  플랫폼 종속적인 개행문자가 출력된다. \r\n 또는 \n 일것이다.  
 %c  카테고리를 표시합니다 
     예) 카테고리가 a.b.c 처럼 되어있다면 %c{2}는 b.c가 출력됩니다. 
 %C  클래스명을 포시합니다. 
     예)클래스구조가 org.apache.xyz.SomeClass 처럼 되어있다면 
     %C{2}는 xyz.SomeClass 가 출력됩니다 
 %F  로깅이 발생한 프로그램 파일명을 나타냅니다. 
 %l  로깅이 발생한 caller의 정보를 나타냅니다 
 %L  로깅이 발생한 caller의 라인수를 나타냅니다 
 %M  로깅이 발생한 method 이름을 나타냅니다. 
 %r  어플리케이션 시작 이후 부터 로깅이 발생한 시점의 시간(milliseconds) 
 %x  로깅이 발생한 thread와 관련된 NDC(nested diagnostic context)를 출력합니다. 
 %X  로깅이 발생한 thread와 관련된 MDC(mapped diagnostic context)를 출력합니다.


파일로그
# Daily file log
log4j.appender.logfile=org.apache.log4j.DailyRollingFileAppender
log4j.appender.logfile.File=${catalina.home}/logs/changpd.log
log4j.appender.logfile.DatePattern='.'yyyy-MM-dd
log4j.appender.logfile.layout=org.apache.log4j.PatternLayout
log4j.appender.logfile.layout.ConversionPattern=[%d{HH:mm:ss}][%-5p](%F:%L) - %m%n
로그는 appender에 의해 출력 방법이 결정된다. 위의 경우는 file로 출력하는 방법이고,
DailyRollingFileAppender는 일자별로 로그파일을 새로 맹그러 준다.
# log level and appender
log4j.logger.com.changpd=DEBUG, console
log4j.logger.com.changpd.Test=INFO, logfile
특정 클래스에서 log4j를 다른 수준의 다른 형식으로 출력할 수 있다.
log4j.logger.[class_name]
위를 예로들면 changpd 이하의 클래스에서 INFO 이상일경우
rootloger에 의해 한번
위의 설정에서 한번
중복되서 출력이 되게 된다. (debug<info)



sql 로그 출력 - http://changpd.blogspot.kr/2016/08/log4j-sql.html


log4j 공식 사이트 : http://logging.apache.org/
머드초보님블로그 : http://mudchobo.tistory.com/251
수갈단산하자폭단님 블로그:http://scblood.egloos.com/3279715

댓글

댓글 쓰기

이 블로그의 인기 게시물

메일서버가 스팸으로 취급받을때

설치한 메일서버를 통해 발송되는 메일이 스팸으로 들어가는 경우가 더러 있다. 이게 한번 들어가기는 쉬운데, 빠져나오기는 드럽게 힘든것 같다... 본인의 경우에는 우선 국내서비스에는 별 무리 없이 들어간다. (naver,daum 등) 그런데 해외메일 그중 Gmail, Hotmail 에는 에누리없이 스팸으로 간주되고 있었다. Gmail같은 경우에는 그래도 스팸함으로 발송은 제대로 되는반면에 Hotmail같은경우에는 아예 수신자체가 안되는 경우도 더러있다.. ㅡ,.ㅡ; 제일 좋은 방법은 Gmail,Hotmail에 전화걸어서 우리 메일서버 IP white Ip로 등록해달라!!! 하면 좋지만, 얘네들은 걸어봤자 자동응답기고, 문의채널은 구글 그룹스 게시판이 전부다.. 본론으로 들어가서. 해외 메일이 차단될 경우 내 매일서버ip가 스팸ip로 등록되 버린 경우일 수 있다. (본인처럼. ㅎ) 이것부터 조회 해보고 싶으면 RBL(real-time blocking List) 체크를 해야 하는데, RBL체크 해주는 사이트는 꽤 많이 있고, 그중 좀 깔끔해 보이는곳 하나 소개. http://www.anti-abuse.org/ 메일서버ip 입력하고 조회해보면 쭈루룩 리스트가 나온다. 그 중 빨간불이 들어온 부분이 메일 서버가 스팸서버가 된 각종 이유들이다.ㅋ 본인의 경우 CBL 때문에 걸렸는데, 내용은 아래와 같다. This IP address is HELO'ing as  "localhost.localdomain"  which violates the relevant standards (specifically: RFC5321). 메일서버 도메인에 별다른 작업을 안해놓아서 "localhost.localdomain" 으로 설정되어있었다. 만약 CBL만 바로 테스트 해보고 싶으면 http://cbl.abusea...

[javascript] 특정시간에만 함수 실행

특정시간에만 팝업을 띄우려면?? 특정시간에만 로그인을 막으려면?? 특정시간에만 할일은 의외로 참 많다. 방법? 딱히 없다. 현재시간 구해서 시작시간, 종료시간 사이에 있을때 시작하는 수밖엔. if ((현재시간 > 시작시간) && (현재시간 < 종료시간)){ .. 팝업노출(); 공사페이지 리다이렉트(); 기타등등(); .. } 자바스크립트로 작성하면 다음과 같다. var startdate = "2014012008" ; var enddate = "2014012418" ; var now = new Date (); //현재시간 year = now. getFullYear (); //현재시간 중 4자리 연도 month = now. getMonth () + 1 ; //현재시간 중 달. 달은 0부터 시작하기 때문에 +1 if ((month + "" ). length < 2 ){ month = "0" + month; //달의 숫자가 1자리면 앞에 0을 붙임. } date = now. getDate (); //현재 시간 중 날짜. if ((date + "" ). length < 2 ){ date = "0" + date; } hour = now. getHours (); //현재 시간 중 시간. if ((hour + "" ). length < 2 ){ hour = "0" + hour; } today = year + "" + month + "" + date + "" + hour; //오늘 날짜 완성. / / 시간비교 i...

(java) 크롬에서 쿠키 삭제 안되는 경우

  java에서 쿠키 삭제하는 방법은 똑같은 이름의 쿠키를 만들고 업데이트 하는 방식이다.  이때 maxAge를 '0' 으로 설정한다.  그래서 아래처럼 코딩한결과  크롬을 제외한 나머지 브라우저에서는 전부 쿠키가 삭제가 되었으나 크롬만 삭제가 되지 않았다.  문제의코드 Cookie cookie = new Cookie(name , null ) ; cookie.setHttpOnly( false ) ; cookie.setMaxAge( 0 ) ; cookie.setPath( "/" ) ; cookie.setDomain( "test.co.kr" ) ; 결론만 얘기하면  Secure 설정을 ture로 추가해서 해결했다.  https, ssl 기반에서만 주고받을 수 있게된다.  public void setSecure ( boolean flag) { secure = flag ; } /** * Returns <code> true </code> if the browser is sending cookies only over a * secure protocol, or <code> false </code> if the browser can send cookies * using any protocol. * * @return <code> true </code> if the browser uses a secure protocol; * otherwise, <code> true </code> * @see #setSecure */ 원인은 이사이트의 쿠키설정중 samesite가 'none' 으로 설정되어있었다.  samesite가 none인 경우에는 반드시 secure 옵션을 같이 넣어줘야 크롬에서 정상동작한다. (chrome 80 버전 업데이트 이슈) 웹서버에서 변경하고 싶으면 nginx.c...