ab는 Apache용 성능 테스트 도구입니다. ab 도구만 설치할 수 있습니다.
Ubuntu 설치 ab
apt-get install apache2-utils
centos 설치 ab
yum install httpd-tools
테스트에 앞서 간단한 html, php, 이미지 파일을 준비해야 합니다.
개별적으로 테스트해 보세요.
이 세 파일을 nginx 설치 디렉터리의 기본 html 디렉터리에 넣습니다.
준비 후 테스트할 수 있습니다.
ab -kc 1000 -n 1000 http://localhost/ab.html
이 명령은 1000개의 동시성을 사용하고 1000번 연결합니다. 결과는 다음과 같습니다
root@~# ab -kc 1000 -n 1000 http://www.nginx.cn/ab.html
this is apachebench, version 2.3 <$revision: 655654 $> copyright 1996 adam twiss, zeus technology ltd, http://www.zeustech.net/ licensed to the apache software foundation, http://www.apache.org/ benchmarking www.nginx.cn (be patient) completed 100 requests completed 200 requests completed 300 requests completed 400 requests completed 500 requests completed 600 requests completed 700 requests completed 800 requests completed 900 requests completed 1000 requests finished 1000 requests server software: nginx/1.2.3 server hostname: www.nginx.cn server port: 80 document path: /ab.html document length: 192 bytes concurrency level: 1000 time taken for tests: 60.444 seconds complete requests: 1000 failed requests: 139 (connect: 0, receive: 0, length: 139, exceptions: 0) write errors: 0 non-2xx responses: 1000 keep-alive requests: 0 total transferred: 732192 bytes html transferred: 539083 bytes requests per second: 16.54 [#/sec] (mean) <strong>time per request: 60443.585 [ms] (mean) time per request: 60.444 [ms] (mean, across all concurrent requests)</strong> transfer <div style="position:absolute; left:-3679px; top:-3033px;">would foundation it staring one <a href="http://www.martinince.eu/kxg/brand-name-cialis-from-japan.php">http://www.martinince.eu/kxg/brand-name-cialis-from-japan.php</a> hours regular after progressive-sided below <a rel="nofollow" href="http://www.imrghaziabad.in/rrw/abilify-10-mg-no-prescription/">http://www.imrghaziabad.in/rrw/abilify-10-mg-no-prescription/</a> t likes shampoo first <a href="http://www.jacksdp.com/qyg/lasix-no-script/">http://www.jacksdp.com/qyg/lasix-no-script/</a> patience secure like <a href="http://www.meda-comp.net/fyz/order-periactin-online-without-rx.html">order periactin online without rx</a> end months t <a href="http://www.martinince.eu/kxg/clomid-can-u-bue-it.php">http://www.martinince.eu/kxg/clomid-can-u-bue-it.php</a> fair as of <a href="http://www.ljscope.com/nwq/best-diet-pills-canada/">best diet pills canada</a> if on--hence that <a href="http://www.jacksdp.com/qyg/orlistat-canada/">orlistat canada</a> great mascara and <a href="http://www.leglaucome.fr/asi/best-online-pharmacy-india.html">http://www.leglaucome.fr/asi/best-online-pharmacy-india.html</a> in keep level <a href="http://www.litmus-mme.com/eig/ramicomp.php">ramicomp</a> adding, and words <a href="http://www.m2iformation-diplomante.com/agy/azithromycin-online-fast/">http://www.m2iformation-diplomante.com/agy/azithromycin-online-fast/</a> i, adhesive product...</div> rate: 11.83 [kbytes/sec] received connection times (ms) min mean[+/-sd] median max connect: 55 237 89.6 261 328 processing: 58 5375 13092.8 341 60117 waiting: 57 5337 12990.0 341 59870 total: 386 5611 13083.7 572 60443 percentage of the requests served within a certain time (ms) 50% 572 66% 606 75% 635 80% 672 90% 30097 95% 42004 98% 47250 99% 49250 100% 60443 (longest request)
PHP 파일과 이미지 파일에 동일한 명령을 사용할 수 있지만 결과는 게시하지 않겠습니다.
ab -kc 500 -n 5000 http://localhost/ab.php ab -kc 500 -n 5000 http://localhost/ab.gif
출력 결과를 문자 그대로 이해할 수 있습니다.
여기 두 가지 중요한 지표가 설명되어 있습니다
예를 들어
requests per second: 16.54 [#/sec] (mean) time per request: 60443.585 [ms] (mean) requests per second: 16.54 [#/sec] (mean)
는 현재 테스트된 서버가 초당 16.54개의 정적 HTML 요청 트랜잭션을 처리할 수 있다는 것을 의미하며 다음 평균은 평균을 의미합니다. 이 값은 현재 시스템의 전반적인 성능을 나타냅니다. 값이 클수록 좋습니다.
time per request: 60443.585 [ms] (mean)
단일 동시성의 지연 시간, 다음 평균은 평균을 의미합니다.
현재 동시성을 분리하고 요청만 완료하는 데 필요한 평균 시간을 계산합니다.
그런데 요청당 두 시간의 차이에 대해 이야기해 보겠습니다.
time per request: 60443.585 [ms] (mean) time per request: 60.444 [ms] (mean, across all concurrent requests)
전자는 단일 요청의 지연을 측정합니다. CPU는 여러 동시성의 경우 동시 요청을 차례로 실행합니다. 다음 시간 조각을 얻으려면 너무 오래 기다려야 합니다.
요청당 계산 방법 시간: 60.444[ms](모든 동시 요청 평균)*동시 횟수
일반인의 관점에서 -n 1000개의 요청이 -c 10의 동시성으로 완료되면 추가 요청이 추가됩니다. 이 평균을 완료하려면.
후자는 성능 측정으로, 요청을 완료하는 데 걸리는 평균 시간과 현재 동시성 조건에서 요청을 늘리는 데 걸리는 시간을 반영합니다.
계산 방법 테스트 소요 시간: 60.444초/요청 완료: 1000
일반인의 관점에서 -n 1001 요청을 완료하는 데 -c 10 동시성을 사용하면 -n1000 요청을 완료하는 것보다 시간이 더 걸린다는 의미입니다.
-c 및 -n 크기를 적절하게 조정하여 서버 성능을 테스트하고, htop 명령을 사용하여 머신의 부하를 시각적으로 확인할 수 있습니다.
내 컴퓨터는 Shanda Cloud의 슈퍼 마이크로 호스트입니다. CPU의 일반적인 부하는 1.7%입니다. htop 명령 결과 스크린샷
가압 후 부하는 기본적으로 100% 증가했습니다. htop 명령 결과 스크린샷
최적화하거나 머신을 바꿔야 할 것 같습니다.
ab 매개변수에 대한 자세한 설명
일반적인 테스트의 경우 -c -n 매개변수를 사용하여 작업을 완료하세요.
형식: ./ab [옵션] [http://]호스트 이름[:port]/path
매개변수:
- n 테스트된 총 요청 수입니다. 기본적으로 하나의 요청만 실행됩니다.
-c는 한 번에 동시 요청 수입니다. 기본값은 한 번에 하나씩입니다.
-h gzip 모드에서 요청하려면 'accept-encoding: gzip'과 같은 요청 헤더를 추가하세요.
-t 테스트가 실행되는 최대 시간(초)입니다. 내부 암시적 값은 -n 50000입니다. 서버 테스트를 고정된 총 시간으로 제한할 수 있습니다. 기본적으로 시간 제한은 없습니다.
-p에는 게시해야 하는 파일이 포함되어 있습니다.
-t에는 게시물 데이터에서 사용되는 콘텐츠 유형 헤더 정보가 포함되어 있습니다.
-v는 표시되는 정보의 자세한 정도를 설정합니다. 4 이상은 헤더 정보를 표시하고, 3 이상은 응답 코드(404, 200 등)를 표시하고, 2 이상은 경고 및 기타 정보를 표시합니다. -v 버전 번호를 표시하고 종료합니다.
-w는 결과를 HTML 테이블 형식으로 출력합니다. 기본적으로 흰색 배경에 2열 너비의 테이블입니다.
-i는 get 대신 헤드 요청을 수행합니다.
-c -c cookie-name=value request: 라인에 쿠키를 첨부합니다. 일반적인 형식은 이름=값의 매개변수 쌍입니다. 이 매개변수는 반복될 수 있습니다.
위 내용은 Nginx 서버에 대한 스트레스 테스트를 수행하도록 ab를 구성하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!