1. JBoss EAP 6 개요
JBoss EAP 6는 개방형 표준을 기반으로 개발된 오픈소스 미들웨어 플랫폼으로 Java EE 6 인증을 받은 제품이다. 엔터프라이즈 환경에서 미들웨어가 갖추어야 하는 대용량 트랜잭션, 고가용성을 위한 클러스터링, 메시징, 분산 캐싱, 고성능 보장 등의 기술들을 제공한다.
2. JBoss EAP 6의 주요 특징
2-1. 모듈형 클래스 로딩
기존에 사용하던 계층형 클래스 로더를 사용하는 경우에는 부모와 자식 클래스 로더 간에 동일한 클래스의충돌로 인하여 개발자나 관리자에게 많은 어려움이 있었고, 이를 해결하기 위해 많은 시간을 소모하였다.
JBoss EAP 6에서 사용하는 JBoss Modules은 배포된 모듈마다 검색 범위가 한정되고 그 내부에서도 패키지마다 인덱스되어 있어 신속하게 클래스를 로드할 수 있으며, JBoss Modules을 통해 의존성을 사용하여 애플리케이션에서 사용하는 클래스와의 충돌을 회피할 수 있게 된다.
또한, 애플리케이션이 요청할 때 클래스를 병렬로 빠르게 로드할 수 있는 장점이 있다.
2-2. 효율적인 메모리 사용
JBoss EAP6 에서는 GC 정지 시간을 최소화하기 위해 jar 파일에 대한 색인 데이터를 사용하는 방법이나, 모든 클래스를 로딩해 놓는 것이 아니라 애플리케이션에서 사용하는 시점에 로드하는 방법 등 메모리를 효율적으로 사용하기 위한 많은 개선점이 생겼다.
이런 방식을 사용하여 메모리 사용량이 크게 줄었으며, 최적화된 메모리 사용으로 소형 디바이스나 아마존 AWS와 같은 클라우드 환경에서 사용이 쉬워졌다. 또, Profile을 정의하여 애플리케이션에서 사용하지 않는 기능(mail, messaging 등)을 손쉽게 제거할 수 있어 최적화된 상태로 서버를 운영할 수 있다.
2-3. 인덱스를 이용한 성능 향상
Web Application Server에 애플리케이션 배포 시 XML과 어노테이션 클래스를 리플렉션으로 스캔하는 것은 리소스에 많은 부담을 준다. 이러한 문제를 개선하기 위해 JBoss EAP 6에서는 클래스 인덱스 및 주석 인덱스를 이용하여 클래스 정보를 얻을 수 있으며 한 번 로드 된 클래스 정보는 캐시되어 실제로 호출되는 횟수를 최소호한다. JBoss EAP 6에서 애플리케이션 배포와 관련된 부분들은 jar 파일 내의 클래스들에 대한 인덱스를 만들어 두었다가 사용하기 때문에 클래스를 스캔할 때 발생하는 병목 문제를 해결할 수 있다.
2-4. 중앙 집중화된 설정 파일과 편리한 관리 도구
기존에 JBoss EAP 5 이하 제품에서는 설정 파일을 서비스마다 XML 파일러 여러 디렉토리에 나누어 관리하여 설정 파일을 수정하는데 많은 불편함이 있었다. JBoss EAP 6에서는 중앙 집중화된 파일을 사용하여 서비스(AJP, Clustering, Data-Source 등)을 관리하기 때문에 편리하게 관리할 수 있다.
2-5. CLI를 통한 커맨드 형식의 관리
JBoss EAP 6에서는 이전 버전에 비해 사용자가 쉽게 사용할 수 있는 웹 관리 콘솔과 정교한 관리가 가능한 CLI 스크립트 및 외부 애플리케이션과 인터페이스를 위한 REST API, Java API, HTTP API를 사용하여 설정에 대한 유지보수 및 관리가 가능하다. 또, 변경된 설정에 대한 버전 관리를 지원하기 때문에 구성 파일의 변경내역을 수작업으로 관리해야하는 작업들이 많이 줄게 되었다.
2-6. Standalone Mode & Domain Mode
JBoss EAP 6에는 웹 서비스의 요구사항에 맞게 이용할 수 있는 Standalone Mode와 Domain Mode 운영 방식을 제공한다. Standalone Mode는 서버 인스턴스마다 개별 관리 기능을 제공하는 방식이고, Domain Mode는 여러 개의 서버 인스턴스를 그룹으로 묶에 관리하는 방식이어서 설정 변경이나 애플리케이션 배포를 중앙에서 한번에 관리할 수 있다.
두개의 운영 방식에는 단지 관리 모델의 차이가 있을 뿐이며, 제공되는 서브시스템은 거의 같이 때문에 기능의 차이는 없다. Standalone Mode의 경우 서버 인스턴스 구성 방법이 매우 간단하여 개발 환경이나 소규모 시스템 영역에 많이 활용되며, Domain Mode의 경우 많은 머신 및 인스턴스를 사용하여 규모가 큰 서비스를 할 경우, 체계적인 환경을 제공하여 손쉽게 여러 개의 인스턴스를 관리할 수 있는 장점이 있다.
■ Standalone Mode
인스턴스를 개별적으로 관리할 수 있으며 서버 별로 개별 프로세스를 제공하는 방식이다. 별도의 관리 프로세스가 없으며, 여러 개의 독립적인 프로세스를 대상으로 HA 클러스터링을 통해 묶어서 사용이 가능하다.
■ Domain Mode
도메인 컨트롤러라고 불리는 프로세스가 전체 도메인 관리를 담당하며 각 머신 상에서 동작하는 호스트 컨트롤러에서 실제 서비스를 담당하는 서버 인스턴스를 관리(설정, 배포, 라이프싸이클 등)한다.
'study > java' 카테고리의 다른 글
maven 설치 및 eclipse 연동 (0) | 2022.04.07 |
---|---|
[Eclipse] 이클립스 maven repository 경로 설정 (settings.xml) (0) | 2022.04.07 |
Tomcat, JBoss 차이 (0) | 2022.01.07 |
[Spring] *.do 설정하기 (0) | 2022.01.06 |
Tomcat : 개인키 및 SSL 인증서 적용 (0) | 2022.01.06 |