728x90
반응형
728x90
반응형

안녕하세요.

톰캣 캐시 부족 현상 해결하기에 대해 알아보겠습니다.

저의 증상은 이미 실행 중인 서비스내 로그가 많이 쌓이는 현상이었습니다.

  • 로그
27-Oct-2022 18:39:59.062 INFO [ContainerBackgroundProcessor[StandardEngine[Catalina]]] org.apache.catalina.webresources.Cache.backgroundProcess The background cache eviction process was unable to free [10] percent of the cache for Context [/tomcat/repository] - consider increasing the maximum size of the cache. After eviction approximately [17,482] KB of data remained in the cache.
27-Oct-2022 18:40:09.063 INFO [ContainerBackgroundProcessor[StandardEngine[Catalina]]] org.apache.catalina.webresources.Cache.backgroundProcess The background cache eviction process was unable to free [10] percent of the cache for Context [/tomcat/repository] - consider increasing the maximum size of the cache. After eviction approximately [17,482] KB of data remained in the cache.

로그가 10초마다 쌓이는 현상이었으며 저는 단순 재기동으로 증상이 해결되었습니다.

구글링 해보니 서비스 시작시 로그가 발생한 경우 톰캣 context.xml파일에 아래 설정값을 추가해주면 된다고 하니 참고해주면 될 것 같습니다.

파일위치 : /톰캣설치경로/conf/context.xml

<Resources cachingAllowed="true" cacheMaxSize="100000"/>

 

728x90
반응형
728x90
반응형

프로그램을 개발하다 보면 자바 OOME(OutOfMemory)를 겪어 본적이 있을 것 같은데요.

OOME(Out Of Memory Error)는 JVM의 메모리가 부족하여 발생한 에러 입니다.

OOME는 자바의 일반적은 오류와 달리 대응이 쉽지가 않습니다.

오류를 해결하기 위해 JVM Option으로 덤프 파일을 생성한 후 덤프 파일을 분석하여 해결을 해야 합니다.

짧은 시간으로 오류를 찾기는 쉽지 않습니다.

그래서 OOME발생시 JVM옵션을 이용하여 톰캣 자동으로 시작할 수 있는데요.

JVM의 OnOutOfMemoryError 옵션을 사용하여 OutOfMemroy 발생 이후에 특정 동작을 지정하면 됩니다.

 

1) 톰캣의 catalina.sh 실헹

 : CATALINA_OPTS의 아래 옵션을 추가합니다.

CATALINA_OPTS="-Djava.awt.headless=true -server -Xms2048m -Xm2048m -XX:MaxPermSize=256m -XX:+HeapDumpOnOutOfMemoryError -XX:OnOutOfMemoryError=/app/serviceRestart.sh

 

2) 재시작 쉘 스크립트 생성

#!/bin/sh
 
export JAVA_HOME=/usr/local/java
export PATH="$PATH:$JAVA_HOME/bin"
export CATALINA_HOME=/usr/local/tomcat8
 
 
# 톰캣 서비스 다운
/app/tomcat8/bin/shutdown.sh
#시간은 서비스 기동 시간에 따라 조절.
sleep 60

# 톰캣 서비스 시작
/app/tomcat7/bin/startup.sh

shutdwon.sh로 서비스가 중단이 안되는 경우 force 옵션을 추가하면 강제로 중지할 수 있습니다.

 

 

 

728x90
반응형
728x90
반응형

톰캣 로그파일인 catalina.out 로그 초기화하는 방법에 대해 알아보겠습니다.

로그 파일을 초기화하는 이유는 용량 때문이죠.

로그 파일로 인해 디스크가 풀이 난다면 서비스 다운의 사유가 될 수 있습니다.

카탈리나 로그 초기화하는 방법에 대해 알아보겠습니다.

 

리눅스의 경우 크론 파일 등록하여 매일 12시에 로그를 삭제하도록 하는 명령어입니다.

 

1. 카탈리나 로그 초기화 명령어

cat /dev/null > /톰캣위치/apache-tomcat-xxx/logs/catalina.out

 

2. 쉘 파일 생성

 초기화 명령어 입력후 아래와 같이 쉘 파일 생성.

 : 서비스명_catalina_log_init.sh 

 

3. 크론(Cron), 스케줄러 등록

 : 0 1 * * * /생성한 쉘파일 위치/서비스명_catalina_log_init.sh  

 -> 매일 12시에 초기화를 하겠다는 크론 명령어

 

4. 등록된 크론 확인

  : crontab -l

단순 카탈리나 로그파일만 초기화 하고 싶다면 

2,3,4번은 생략하고 톰캣위치로 이동하여 해당 명령어를 입력하면 됩니다.

cat /dev/null > /톰캣위치/apache-tomcat-xxx/logs/catalina.out

728x90
반응형
728x90
반응형

대부분 아파치 톰캣을 이용해서 웹 서버를 띄우고 개발을 진행을 합니다.

아파치와 톰캣이 무엇인지 알기 위해서 WEB과 WAS에 대해서 알아야합니다.

 

WEB Server HTML 문서같은 정적 컨텐츠를 처리하는 것입니다. (HTTP 프로토콜을 통해 읽힐 수 있는 문서)

클라이언트가 GET, POST 등의 메소드를 이용해 요청 하면 프로그램이 결과를 돌려주는 기능을 합니다.

WAS Server asp, php, jsp 등 개발 언어를 읽고 처리하여 동적 컨텐츠, 웹 응용 프로그램 서비스를 처리하는 것입니다.

DB와 연결되어 데이터를 주고 받거나 프로그램으로 데이터 조작이 필요한 경우 사용합니다.

apache web server(html) 이고

tomcat Servlet/JSP container = WAS(Web Application Server)

아파치는 jsp처리를 못하기 때문에 jsp를 받아서 톰캣에서 처리하고 다시 아파치로 넘겨주는 작업을 합니다.


웹 컨테이너란 웹 서버에서 JSP를 요청해 톰캣에서 JSP파일을  서블릿으로 변환하여 컴파일하여 서블릿의 결과를 웹서버의 전달하는 것입니다.


출처 : http://gap85.tistory.com/45


*정적 컨텐츠와 동적 컨텐츠의 차이

 

 장점

단점 

 정적 컨텐츠

 *요청에 의한 파일만 전송하면 되기 때문에 속도가 빠르다. 

 *비용이 적다.

 *저장된 정보만 보여 줄 수 있기 때문에 서비스가 제한적이다.

 *관리가 힘들다.

 동적 컨텐츠

 *데이터의 조작이 가능하기 때문에 서비스가 다양하다.

 *관리가 쉽다.

 *정적 컨텐츠에 비해 속도가 느리다.

 *WAS서버가 필요하기 때문에 추가적인 비용이 든다.


출처: http://titus94.tistory.com/4

728x90
반응형

'프로그래밍 > Web' 카테고리의 다른 글

아파치 버전 확인하는 방법  (0) 2022.10.21
HTTP란 무엇인가??  (0) 2017.12.15
JSP 처리과정!!  (0) 2017.11.30
서버와 클라이언트 생활코딩 강의  (0) 2017.07.14
728x90
반응형

+ Recent posts