Apache: 30개의 글
운영중인 톰캣이 OutOfMemory를 뱉어내고 작동을 안하는 경우가 있다. 관제 시스템이 잘 갖춰진 운영 환경이라면, 담당자에게 바로 알림이 가고 특정 시간내에 처리가 가능하겠지만,그렇지 않은경우에는 의도치 않게 장애가 길어지게 된다. OutOfMemory가 발생된 후 톰캣이 실행중인데 작동 불능에 빠졌을경우 누군가 조치를 취해주지 않거나 톰캣 상태를 모니터링해주는 자동화된 도구가 없다면 어떻게 해야할까? 이럴때는 JVM 옵션을 이용하여 후속 조치가 가능하다. OnOutOfMemoryError 옵션을 이용할 경우 OutOfMemroy 발생 이후에 특정 동작을 지정할 수 있다. 톰캣 catalina.sh 파일의 CATALINA_OPTS 옵션에 "-XX:+HeapDumpOnOutOfMemoryError -..
서버를 운영하다보면 장애 대응을 위하여 여러가지 대비책을 세우게 되는데,Tomcat을 사용하는 곳에서 많이 이용하는것중 하나가 톰캣을 자동으로 시작 시킬수 있는 shell Script가 아닐까 싶다. 아래 스크립트는 톰캣의 PID와 개수를 확인하여 톰캣이 실행중이지 않을때 톰캣을 자동으로 시작시켜주는 쉘 스크립트 이다. * 주의 : 서버에 톰캣 1개만 설치되어 있다는 가정하에 작성 --------------------------------------------------------------------------------------------------------#!/bin/sh export JAVA_HOME=/usr/local/javaexport PATH="$PATH:$JAVA_HOME/bin"exp..
Tomcat에서는 특정 IP의 접근을 제한하거나, 허용할 수 있는 옵션을 제공한다. 물론 웹 서비스내에서 인터셉터 또는 필터링 등을 이용하여 IP를 체크한 뒤 걸러낼수는 있지만, 접근을 제한하는 IP등이 명확하다면 서비스단이 아닌 Tomcat 내부 설정에서 컨트롤 하는것이 운영하기에 더 편할때가 있다. Tomcat 내에서 IP를 허용/제한하는 방법은 Tomcat의 설정파일인 server.xml에서 .. 사이에 다음과 같은 내용을 추가하고 재시작 하면된다. [IP 허용] [IP 거부] 이밖에 Tomcat의 valve 컴포넌트에서는 다양한 옵션을 제공하는데, 추가로 정보가 더 필요한 사용자는 아래 URL 에서 확인이 가능하다. http://tomcat.apache.org/tomcat-7.0-doc/confi..
로컬환경으로 Tomcat을 이용하여 개발하다 보면 종종 세션이 끊길때가 있다. 물론 Tomcat 1개에 1개의 서비스만 올려서 사용중이라면 그럴일은 없겠지만, 여러 프로젝트를 여러개의 서비스에 올려서 개발할경우 종종 로그인이 끊어지는 경우가 있다. 여러개의 서비스 일지라도 1개의 서비스만 집중적으로 개발할 경우 그럴일은 없는데, 하루에 여러 프로젝트를 손대다보면 세션 끊김이 발생한다. 예를들어 로컬에서 개발시 A라는 프로젝트를 로그인을 한 후 B라는 프로젝트를 로그인 하면 A 프로젝트에서 로그인 했던 세션이 끊어진다. 해당 문제는 바로 JSessionID가 충돌하여 발생하는 문제라고 볼수 있다. JSessionID는 브라우저에서 로그인등을 통해 세션이나 쿠키등이 생성될경우 사용자의 고유정보를 갖고있는데,..
일반적으로 톰캣을 구동하고 종료하는 명령어는 $TOMCAT_HOME/bin/ 에 있는 startup.sh 와 shutdown.sh 이다. 그런데 리눅스 서버에서 톰캣을 운영하다 보면 종종 어이없는 일이 발생을 한다. 그중에 하나가 shutdown.sh 명령을 실행했음에도 불구하고 톰캣이 죽지 않는 상황이 발생할 때가 있다. 물론 이 경우 리눅스에서 PID를 확인 한 후에 kill -9 명령어를 통해 톰캣 프로세스를 종료시킬 수는 있으나 매번 이렇게 종료시키에는 귀찮음이 따른다. 이럴때는 CATALINA_PID를 이용하여 shutdown.sh에 force 옵션을 사용하면 된다. CATALINA_PID를 지정하게 되면 톰캣이 구동될때 프로세스ID를 해당 파일에 기록하게 되며, shutdown시 해당 PID를..
지난번에 리눅스 시스템내에서 심볼링 링크를 생성하고 삭제하는 방법을 포스팅한적이 있다. 오늘은 Apache 와 Tomcat에서 심볼링 링크를 일반 디렉토리와 동일하게 읽을수 있도록 설정하는 방법을 포스팅하겠다. Apache와 Tomcat은 기본 설정으로는 심볼릭 링크를 읽지 못한다. 이는 보안 측면으로 기본설정에서 막아둔 것인데 간단한 옵션 설정을 통해 설정변경이 가능하다. 1. Tomcat $TOMCAT_HOME/conf/server.xml 파일을 열어 Context 구문에 allowLinking="true" 를 지정해 주면 된다. 2. Apache2 $APACHE_HOME/conf/httpd.conf 파일을 열어 태그 밑에 Options FollowSymLinks 를 지정해주면 된다. Options ..
나같은 경우 로컬 개발환경이나 테스트 서버의 경우 수많은 프로젝트들이 존재한다. 운영환경도 아닌 개발 및 테스트 환경에서 프로젝트가 추가될때마다 톰캣을 추가하는것은 사실 불필요하다. 어차피 내부 개발인력과 테스터 인력들만이 접속해서 확인할텐데 그때마다 톰캣을 새로 추가하는것은 오히려 리소스 낭비이다. 그래서 나는 로컬이나 테스트서버의 경우 1개의 톰캣에 3~4가지의 서비스들(프로젝트들)을 올려서 사용한다. 톰캣에 여러 서비스를 올리는것은 간단하다. TOMCAT_HOME/conf/server.xml 에서 service 부분을 추가해 주면 된다. [server.xml] 이때 주의할점은 크게 다음과 같다. 1. Service Name 과 Engine Name은 서로 동일해야 한다 2. Connector por..
DBCP validationQuery 설정* 참고 사이트: http://linuxism.tistory.com/579 * 참고 사이트: Configuring the High Concurrency JDBC Connection Pool * 참고 사이트: DBCP 설정 정리 에러 메시지 일부분 - is longer than the server configured value of 'wait_timeout'. 원인 - 마지막으로 DB에 커넥션을 맺은후 사용이 없다 보니 데이터 베이스 커넥션이 끝겼다. 해결책 - 특정 시간마다 커넥션을 확인 하는 셋팅을 지정한다. 적용 코드 - MySQLvalidationQuery="select 1" - 오라클의 경우validationQuery="select 1 from dual" ..
tomcat dbcp를 이용하여 검색데이터 추출할 때, mysql 사용. mysql wait_timeout 설정(기본값 28800 , 8시간) 에 의해 커넥션이 연결된 이후 해당 커넥션의 close 없이 8시간이 지나면 해당 커넥션을 종료. ▶issue : 종료된 커넥션을 dbcp의 connection pool 에선 여전히 가지고 있는 상태. 이런 상황에서 DB 관련 프로그램이 호출되면 커넥션 관련 에러가 발생. ▶solution : java에서 DB를 사용하기 전에 해당 connection 이 정상적인지 검사를 하도록 하는 것. 이 옵션이 validationQuery. 와 같이 사용하면 된다. 오라클의 경우 : validationQuery="select 1 from dual" 출처 : blog.hoon..
DB Connection Pool을 사용하다가, 어쩌다가 가끔 커넥션이 끊겨 버리는 오류가 발생하기도 한다. 아래는 Jakarta Commons DBCP 커넥션 풀을 사용하면서 그런 현상이 발생했을 때의 대처 방법이다. 어떤 서버는 소켓이 열린상태로 장시간 아무런 데이터 이동없이 방치될경우 소켓을 강제로 닫아버리는 경우도 있습니다. 보름에 한 번정도 발생한다는 것은 아마도, 보름에 한 번 정도 아무 사용자도 없는 상태가 장시간 계속되었기 때문일 것으로 예상됩니다. DBCP를 사용하시는 것으로 보이는군요. 그렇다면 설정을 통해 손쉽게 해결할 수 있습니다. * DBCP 설정하기 참조 상세 설정은 DBCP를 어떻게 호출하느냐(Spring, 혹은 Tomcat DataSource 설정, 기타 등등)에 따라 전혀 ..