달력

5

« 2024/5 »

  • 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
2010. 11. 11. 07:36

겪었던 오류(Already closed 오류) Study/WEB2010. 11. 11. 07:36

프로젝트를 완성하고 이제 운영서버 반영하여 최종적으로 사용자 베타 테스트 만 남았다.

3~4시간 주기로 java.sql.SQLException: Already closed. 라는 오류가 발생하면서 톰켓이 죽어버렸다.

톰켓을 재시작하면 다시 되기는 하지만 또 3~4시간 뒤에 저 오류가 발생하면서 죽었다.

알고 보니 DBCP를 사용하는데 이미 끊어진 connection을 애플리케이션이 이걸 사용하려다가

발생한 오류였다.

간단하게 해당 connection이 살아있는지 확인하면 된다.

<!-- Mysql (홈페이지 DB서버 연결 -->
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
<property name="driverClassName" value="com.mysql.jdbc.Driver" />
<property name="url" value="jdbc:mysql://localhost:3306/virus" />
<property name="username" value="manUser" />
<property name="password" value="********" />
<!-- connection이 살아 있는지 확인 -->
<property name="validationQuery" value="select 1" />
</bean>




:
Posted by 유쾌한순례자
2010. 11. 9. 23:01

finalizer의 사용을 피하자 Study/Java2010. 11. 9. 23:01

신속하게 실행된다는 보장이 없다. 예를 들어 finalizer에서 파일을 닫는 것은 심각한 실수이다. 열 수 있는 파일이 제한되어 있는 상황에서 파일이 언제 닫힐지 보장이 안되기 때문이다.

finalizer를 하는 동안 catch 되지 않은 예외가 발생하면 그 예외는 무시되고 그 객체의 finalizer는 종결된다. catch 되지 않은 예외가 발생하면 객체가 불완전한 상태일 수 있다. 그런 상황에서 다른 스레드가 그런 객체를 사용하려 한다면 예측할 수 없는 결과가 생길 수 있다. 일반적으로 catch 되지 않은 예외가 발생하면, 스레드 실행이 중단되고 스택 추적정보가 출력된다. 그러나 finalizer 내에서 발생하면 그런 예외가 무시되므로 경고조차도 출력되지 않는다.

:
Posted by 유쾌한순례자
홈페이지 서버가 자꾸 죽어버려서 확인.

확인결과 특정부분에서 계속 읽어지는 것을 확인하였고 소스를 보니

while(1){

      쿼리;
      continue;
}

개발일을 시작한지 일주일밖에 안되신분께서 이렇게 해놓으셨다.

개발자 PC에서 할때야 한명이서 보니깐 부하가 덜 걸려도

홈페이지에서는 약 평균접속자수가 4000명 정도 되는 홈페이지니까 말 다했다.

어쨌든 수정하고 설명하고 귀환.
:
Posted by 유쾌한순례자