Background Image
응용개발
2009.07.01 08:38

JDBC 사용시 SQL 로깅 - p6spy 사용

조회 수 35998 추천 수 0 댓글 1
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

웹개발을 하다 보면 응용 프로그램에서 DB로 넘어가는 SQL을 보고 싶을때가 있다.

그에 대한 방법이 많지만 그 중 아주 간단한 tip을 공유 한다.

비슷한 SQL로깅 하는 라이브러리는 log4sql 이라는 오픈소스도 존재 한다.

홈페이지 : http://www.p6spy.com

설치 방법 :
TOMCAT 5.x + DBCP 사용시
1. http://jaist.dl.sourceforge.net/sourceforge/p6spy/p6spy-install.zip 에서 p6spy를 다운 받는다.

2. 다운 받은 zip파일의 압축 파일을 풀어서

TOMCAT_HOME/common/lib에 p6spy.jar를넣어둔다.
TOMCAT_HOME/common/classes/에 spy.properties 설정 파일을 넣어 둔다.

3.
<Resource name="jdbc/CUBRIDDS" auth="Container" type="javax.sql.DataSource"
   factory="org.apache.commons.dbcp.BasicDataSourceFactory"
   driverClassName="cubrid.jdbc.driver.CUBRIDDriver"
   url="jdbc:cubrid:localhost:33000:subway:::"
   username="" password=""
   maxActive="10"
   maxIdle="10"
   maxWait="-1"
   removeAbandoned="true"
   removeAbandonedTimeout="60"
   logAbandoned="true"/>

cubrid.jdbc.driver.CUBRIDDriver
부분을
com.p6spy.engine.spy.P6SpyDriver로 설정해주면 된다.

4. spy.properties 파일의 설정을 바꿔준다.
realdriver=cubrid.jdbc.driver.CUBRIDDriver

추가 정보
1. p6spy에는 로그 포맷을 여러 형태로 지정 할 수 있다.
#specifies the appender to use for logging
#appender=com.p6spy.engine.logging.appender.Log4jLogger
#appender=com.p6spy.engine.logging.appender.StdoutLogger
appender=com.p6spy.engine.logging.appender.FileLogger
#log4j.appender.CHAINSAW_CLIENT=org.apache.log4j.net.SocketAppender
#log4j.appender.CHAINSAW_CLIENT.RemoteHost=localhost
#log4j.appender.CHAINSAW_CLIENT.Port=4445
#log4j.appender.CHAINSAW_CLIENT.LocationInfo=true
log4j.logger.p6spy=INFO,STDOUT

2. p6spy에는 filter 기능이 존재 한다.
필터 기능을 이용하여 P6Spy는 사용자들로 하여금 특정 테이블, 특정 statement 타입들에 대하여 로깅 할 수 있게 한다.


filter = true
# comma separated list of tables to include
include = select
# comma separated list of tables to exclude
exclude = insert



List of Articles
번호 분류 제목 글쓴이 날짜 조회 수
99 질의작성 Integer 컬럼의 결과에 + or – 연산을 할 때 주의해야 할 점 웁쓰 2009.12.31 13493
98 질의작성 오라클 바이딩 변수와 큐브리드 인터프리터 변수를 사용한 경로 표현식 정만영 2009.06.09 13483
97 질의작성 function based index 대체 방법 남재우 2010.07.01 13420
96 운영관리 cubrid.conf파일 적용의 우선 순위와 HOST적용 우선 순위 cubebridge 2009.11.14 13369
95 응용개발 CUBRID에서 SQL힌트와 주석을 쓸 때 순서. cubebridge 2012.01.11 13323
94 질의작성 CUBRID 2008에서 ' 사용하기. file seongjoon 2009.06.16 13315
93 질의작성 CUBRID 2008에서의 class 정보를 확인하는 sql 쿼리문. seongjoon 2009.06.30 13288
92 마이그레이션 MySQL에서 사용하는 스키마 변환시 주의 사항 정만영 2012.03.02 13256
91 운영관리 csql 인터프리터를 통해 쿼리 수행시간을 확인하는 방법. file seongjoon 2009.06.30 13195
90 운영관리 TIME_TO_KILL과 SESSION_TIMEOUT에 대한 정리 cubebridge 2009.05.27 13191
89 운영관리 insert 질의로 16K 이상 데이터 입력 시 오류 문제와 해결방법 정만영 2010.07.01 13184
88 CUBRID 매니저 질의편집기 사용시 주의할 점 남재우 2010.01.01 13112
87 CUBRID 매니저 한 개 PC에서 CUBRID7.3과 CUBRID2008R1.4 & R2.0 매니저 사용 방법 1 정만영 2009.12.12 13054
86 운영관리 cubrid_service.exe 가 CPU 를 지속적으로 일정부분 점유하는 경우 남재우 2010.01.01 13030
85 기타 EVALUATE method 수행시 주의해야 할 점 웁쓰 2009.12.31 12875
84 운영관리 자동 백업, 매니져 관리자 암호 등의 설정에 대하여 CUBRID 배포판을 만들어 동일하게 배포하고자 할때 남재우 2009.12.16 12826
83 운영관리 큐브리드 복제 구성 시 마스터 데이터베이스 백업 주의사항 정만영 2010.02.11 12591
82 운영관리 CUBRID에서의 출력 메시지 한글로 변경 방법. file seongjoon 2010.03.01 12440
81 운영관리 CUBRID 4.0 서버 재부팅 후 CUBRID Tray 기동문제 해결방법 정만영 2011.08.31 12419
80 운영관리 CUBRID에서 데이터가 있는 칼럼의 도메인 변경 시 조치방법 cubebridge 2009.11.16 12409
Board Pagination Prev 1 ... 5 6 7 8 9 10 11 12 13 14 Next
/ 14

Contact Cubrid

대표전화 070-4077-2110 / 기술문의 070-4077-2113 / 영업문의 070-4077-2112 / Email. contact_at_cubrid.com
Contact Sales