php教程 PHP开发 Apache 성능 최적화 (4)

Apache 성능 최적화 (4)

Dec 21, 2016 am 11:26 AM

다음은 prefork의 기본 구성 섹션입니다.

StartServers 5 //

MinSpareServers 5 // 유휴 프로세스의 최소 개수가 설정됩니다.

MaxSpareServers 10 //유휴 프로세스의 최대 수를 설정합니다. 유휴 프로세스 수가 이 값보다 크면 Apache는 일부 중복 프로세스를 자동으로 종료합니다. 이 값을 너무 크게 설정하지 마십시오. 값이 MinSpareServers보다 작은 경우 Apache는 자동으로 MinSpareServers+1로 조정합니다. 사이트 로드가 많은 경우 MinSpareServers와 MaxSpareServers를 모두 늘리는 것이 좋습니다.

MaxClients 150 // MaxClients는 이 명령 중 가장 중요한 명령으로 Apache가 동시에 처리할 수 있는 요청을 설정하며 Apache 성능에 가장 큰 영향을 미치는 매개변수입니다. 기본값인 150은 충분하지 않습니다. 총 요청 수가 이 값에 도달하면(ps -ef|grep http|wc -l로 확인할 수 있음) 처리된 요청이 완료될 때까지 후속 요청이 대기됩니다. . 시스템 자원은 많이 남았으나 HTTP 접속이 매우 느린 주된 이유가 바로 이것이다. 시스템 관리자는 하드웨어 구성 및 로드 조건에 따라 이 값을 동적으로 조정할 수 있습니다. 이론적으로 이 값이 클수록 처리할 수 있는 요청이 많아지지만 Apache의 기본 제한은 256(2.0의 #define DEFAULT_SERVER_LIMIT 256에서 파생됨)보다 클 수 없습니다. 이 값을 256보다 크게 설정하면 Apache가 시작되지 않습니다. 실제로 256은 부하가 약간 더 높은 사이트에는 충분하지 않습니다. Apache 1.3에서는 이는 엄격한 제한입니다. 이 값을 늘리려면 "configure" 이전에 수동으로 수정한 소스코드 트리 아래 src/include/httpd.h에서 256을 검색하면 "#define HARD_SERVER_LIMIT 256" 줄을 찾을 수 있습니다. 256을 늘리려는 값(예: 4000)으로 변경한 다음 Apache를 다시 컴파일하십시오. ServerLimit 지시문이 Apache 2.0에 새로 추가되었으므로 Apache를 다시 컴파일하지 않고도 MaxClients를 늘릴 수 있습니다. ServerLimit을 사용하는 경우 여기에 별도의 줄을 추가하면 됩니다. ServerLimit 값이 여기에 정의된 대로 20000을 초과하는 경우 server/mpm/prefork/prefork.c #define MAX_SERVER_LIMIT 20000을 수정해야 합니다. 20000을 더 큰 값으로 변경합니다.

MaxRequestsPerChild 0 //각 하위 프로세스가 처리할 수 있는 요청 수를 설정합니다. 각 하위 프로세스는 "MaxRequestsPerChild" 요청을 처리한 후 자동으로 삭제됩니다. 0은 무한함을 의미합니다. 즉, 하위 프로세스는 절대 파괴되지 않습니다. 기본 설정을 0으로 설정하면 각 하위 프로세스가 더 많은 요청을 처리할 수 있지만 0이 아닌 값으로 설정하면 두 가지 중요한 이점도 있습니다. 즉, 우발적인 메모리 누수를 방지할 수 있으며 서버 로드가 감소하면 자동으로 하위 프로세스 수가 줄어듭니다. . 숫자.

작업자의 작동 원리는 기본 제어 프로세스가 "StartServers" 하위 프로세스를 생성하고 각 프로세스는 하위 프로세스 고정된 수의 ThreadsPerChild 스레드가 포함되어 있으며 각 스레드는 요청을 독립적으로 처리합니다. 마찬가지로 요청이 들어올 때 스레드를 생성하지 않기 위해서입니다.

각 프로세스가 가질 수 있는 스레드 수는 고정되어 있습니다. 서버는 로드 조건에 따라 프로세스 수를 늘리거나 줄이도록 조정합니다. 단일 제어 프로세스는 하위 프로세스의 설정을 담당합니다. 각 하위 프로세스는 ThreadsPerChild에 지정된 고정된 개수의 스레드를 생성할 수 있습니다. 그런 다음 별도의 스레드가 들어오는 연결을 수신하고 처리합니다.

Apache는 항상 예비 또는 유휴 서비스 스레드 풀을 유지하려고 합니다. 이러한 방식으로 클라이언트는 스레드나 프로세스가 처리되기 전에 설정될 때까지 기다릴 필요가 없습니다. 처음 생성된 프로세스 수는 StartServers 지시어에 의해 결정됩니다. 이후 Apache는 모든 프로세스에서 유휴 스레드의 총 개수를 감지하고 MinSpareThreads 및 MaxSpareThreads에 지정된 범위 내에서 총 개수를 유지하도록 프로세스를 생성하거나 종료합니다. 이 프로세스는 자체 조정이므로 이러한 지침의 기본값을 수정할 필요가 거의 없습니다. 동시에 처리할 수 있는 최대 클라이언트 수는 MaxClients 지시어에 따라 달라지며, 설정된 최대 프로세스 수는 ServerLimit 지시어에 따라 달라집니다. ServerLimit에 ThreadsPerChild를 곱한 값은 MaxClients보다 크거나 같아야 합니다.

위 내용은 아파치 성능 최적화(4) 내용입니다. 더 많은 관련 내용은 PHP 중국어 홈페이지(www.php.cn)를 참고해주세요!


본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Apache에서 CGI 디렉토리를 설정하는 방법 Apache에서 CGI 디렉토리를 설정하는 방법 Apr 13, 2025 pm 01:18 PM

Apache에서 CGI 디렉토리를 설정하려면 다음 단계를 수행해야합니다. "CGI-BIN"과 같은 CGI 디렉토리를 작성하고 Apache 쓰기 권한을 부여하십시오. Apache 구성 파일에 "Scriptalias"지시록 블록을 추가하여 CGI 디렉토리를 "/cgi-bin"URL에 매핑하십시오. Apache를 다시 시작하십시오.

Apache80 포트가 점유 된 경우해야 할 일 Apache80 포트가 점유 된 경우해야 할 일 Apr 13, 2025 pm 01:24 PM

Apache 80 포트가 점유되면 솔루션은 다음과 같습니다. 포트를 차지하고 닫는 프로세스를 찾으십시오. 방화벽 설정을 확인하여 Apache가 차단되지 않았는지 확인하십시오. 위의 방법이 작동하지 않으면 Apache를 재구성하여 다른 포트를 사용하십시오. Apache 서비스를 다시 시작하십시오.

Apache의 데이터베이스에 연결하는 방법 Apache의 데이터베이스에 연결하는 방법 Apr 13, 2025 pm 01:03 PM

Apache는 데이터베이스에 연결하여 다음 단계가 필요합니다. 데이터베이스 드라이버 설치. 연결 풀을 만들려면 Web.xml 파일을 구성하십시오. JDBC 데이터 소스를 작성하고 연결 설정을 지정하십시오. JDBC API를 사용하여 Connections, 명세서 작성, 매개 변수 바인딩, 쿼리 또는 업데이트 실행 및 처리를 포함하여 Java 코드의 데이터베이스에 액세스하십시오.

아파치를 시작하는 방법 아파치를 시작하는 방법 Apr 13, 2025 pm 01:06 PM

Apache를 시작하는 단계는 다음과 같습니다. Apache 설치 (명령 : Sudo apt-get Apache2를 설치하거나 공식 웹 사이트에서 다운로드) 시작 apache (linux : sudo systemctl start : windes (선택 사항, Linux : Sudo SystemCtl

Apache 버전을 보는 방법 Apache 버전을 보는 방법 Apr 13, 2025 pm 01:15 PM

APACHE 서버에서 버전을 보는 3 가지 방법이 있습니다. 명령 줄 (APACHECTL -V 또는 APACHE2CTL -V)을 통해 서버 상태 페이지 (http : // & lt; 서버 IP 또는 도메인 이름 & gt;/server -status)를 확인하거나 APACHE 구성 파일 (ServerVersion : Apache/& lt; 버전 번호 & gt;).

Apache의 서버 이름 이상을 삭제하는 방법 Apache의 서버 이름 이상을 삭제하는 방법 Apr 13, 2025 pm 01:09 PM

Apache에서 추가 ServerName 지시문을 삭제하려면 다음 단계를 수행 할 수 있습니다. 추가 ServerName Directive를 식별하고 삭제하십시오. Apache를 다시 시작하여 변경 사항이 적용됩니다. 구성 파일을 확인하여 변경 사항을 확인하십시오. 서버를 테스트하여 문제가 해결되었는지 확인하십시오.

Apache의 Zend를 구성하는 방법 Apache의 Zend를 구성하는 방법 Apr 13, 2025 pm 12:57 PM

Apache에서 Zend를 구성하는 방법은 무엇입니까? Apache 웹 서버에서 Zend 프레임 워크를 구성하는 단계는 다음과 같습니다. Zend 프레임 워크를 설치하고 웹 서버 디렉토리로 추출하십시오. .htaccess 파일을 만듭니다. Zend 응용 프로그램 디렉토리를 작성하고 Index.php 파일을 추가하십시오. Zend 응용 프로그램 (application.ini)을 구성하십시오. Apache 웹 서버를 다시 시작하십시오.

Debian이 Hadoop 데이터 처리 속도를 향상시키는 방법 Debian이 Hadoop 데이터 처리 속도를 향상시키는 방법 Apr 13, 2025 am 11:54 AM

이 기사에서는 데비안 시스템에서 Hadoop 데이터 처리 효율성을 향상시키는 방법에 대해 설명합니다. 최적화 전략에는 하드웨어 업그레이드, 운영 체제 매개 변수 조정, Hadoop 구성 수정 및 효율적인 알고리즘 및 도구 사용이 포함됩니다. 1. 하드웨어 리소스 강화는 모든 노드에 일관된 하드웨어 구성, 특히 CPU, 메모리 및 네트워크 장비 성능에주의를 기울일 수 있도록합니다. 전반적인 처리 속도를 향상시키기 위해서는 고성능 하드웨어 구성 요소를 선택하는 것이 필수적입니다. 2. 운영 체제 조정 파일 설명 자 및 네트워크 연결 : /etc/security/limits.conf 파일을 수정하여 파일 설명자의 상한을 늘리고 동시에 시스템에 의해 열 수 있습니다. JVM 매개 변수 조정 : Hadoop-env.sh 파일에서 조정

See all articles