Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- Data Transfer Object(DTO)
- Tomcat error-page version
- open cursors
- maven #junit
- 소프트웨어설계
- 실해하지 않는
- angular 6
- SI와 SM 차이점
- 경력개발자
- 객체설계
- EXK
- 자바스크립트 JQuery
- 네트워크 기본개념
- ASUS 공유기
- CBD 단점
- SW설계
- 구글캘린더 검색
- 자바튜닝
- LG그램2017
- USB-C충전
- 자바개발
- tvheadend
- SW분석
- Value Object(VO)
- 프로젝트관리
- SpringBoot
- USB-C to HDMI 아답터
- sonoff
- docker 네트워크
- LAN WAN
Archives
- Today
- Total
대빵's Blog
ORA-01000: maximum open cursors exceeded 관련 버그처리 본문
정확한 원인은 알 수 없지만 엑셀 대량(1000건 미만)으로 업로드 하는 기능에서 아래와 같은 오라클 에러가 발생함
ORA-01000: maximum open cursors exceeded
인터넷 검색해 보니 대부분 프로그램에서 정상적으로 리소스를 정리 하지 않아 발생하는 에러라는 의견
오라클 커서는 JDBC preparedStatement 와 연관된 설정인 듯함
약 이틀간의 삽질 끝에 해결함
서버환경
Spring 3, Mybatis 3.1.1, JDK 1.7, Tomcat 8.5, CentOS
- 원래 초기 구성은 Tomcat 의 Connection Pool 이 Commons DBCP 1.x 이었음
- DBCP 1.x 를 org.apache.tomcat.jdbc.pool 로 변경함
참고 : https://tomcat.apache.org/tomcat-8.5-doc/jdbc-pool.html#org.apache.tomcat.jdbc.pool.JdbcInterceptor
- 문제는 Connection Pool 을 tomcat jdbc pool 로 바꾸면 오라클에서 cursor 누수가 발생함.
- DBCP 1.x 로 변경하면 cursor 누수가 발생안함.
- 현재 시점에서 DBCP 1.x 은 아닌것 같고 원래의 DBCP 2.x 를 테스트 해보니 cursor 누수가 발생안함.
- 결론 tomcat jdbc pool 에서 누수가 발생함. 누수의 원인이 jdbc pool 자체적인 버그인지 mybatis 와 tomcat jdbc pool 간의 궁합이 안맞는 건지 알수 없지만 DBCP 2.x 에서는 누수가 발생되지 않는 것으로 보임
'개발관련' 카테고리의 다른 글
SI 와 SM 의 차이점(진격의 거인을 보고....) (0) | 2018.01.13 |
---|---|
프린터공유하기(LAN과 WAN 의 차이점) (0) | 2018.01.13 |
톰캣 에러페이지 버전 삭제-delete version in tomcat default error page (0) | 2017.10.26 |
[도서리뷰]모던 웹을 위한 JavaScript + jQuery 입문(3판) (0) | 2017.06.16 |
Spring Controller 의 View Return redirect 처리 (0) | 2017.04.07 |