Apache MPM Module: Prefork, Worker, Event 3가지 방식 비교 및 Event Module 최적화 설정

Apache MPM Module은 Apache HTTP Server의 중요한 부분으로, 서버의 요청 처리 방식을 결정합니다. MPM(Multi-Processing Module)은 서버의 성능과 확장성에 큰 영향을 미치는 역할을 합니다.

✅ MPM Module(Multi-Processing Module)

MPM 모듈은 서버가 요청을 처리하는 방식을 정의하며, 서버의 성능, 안정성, 확장성에 영향을 미칩니다. 주요 MPM 모듈로는 Prefork, Worker, Event가 있습니다. 확장성과 성능이 중요한 사이트는 Worker MPM을 선택하는 것이 일반적이며, 안정성과 오래된 소프트웨어와의 호환성이 중요한 사이트는 Prefork MPM을 사용하는 것이 보편적입니다.

Apache 2.4.x Version부터 Event 방식의 MPM Module이 추가 되었으며 Event MPM은 Worker MPM과 유사한 다중 프로세스, 다중 스레드 방식을 사용하지만, 추가적으로 이벤트 기반 메커니즘을 통해 keep-alive 연결을 더욱 효율적으로 관리합니다.

Keep-alive 연결은 HTTP/1.1에서 도입된 기능으로, 클라이언트와 서버 간의 연결을 유지함으로써 여러 요청을 하나의 연결에서 처리할 수 있도록 합니다. 이를 통해 각 요청마다 새로운 연결을 설정하고 해제하는 오버헤드를 줄여 성능을 향상 시킬 수 있습니다.
~]# pwd
/etc/httpd/modules
[root@ip-172-26-6-43 modules]# ll mod_mpm_*
-rwxr-xr-x. 1 root root 77696 Apr  3 09:50 mod_mpm_event.so
-rwxr-xr-x. 1 root root 40384 Apr  3 09:50 mod_mpm_prefork.so
-rwxr-xr-x. 1 root root 52736 Apr  3 09:50 mod_mpm_worker.so

✅ Prefork, Worker, Event 비교표

✅ Apache Event Module 확인 및 최적화 설정

워드프레스와 같은 웹사이트를 관리할 때 블로그 중심의 웹 사이트라면, 블로그 포스트 작성, 댓글 기능, 최신 글 목록, 글 업데이트 시 카테고리 업데이트 등이 동적인 요소에 속하며, 포스트의 개별 페이지, 소개 페이지, 연락처 페이지 등 자주 변경되지 않는 페이지들을 정적인 요소로 볼 수 있습니다.

이미 작성된 포스트가 수정되지 않는다면 정적인 요소가 더 크게 작용할 수 있으며, 플러그인 및 테마 업데이트와 같은 동적인 요소 및 서버에 설치된 캐시 등을 고려해서 Module Module은 Event Module 설정을 결정하게 되었습니다.

🔲 Apache Module 확인

현재 사용하는 서버의 모듈 확인 시 기본 모듈이 Event인 것을 확인했습니다.

modules]# ll mod_mpm_*
-rwxr-xr-x. 1 root root 77696 Apr  3 09:50 mod_mpm_event.so
-rwxr-xr-x. 1 root root 40384 Apr  3 09:50 mod_mpm_prefork.so
-rwxr-xr-x. 1 root root 52736 Apr  3 09:50 mod_mpm_worker.so

modules]# httpd  -V | grep MPM
Server MPM:     event
modules]# vi /etc/httpd/conf.modules.d/00-mpm.conf
# Select the MPM module which should be used by uncommenting exactly
# one of the following LoadModule lines.  See the httpd.conf(5) man
# page for more information on changing the MPM.

# prefork MPM: Implements a non-threaded, pre-forking web server
# See: http://httpd.apache.org/docs/2.4/mod/prefork.html
#
# NOTE: If enabling prefork, the httpd_graceful_shutdown SELinux
# boolean should be enabled, to allow graceful stop/shutdown.
#
#LoadModule mpm_prefork_module modules/mod_mpm_prefork.so

# worker MPM: Multi-Processing Module implementing a hybrid
# multi-threaded multi-process web server
# See: http://httpd.apache.org/docs/2.4/mod/worker.html
#
#LoadModule mpm_worker_module modules/mod_mpm_worker.so

# event MPM: A variant of the worker MPM with the goal of consuming
# threads only for connections with active processing
# See: http://httpd.apache.org/docs/2.4/mod/event.html
#
LoadModule mpm_event_module modules/mod_mpm_event.so

🔲 Event Module 최적화 설정

###############################################
## MPM-Module Event 및KeepAlive 설정 ##
<IfModule mpm_event_module>
    StartServers             2
    MinSpareThreads         25
    MaxSpareThreads         75
    ThreadsPerChild         25
    MaxRequestWorkers      150
    MaxConnectionsPerChild   0
</IfModule>

# KeepAlive settings
KeepAlive On
MaxKeepAliveRequests 100
KeepAliveTimeout 5

# Timeout settings
Timeout 60
###############################################

🔲 Error_log에서 정상 작동하는지 확인해 보기

/var/log/httpd/error_log를 통해 정상 작동하는지 확인해 볼 수 있습니다.

[mpm_event:notice] [pid 728138:tid 728138] AH00492: caught SIGWINCH, shutting down gracefully
# Apache 서버가 SIGWINCH 신호를 받아 부드럽게 종료되었다는 것을 의미합니다. 이는 서버가 재시작 되었음을 의미 #
[Mon Aug 05 09:34:32.856097 2024] [suexec:notice] [pid 808397:tid 808397] AH01232: suEXEC mechanism enabled (wrapper: /usr/sbin/       suexec)
# suEXEC 메커니즘이 활성화되었음을 나타냅니다. suEXEC는 Apache에서 CGI 스크립트나 다른 실행 파일을 지정된 사용자 권한으로 실행하는 기능 #
[Mon Aug 05 09:34:32.887027 2024] [lbmethod_heartbeat:notice] [pid 808397:tid 808397] AH02282: No slotmem from mod_heartmonitor
# mod_heartmonitor 모듈에서 slotmem을 찾지 못했다는 경고입니다. 이는 로드 밸런싱 모듈과 관련된 메시지로, 실제로 문제가 되지 않는 경우가 대부분임 # 
[Mon Aug 05 09:34:32.893961 2024] [mpm_event:notice] [pid 808397:tid 808397] AH00489: Apache/2.4.57 (AlmaLinux) OpenSSL/3.0.7 co       nfigured -- resuming normal operations
# Apache 서버가 event MPM으로 구성되어 있으며, OpenSSL 3.0.7을 사용하고 있음을 나타냅니다. 서버가 정상적으로 작동을 시작했음을 의미함 # 

🔲 이전에 적용한 http2 모듈 작동 안됨.

예전 설정이 [Protocols h2 h2c http/1.1] 였는데 h2c 삭제 처리를 진행했습니다. 비보안 연결(HTTP)에서의 HTTP/2 연결이었는데 Apache 설정이 자동으로 보안 연결로 되도록 설정이 되어 있어 이 상태로 설정을 유지하는 걸로 마무리 했습니다.

# http2 module setting #
<IfModule http2_module>
ProtocolsHonorOrder On
Protocols h2 http/1.1
</IfModule>
리눅스(Linux)

Similar Posts

  • PHP-FPM이란 | PHP-FPM 설치 및 설정

    PHP-FPM을 시작하기 전에 CGI에 대해 알아야 합니다. CGI(Common Gateway Interface)는 웹 서버와 외부 프로그램 사이의 상호작용을 위한 표준 프로토콜이며, 웹 서버는 사용자 요청에 따라 동적으로 콘텐츠를 생성하거나 데이터를 처리할 수 있습니다. 요청이 들어올 때 마다 각각의 요청으로 CGI가 생성되게 되어 서버의 속도는 느려질 수 밖에 없습니다. CGI(Common Gateway Interface)의 업그레이드 버전으로 서버의 성능을…

  • 리눅스 file 명령어

    리눅스 file 명령어는 그 파일이 어떤 파일인지 확인하는데 사용되는 명령으로 파일의 파일 타입을 확인할 때 사용합니다. 확인할 수 있는 파일은 텍스트 파일(ASCII 텍스트), 바이너리 파일, 그림 파일 및 동영상 등입니다. 단순하게 파일의 확장자만 확인하는 것이 아닌 파일의 매직파일(usr/local/magic)의 내용을 참조하여 파일 종류를 표시해 줍니다. magic 파일은 특정 파일의 형식을 식별하기 위한 정보를 담고…

  • 리눅스 FirewallD 설치 및 데몬 설정

    리눅스 FirewallD는 iptables의 체인과 정책이라는 규칙 대신 Zone과 Service를 대신 사용합니다. Firewalld를 사용하는 이유는 iptables의 규칙이 복잡하기 때문에 iptables 대신 사용할 수 있도록 하기 위함입니다. 목차✅ MPM Module(Multi-Processing Module)✅ Prefork, Worker, Event 비교표✅ Apache Event Module 확인 및 최적화 설정🔲 Apache Module 확인🔲 Event Module 최적화 설정🔲 Error_log에서 정상 작동하는지 확인해 보기🔲 이전에…

  • [Linux] 리눅스 일반 사용자 root 권한 부여 방법

    리눅스 일반 사용자 root 권한 부여 방법입니다. ‘testid’라는 계정을 임시로 만들었습니다. 목차✅ MPM Module(Multi-Processing Module)✅ Prefork, Worker, Event 비교표✅ Apache Event Module 확인 및 최적화 설정🔲 Apache Module 확인🔲 Event Module 최적화 설정🔲 Error_log에서 정상 작동하는지 확인해 보기🔲 이전에 적용한 http2 모듈 작동 안됨.✅ 리눅스 일반 사용자 root 권한 부여하기 1. /etc/sudoers 2….

  • SSH 명령어: 옵션 및 사용 방법

    리눅스에서 SSH(Secure Shell)는 네트워크를 통해 다른 시스템에 안전하게 접속할 수 있도록 해주는 프로토콜입니다. SSH는 원격 서버와 클라이언트 간의 통신을 암호화하여 보안성을 높이며, 주로 원격 접속, 파일 전송, 그리고 터널링 기능을 제공합니다. SSH 명령어를 사용하여 사용자는 원격 서버에 안전하게 접속한 뒤 다양한 작업을 수행할 수 있습니다. 터널링 기능: 한 네트워크에서 다른 네트워크로 데이터를 안전하게…

  • 리눅스 데몬이란? 독립형(Standalone) 방식과 슈퍼데몬 방식(xinetd)

    리눅스 데몬(Daemon)이란 사용자가 직접 제어하지 않고 백그라운드에서 실행되는 여러 작업을 하는 프로그램을 뜻 합니다. 뒤에 ‘d’로 끝나며 보통 프로세스로 실행됩니다. 목차✅ MPM Module(Multi-Processing Module)✅ Prefork, Worker, Event 비교표✅ Apache Event Module 확인 및 최적화 설정🔲 Apache Module 확인🔲 Event Module 최적화 설정🔲 Error_log에서 정상 작동하는지 확인해 보기🔲 이전에 적용한 http2 모듈 작동 안됨.✅…

답글 남기기

이메일 주소는 공개되지 않습니다. 필수 필드는 *로 표시됩니다

Prove your humanity: 5   +   9   =