apache 컴파일시 동시 접속자 제한 변경하기

by 조쉬 posted Mar 26, 2014
?

단축키

Prev이전 문서

Next다음 문서

ESC닫기

크게 작게 위로 아래로 댓글로 가기 인쇄

아파치 동접자 제어



  • worker MPM은 여러 자식 프로세스가 각각 여러 쓰레드를 사용한다. 각 쓰레드는 한번에 한 연결을 담당한다. 일반적으로 worker는 prefork MPM 보다 적은 메모리를 사용하므로 통신량이 많은 서버에 적절하다.
    즉 동접자의 계산은 기본 프로세스가 16이고 Thread가 64일 경우

    16 * 64 = 1024(동접자)



    - 1.x.x 버전에서는 어디서 하는지 모르겠음



    - 2.x.x 버전일 경우

    아파치소스 2.x.x/server/mpm/worker/worker.c 에 있는

    #define DEFAULT_SERVER_LIMIT 16

    #define DEFAULT_THREAD_LIMIT 16

    여기서 16 -> 64로 하면 동접자 1024까지가 가능하다.

    위와 같이 소스 수정후 컴파일을 하고 나서 다시

    아파치설치폴더/conf/httpd.conf 의

    <IfModule worker.c>
    StartServers 2
    MaxClients 150
    MinSpareThreads 25
    MaxSpareThreads 75
    ThreadsPerChild 25
    MaxRequestsPerChild 0
    </IfModule>

    Max Clients 라고 씌여진 비슷한 부분을 1024로 바꾸고

    ThreadsPerChild 역시 64로 바꾸어 주면 되겠죠?

    아닌가? 아니면 말구









  • prefork MPM은 쓰레드가 한개인 자식 프로세스를 여러개 사용한다. 각 프로세스는 한번에 한 연결을 담당한다. 여러 시스템에서 prefork의 속도는 worker와 비슷하지만, 더 많은 메모리를 사용한다. 다음과 같은 상황에서 쓰레드를 사용하지 않는 prefork 방식이 worker에 비해 이점을 가진다: 쓰레드에 안전하지 (thread-safe) 않은 제삼자가 만든 모듈을 사용할 수 있고, 쓰레드 디버깅 지원이 빈약한 플래폼에서 쉽게 디버깅할 수 있다.


    - 1.x.x 버전일 경우

    아파치소스 1.x.x/src/include/httpd.h 에 있는

    #define HARD_SERVER_LIMIT 256

    여기서 256 -> 1024로 하면 동접자 1024까지가 가능하다.

    위와 같이 소스 수정후 컴파일을 하고 나서 다시

    아파치설치폴더/conf/httpd.conf 의

    Max Clients 라고 씌여진 비슷한 부분을 1024로 바꾸면 된다.



    - 2.x.x 버전일 경우

    아파치소스 2.x.x/server/mpm/prefork/prefork.c 에 있는

    #define DEFAULT_SERVER_LIMIT 256

    여기서 256 -> 1024로 하면 동접자 1024까지가 가능하다.

    위와 같이 소스 수정후 컴파일을 하고 나서 다시

    아파치설치폴더/conf/httpd.conf 의

    <IfModule prefork.c>
    StartServers 5
    MinSpareServers 5
    MaxSpareServers 10
    MaxClients 150
    MaxRequestsPerChild 0
    </IfModule>

    Max Clients 라고 씌여진 비슷한 부분을 1024로 바꾸면 된다.