>  기사  >  백엔드 개발  >  동시성 성능 테스트 apache nginx

동시성 성능 테스트 apache nginx

WBOY
WBOY원래의
2016-08-08 09:32:581037검색

동시성 성능 테스트
1 테스트 목적
Apache와 Nginx의 동시성 성능 테스트 결과를 바탕으로 동시성 모델의 각각의 장단점을 분석합니다.
성능 평가 항목에는 RPS(초당 처리되는 요청 수), CPU 사용량, 메모리 사용량, 최대 동시성 수 등이 포함됩니다.
Apache 및 Nginx 동시성 모델의 장점과 단점을 기반으로 적절한 동시성 모델 프레임워크를 선택합니다.
2 테스트 환경
1. 하드웨어 환경
서버: 인터 서버 Borad
8코어 CPU, 2G 메모리, 160G 하드 드라이브,
클라이언트 : 서버환경과 동일
2. 운영체제
운영 체제: Red Hat EnterPrise Kernel Linux 2.6.18
클라이언트: Red Hat EnterPrise Kernel Linux 2.6.9
3. 네트워크 토폴로지
서버와 클라이언트는 100M 네트워크 케이블을 통해 스위치에 연결됩니다
서버 IP 주소: 192.168.192.201
클라이언트 IP 주소: 192.168.192.200
3가지 테스트 방법
3.1 테스트 도구
Apache 2.2.10에는 도구 벤치가 함께 제공됩니다
웹벤치 1.5
3.2 테스트 단계 1. 장비 점검 및 설치
모든 시스템 장치가 손상되지 않고 사용 가능한지 확인하고 장치를 호스트에 연결하십시오.
2. 네트워크 연결 확인
서버와 클라이언트는 100M 네트워크 케이블을 사용하여 동일한 스위치에 연결됩니다
3. 운영체제 준비
Red Hat Enterprise 시작
마우스 드라이버 설치 및 네트워크 구성
4.
다운로드, 설치 및 구성 참고 부록
5. 아파치 테스트
아파치 실행
CD /usr/local/apache/bin
./apachectl -k 시작
테스트 아파치 서비스가 성공적으로 시작되었습니다
창 아래 방문: http://192.168.192.201/index.html
"작동합니다!" 테스트 페이지가 나타납니다
Apche 벤치 테스트 프로그램 실행
CD /usr/local/apache/bin
./ab -c 클라이언트 -n 요청 http://192.168.192.201/index.html
웹벤치 테스트 프로그램 실행
CD /usr/local/bin
webbench -c 클라이언트 -t 시간 ​​http://192.168.192.200/index.html
(클라이언트는 사용자 수, 요청은 동시성 수를 나타냅니다)
6. Nginx 테스트
nginx 실행
./nginx
테스트 nginx 서비스가 성공적으로 시작되었습니다
창 아래 방문: http://192.168.192.201/index.html
"nginx에 오신 것을 환영합니다!" 페이지가 나타납니다
결과의 비교 가능성을 테스트하려면 nignx 테스트 페이지를 덮도록 Apache 테스트 페이지 index.html을 복사하세요
Apche 벤치 테스트 프로그램 실행
CD /usr/local/apache/bin
./ab -c 클라이언트 -n 요청 http://192.168.192.201/index.html
webbech 테스트 프로그램 실행
CD /usr/local/bin
webbench -c 클라이언트 -t 시간 ​​http://192.168.192.200/index.html

7. 테스트 결과 기록
벤치 테스트 결과 기록: 테스트 소요 시간(테스트 시간, 단위: 초), 초당 요청 수(초당 처리되는 요청 수)
웹벤치 테스트 결과 기록: 속도(분당 처리되는 요청 수, 아파치 벤치와 일관성을 유지하기 위해 *30은 기록 시 초당 처리되는 요청 수로 환산), 실행 시간은 다음에 따라 지정됩니다. 작업 명령 -t, 기본값은 30초
CPU 사용량 확인 명령: top
메모리 사용량 명령: free
4 테스트 계획
Nginx 단일 스레드 테스트
Nginx 멀티 스레드 테스트
Apache 작업자 모드 테스트
Apache 프리포크 모드 테스트
5 데이터 요약
테스트 구성: Apache 구성 참조 7.4, Nginx 구성 참조 7.5
원본자료는 원본자료 xls를 참고해주세요
데이터를 요약하면 다음과 같습니다.
서버 클라이언트 RPS
Idle Free(중고) Idle Free(중고)
Nginx 단일 프로세스 79 102526K 82 185196K 20757
Nginx 다중 프로세스 81 395444K 85 177405K 20861
아파체 프리포크 38 154380K 75 178215K 30181
아파치 작업자 41 81506K 81 183166K 24669

6 테스트 결론

7 부록
7.1 웹벤치 설치
단계 운영
http://blog.s135.com/soft/linux/webbench/webbench-1.5.tar.gz
설치 패키지 wget을 다운로드하세요.tar zxvf webbench-1.5.tar.gz 압축 풀기
CD webbench-1.5 컴파일
만들다
설치 설치
7.2 아파치 설치
단계 동작 설명
설치 패키지 다운로드 http://www.apache.org에서 소프트웨어 패키지 httpd-2.2.10.tar.gz 다운로드 최신 안정 버전
tar xvzf httpd-2.2.10.tar.gz 압축 풀기
컴파일 옵션 ./configure --prefix=/usr/local/apache 설치 경로
--enable-module=shared 프로세스 간 공유 메모리
--enable-module=다시 쓰기
--enable-threads 스레드 지원(작업자 모드가 유효함)
--enable-shared=최대
--with-mpm=worker 작업자 모드 선택
--with-mpm=prefork 프리포크 모드 선택
--with-mpm=이벤트 I/O 다중화 지원
컴파일하기 설치 설치
7.3 Nginx 설치
단계 동작 설명
설치 패키지 다운로드 http://sysoev.ru/nginx/download.html에서 소프트웨어 패키지 nginx-0.7.24.tar.gz를 다운로드하십시오. 최신 안정 버전
tar xvzf ginx-0.7.24.tar.gz 압축 풀기
컴파일 ./configure --prefix=/usr/local/ 설치 경로
컴파일
설치 설치
7.4 아파치 구성
Apache 구성 명령:
CD /usr/local/apache/conf
vi http.conf

프리포크 모드의 매개변수 구성:
아파치 구성
프리포크 모드 --with-mpm=prefork
시스템 시작 시 생성되는 프로세스 수 StartServers 128 //Nginx와 비교 가능
활성 하위 프로세스 수 ServerLimit 50000
하위 프로세스의 수명 주기 동안 처리된 연결 수 MaxRequestsPerChild 0 // 0은 제한이 없음을 의미합니다.
최대 하위 프로세스 수 MaxClients 50000
청취 포트 Listen 80
타임아웃 타임아웃 300
keepAlive KeepAlive 켜기
Sendfile 활성화Sendfile on

작업자 모드 구성:
구성항목 구현
작업자 모드 --with-mpm=worker
시스템 시작 중 생성된 프로세스 수 StartServers 32
활성 하위 프로세스 수 ServerLimit 7812
최대 스레드 수 MaxClients 500000
하위 프로세스 스레드 수 ThreadsPerChild 64 //Apache에서 허용하는 최대값과 동일
청취 포트 Listen 80
타임아웃 타임아웃 300
keepAlive KeepAlive 켜기
Sendfile 활성화Sendfile on


7.5 Nginx 구성
Nginx 구성 명령:
CD /usr/local/nginx/conf
vi nginx.conf
Nginx 구성 명령 테스트:
./nginx –t


단일 작업자 프로세스의 주요 구성:
Nginx 구성
프로세스 작업자_프로세스 1;
프로세스 Worker_connections 102400;
에서 처리한 연결 수 수신 포트 서버 {
80 들어보세요;
}
Sendfile sendfile on;
I/O 다중화 방법은 epoll을 사용합니다.

다중 작업자 구성:
Nginx 구성
프로세스 작업자_프로세스 16;
프로세스 Worker_connections 102400;
에서 처리한 연결 수 수신 포트 서버 {
80 들어보세요;
}
Sendfile sendfile on;
I/O 다중화 방법은 epoll을 사용합니다.
위의 내용을 포함하여 동시 성능 테스트 apache nginx를 소개합니다. PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.

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