Apache Bench-빠른 가이드

성능 테스트는 비즈니스의 성공에 매우 중요합니다. 실적이 저조한 사이트는 재정적 손실을 입을뿐만 아니라 때때로 법적 영향을 미칠 수 있습니다.

구매, 온라인 시험 응시, 청구서 지불 등과 같은 중요한 온라인 상호 작용에서 성능이 느리고 신뢰할 수없는 사이트를 견디고 싶어하는 사람은 없습니다. 인터넷이 널리 사용됨에 따라 대안의 범위가 엄청납니다. 고객을 얻는 것보다 고객을 잃는 것이 더 쉬우 며 성능은 핵심 게임 체인저입니다.

부하 테스트 도구의 필요성

부하 테스트 도구의 필요성을 이해할 수 있다면이를 사용하는 이유와 동기를 얻을 수 있습니다. 일부 유명 비즈니스 사이트는 많은 방문자가 유입되면서 심각한 다운 타임을 겪었습니다. 전자 상거래 웹 사이트는 광고 캠페인에 많은 투자를하지만 부하 테스트에는 투자하지 않습니다. 따라서 마케팅이 트래픽을 가져올 때 최적의 시스템 성능을 보장하지 못합니다.

부하 테스트를 무시하는 또 다른 익숙한 예는 WordPress 웹 사이트의 "연결 설정 오류"입니다. 따라서 프로덕션에 배포하기 전에 웹 사이트 또는 응용 프로그램을로드 테스트하는 것이 좋습니다. 더 자세한 테스트를 진행하기 전에 프로젝트에 대한 최상의 시나리오를 신속하게 설정하는 것이 좋습니다.

Apache Bench는 무엇입니까?

Apache Bench (ab)는 HTTP (Hypertext Transfer Protocol) 웹 서버를 벤치마킹하기위한 Apache 조직의 도구입니다. Apache 웹 서버의 성능을 측정하도록 설계되었지만 똑같이 좋은 다른 웹 서버를 테스트하는데도 사용할 수 있습니다. 이 도구를 사용하면 웹 서버가 처리 할 수있는 초당 요청 수를 빠르게 알 수 있습니다.

Apache Bench의 기능

Apache Bench의 중요한 기능과 제한 사항을 살펴 보겠습니다. 기능과 제한 사항은 다음과 같습니다.

  • 오픈 소스 소프트웨어이므로 자유롭게 사용할 수 있습니다.

  • 간단한 명령 줄 컴퓨터 프로그램입니다.

  • 플랫폼에 독립적 인 도구입니다. 이는 Linux / Unix 또는 Windows 서버에서 동일하게 호출 될 수 있음을 의미합니다.

  • 웹 서버 (HTTP 또는 HTTPS)에 대해서만 부하 및 성능 테스트를 수행 할 수 있습니다.

  • 확장 할 수 없습니다.

Apache Bench는 동시성 수준 (-c 플래그로 지정됨)에 관계없이 하나의 운영 체제 스레드 만 사용합니다. 따라서 고용량 서버를 벤치마킹 할 때 Apache Bench의 단일 인스턴스 자체가 병목 현상이 될 수 있습니다. 대상 URL을 완전히 포화 시키려면 서버에 여러 프로세서 코어가있는 경우 Apache Bench의 추가 인스턴스를 병렬로 사용하는 것이 좋습니다.

예방법

테스트를 실행하는 동안 특정 간격으로 동시성을 높이기위한 지시문이 Apache Bench에 없음을 알고 있어야합니다. 따라서 ab를 사용하여 부하 테스트를 실행하는 것은 서비스 거부 (DOS) 공격과 동일합니다. 장기간 고부하 테스트를 수행 할 경우 VPS 서비스 제공 업체에 알리고 사전 승인을받는 것이 좋습니다. 적절한 시간 간격을 할당하거나 부하 테스트 작업을 위해 노드를 이동합니다.

둘째, VPS (테스트 노드가 됨)에서 Apache Bench를 배우기 위해 제 3 자의 웹 사이트를 지속적으로 오랫동안 테스트하는 경우 VPS 공용 IP가 제 3 자의 웹 사이트에 의해 차단 될 수있는 원격 가능성이 있습니다. 영구적으로. 이 경우 동일한 IP로 해당 웹 사이트에 연결할 수 없습니다. 그러나 나중에 웹 사이트에 실제로 연결하려는 경우 유일한 솔루션은 대상 웹 사이트의 시스템 관리자에게 문의하거나 VPS 서비스 공급자의 도움을 받아 다른 IP로 서버의 새 인스턴스를 만드는 것입니다.

경고했듯이,이 튜토리얼의 모든 테스트는 시스템 관리자가 일반적으로 "시스템 남용"관행이라고 부르는 것에서 충분히 안전하다는 것을 확신합니다.

이 장에서는 VPS에서 Apache Bench에 대한 환경을 설정하는 방법을 안내합니다.

시스템 요구 사항

  • Memory − 128MB

  • Disk Space − 최소 요구 사항 없음

  • Operating System − 최소 요구 사항 없음

Apache Bench 설치

Apache Bench는 독립 실행 형 애플리케이션이며 Apache 웹 서버 설치에 종속되지 않습니다. 다음은 Apache Bench를 설치하는 2 단계 프로세스입니다.

Step 1 − 패키지 데이터베이스를 업데이트합니다.

# apt-get update

터미널 명령 앞에 # 기호는 루트 사용자가 해당 명령을 실행하고 있음을 의미합니다.

Step 2 − Apache Bench에 액세스하려면 apache2 utils 패키지를 설치하십시오.

# apt-get install apache2-utils

이제 Apache Bench가 설치되었습니다. 동일한 VPS에서 호스팅되는 웹 애플리케이션을 테스트하려면 Apache 웹 서버 만 설치하면됩니다.

# apt-get install apache2

Apache 유틸리티 인 Apache Bench는 Apache 웹 서버 설치시 자동으로 설치됩니다.

Apache Bench 설치 확인

이제 Apache Bench 설치를 확인하는 방법을 살펴 보겠습니다. 다음 코드는 설치를 확인하는 데 도움이됩니다.

# ab -V

Output

This is ApacheBench, Version 2.3 <$Revision: 1604373 $>
Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/
Licensed to The Apache Software Foundation, http://www.apache.org/

위의 터미널 출력이 표시되면 Apache Bench를 성공적으로 설치 한 것입니다.

권한이있는 Sudo 사용자 만들기

안전 관점에서 시스템 관리자가 루트로 작업하는 대신 sudo 사용자를 만드는 것이 좋은 방법으로 간주됩니다. 목적을 위해 test라는 이름의 테스트 사용자를 만듭니다.

# useradd -m -d /home/test -g sudo test

새 사용자의 비밀번호를 설정해 보겠습니다.

# passwd test

시스템은 사용자 테스트를 위해 새 암호를 입력하라는 메시지를 표시합니다. 테스트 중이며 프로덕션 서버에 배포하지 않으므로 간단한 암호를 입력 할 수 있습니다. 일반적으로 sudo 명령은 sudo 사용자 암호를 입력하라는 메시지를 표시합니다. 절차가 번거로워 지므로 복잡한 비밀번호는 사용하지 않는 것이 좋습니다.

Output

Enter new UNIX password:
Retype new UNIX password:   
passwd: password updated successfully

Apache.org 웹 사이트 테스트

이 섹션에서는 Apache.org 웹 사이트를 테스트합니다. 먼저 sudo 사용자 테스트로 전환 해 보겠습니다.

# su test

우선 Apache 조직의 웹 사이트를 테스트합니다. https://www.apache.org/. 먼저 명령을 실행 한 다음 출력을 이해합니다.

$ ab -n 100 -c 10 https://www.apache.org/

여기 -n벤치마킹 세션에 대해 수행 할 요청 수입니다. 기본값은 일반적으로 대표적이지 않은 벤치마킹 결과로 이어지는 단일 요청을 수행하는 것입니다.

-c동시성이며 한 번에 수행 할 여러 요청 수를 나타냅니다. 기본값은 한 번에 하나의 요청입니다.

따라서이 테스트에서 Apache Bench는 Apache 조직 서버에 동시성 10으로 100 개의 요청을 보냅니다.

Output

This is ApacheBench, Version 2.3 <$Revision: 1604373 $>
Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/
Licensed to The Apache Software Foundation, http://www.apache.org/

Benchmarking www.apache.org (be patient).....done

Server Software:        Apache/2.4.7
Server Hostname:        www.apache.org
Server Port:            443
SSL/TLS Protocol:       TLSv1.2,ECDHE-RSA-AES256-GCM-SHA384,2048,256

Document Path:          /
Document Length:        58769 bytes

Concurrency Level:      10
Time taken for tests:   1.004 seconds
Complete requests:      100
Failed requests:        0
Total transferred:      5911100 bytes
HTML transferred:       5876900 bytes
Requests per second:    99.56 [#/sec] (mean)
Time per request:       100.444 [ms] (mean)
Time per request:       10.044 [ms] (mean, across all concurrent requests)
Transfer rate:          5747.06 [Kbytes/sec] received

Connection Times (ms)
              min  mean[+/-sd] median   max
Connect:       39   46  30.9     41     263
Processing:    37   40  21.7     38     255
Waiting:       12   15  21.7     13     230
Total:         77   86  37.5     79     301

Percentage of the requests served within a certain time (ms)
  50%     79
  66%     79
  75%     80
  80%     80
  90%     82
  95%     84
  98%    296
  99%    301
 100%    301 (longest request)

첫 번째 테스트를 실행하면 다음과 같은이 명령의 사용 패턴을 쉽게 인식 할 수 있습니다.

# ab [options .....]  URL

어디,

  • ab − Apache Bench 명령

  • options − 수행하려는 특정 작업에 대한 플래그

  • URL − 테스트 할 경로 URL

출력 값 이해

ab가 반환하는 다양한 출력 값을 이해하려면 다양한 메트릭을 이해해야합니다. 여기에 목록이 있습니다-

  • Server Software − 첫 번째 성공적인 반환의 HTTP 헤더에 반환 된 웹 서버의 이름입니다.

  • Server Hostname − 명령 줄에 지정된 DNS 또는 IP 주소입니다.

  • Server Port− ab가 연결되는 포트입니다. 명령 줄에 포트가 지정되지 않은 경우 기본값은 http의 경우 80, https의 경우 443입니다.

  • SSL/TLS Protocol− 이것은 클라이언트와 서버간에 협상되는 프로토콜 매개 변수입니다. SSL을 사용하는 경우에만 인쇄됩니다.

  • Document Path − 이것은 명령 줄 문자열에서 구문 분석 된 요청 URI입니다.

  • Document Length− 첫 번째로 성공적으로 반환 된 문서의 크기 (바이트)입니다. 테스트 중에 문서 길이가 변경되면 응답은 오류로 간주됩니다.

  • Concurrency Level − 이것은 테스트 중에 사용 된 동시 클라이언트 (웹 브라우저와 동일)의 수입니다.

  • Time Taken for Tests − 첫 번째 소켓 연결이 생성 된 순간부터 마지막 ​​응답이 수신되는 순간까지 걸리는 시간입니다.

  • Complete Requests − 수신 한 성공적인 응답 수.

  • Failed Requests− 실패로 간주 된 요청 수. 숫자가 0보다 크면 연결, 읽기, 잘못된 콘텐츠 길이 또는 예외로 인해 실패한 요청 수를 표시하는 다른 줄이 인쇄됩니다.

  • Total Transferred− 서버에서 수신 한 총 바이트 수. 이 숫자는 기본적으로 유선을 통해 전송 된 바이트 수입니다.

  • HTML Transferred− 서버에서 수신 한 총 문서 바이트 수. 이 숫자는 HTTP 헤더에서받은 바이트를 제외합니다.

  • Requests per second− 이것은 초당 요청 수입니다. 이 값은 요청 수를 총 소요 시간으로 나눈 결과입니다.

  • Time per request− 요청 당 평균 소요 시간. 첫 번째 값은 공식 동시성 * timetaken * 1000 / done으로 계산되고 두 번째 값은 timetaken * 1000 / done 공식으로 계산됩니다.

  • Transfer rate − totalread / 1024 / timetaken 공식에 의해 계산 된 전송 속도.

부하 테스트 출력의 빠른 분석

ab 명령에서 출력 값의 제목에 대해 배웠으므로 초기 테스트의 출력 값을 분석하고 이해해 보겠습니다.

  • Apache 조직은 자체 웹 서버 소프트웨어를 사용하고 있습니다-Apache (버전 2.4.7)

  • 서버는 https 때문에 포트 443에서 수신 대기합니다. http 였다면 80 (기본값)이됩니다.

  • 전송 된 총 데이터는 100 개의 요청에 대해 58769 바이트입니다.

  • 테스트는 1.004 초 만에 완료되었습니다. 실패한 요청이 없습니다.

  • 초당 요청-99.56. 이것은 꽤 좋은 숫자로 간주됩니다.

  • 요청 당 시간-100.444ms (동시 요청 10 개) 따라서 모든 요청에서 100.444ms / 10 = 10.044ms입니다.

  • 전송 속도-1338.39 [Kbytes / sec] 수신.

  • 연결 시간 통계에서 많은 요청이 몇 초 동안 기다려야한다는 것을 알 수 있습니다. 이는 Apache 웹 서버가 대기 대기열에 요청을 넣었 기 때문일 수 있습니다.

첫 번째 테스트에서 우리는 다른 서버에서 호스팅되는 응용 프로그램 (예 : www.apache.org)을 테스트했습니다. 자습서의 후반부에서는 ab 테스트를 실행할 동일한 서버에서 호스팅되는 샘플 웹 애플리케이션을 테스트 할 것입니다. 이것은 학습의 용이성과 데모 목적을위한 것입니다. 이상적으로는 정확한 측정을 위해 호스트 노드와 테스트 노드가 달라야합니다.

ab를 더 잘 배우려면이 튜토리얼을 진행하면서 출력 값이 다른 경우에 어떻게 다른지 비교하고 관찰해야합니다.

Apache Bench의 출력 플로팅

여기에서는 요청 수가 증가함에 따라 서버가 걸리는 시간을 확인하기 위해 관련 결과를 플로팅합니다. 이를 위해-g ab 출력 데이터가 저장 될 파일 이름 (여기서는 out.data)이 뒤 따르는 이전 명령의 옵션-

$ ab -n 100 -c 10 -g out.data https://www.apache.org/

이제 보자 out.data 플롯을 만들기 전에-

$ less out.data

Output

starttime       seconds ctime   dtime   ttime   wait
Tue May 30 12:11:37 2017        1496160697      40      38      77      13
Tue May 30 12:11:37 2017        1496160697      42      38      79      13
Tue May 30 12:11:37 2017        1496160697      41      38      80      13
...

이제 열 머리글을 이해하겠습니다. out.data 파일-

  • starttime − 이것은 통화가 시작된 날짜와 시간입니다.

  • seconds − 시작 시간과 동일하지만 Unix 타임 스탬프 형식 (날짜 -d @ 1496160697은 시작 시간 출력을 반환 함)입니다.

  • ctime − 이것이 연결 시간입니다.

  • dtime − 이것이 처리 시간입니다.

  • ttime − 이것은 총 시간입니다 (이것은 ctime과 dtime의 합, 수학적으로 ttime = ctime + dtime).

  • wait − 이것이 대기 시간입니다.

이러한 여러 항목이 서로 어떻게 관련되어 있는지 그림으로 시각화하려면 다음 이미지를 살펴보십시오.

터미널에서 작업하거나 그래픽을 사용할 수없는 경우 gnuplot훌륭한 옵션입니다. 다음 단계를 통해 빠르게 이해할 수 있습니다.

gnuplot을 설치하고 실행 해 보겠습니다.

$ sudo apt-get install gnuplot  
$ gnuplot

Output

G N U P L O T
Version 4.6 patchlevel 6    last modified September 2014
Build System: Linux x86_64

Copyright (C) 1986-1993, 1998, 2004, 2007-2014
Thomas Williams, Colin Kelley and many others

gnuplot home:     http://www.gnuplot.info
faq, bugs, etc:   type "help FAQ"
immediate help:   type "help"  (plot window: hit 'h')

Terminal type set to 'qt'
gnuplot>

터미널을 통해 작업하고 그래픽을 사용할 수 없다고 가정 할 때 터미널 자체에 ASCII로 출력을 제공하는 멍청한 터미널을 선택할 수 있습니다. 이렇게하면이 빠른 도구를 사용하여 플롯이 어떻게 생겼는지 알 수 있습니다. 이제 ASCII 플롯을위한 터미널을 준비하겠습니다.

gnuplot> set terminal dumb

Output

Terminal type set to 'dumb'
Options are 'feed  size 79, 24'

이제 gnuplot 터미널이 ASCII 플롯을 사용할 준비가되었으므로 out.data 파일-

gnuplot> plot "out.data" using 9  w l

Output

1400 ++-----+------+-----+------+------+------+------+-----+------+-----++
       +      +      +     +      +      +      +"out.data" using 9 ****** +
       |                                                                   |
  1200 ++                       ********************************************
       |     *******************                                           |
  1000 ++    *                                                            ++
       |     *                                                             |
       |     *                                                             |
   800 ++   *                                                             ++
       |    *                                                              |
       |    *                                                              |
   600 ++   *                                                             ++
       |    *                                                              |
       |    *                                                              |
   400 ++   *                                                             ++
       |    *                                                              |
   200 ++   *                                                             ++
       |    *                                                              |
       +****  +      +     +      +      +      +      +     +      +      +
     0 ++-----+------+-----+------+------+------+------+-----+------+-----++
       0      10     20    30     40     50     60     70    80     90    100

요청 수와 관련하여 열 9의 ttime, 총 시간 (ms)을 표시했습니다. 처음 10 개의 요청에 대해 총 시간은 거의 100ms 였고, 다음 30 개의 요청 (10 번째 에서 40 번째까지 )에 대해서는 1100ms로 증가했습니다. 당신의 플롯은 당신에 따라 달라야합니다out.data.

이전 장에서 우리는 제 3 자 웹 사이트를 테스트하기위한 Apache Bench의 기본적인 사용법을 이해했습니다. 이 섹션에서는이 도구를 사용하여 자체 서버에서 웹 애플리케이션을 테스트합니다. 튜토리얼을 가능한 한 독립적으로 유지하기 위해 데모 목적으로 파이썬 응용 프로그램을 설치하기로 결정했습니다. 전문성 수준에 따라 PHP 또는 Ruby와 같은 다른 언어를 선택할 수 있습니다.

Python 설치

일반적으로 Python은 Linux 서버에 기본적으로 설치됩니다.

Bottle Framework 설치 및 간단한 애플리케이션 생성

Bottle은 웹 애플리케이션을 만들기 위해 Python으로 작성된 마이크로 프레임 워크이고 pip는 Python 패키지 관리자입니다. Bottle을 설치하려면 터미널에 다음 명령을 입력하십시오-

$ sudo apt-get install python-pip
$ sudo pip install bottle

이제 작은 Bottle 애플리케이션을 만들어 보겠습니다. 이를 위해 디렉토리를 생성하고 그 내부로 이동하십시오.

$ mkdir webapp
$ cd webapp

새로운 파이썬 스크립트를 생성합니다. app.py, webapp 디렉토리 내부-

$ vim app.py

이제 app.py 파일에 다음 코드를 작성하십시오.

from bottle import Bottle, run

app = Bottle()

@app.route('/')
@app.route('/hello')
def hello():
   return "Hello World!"

run(app, host = 'localhost', port = 8080)

위의 줄을 추가했으면 파일을 저장하고 닫습니다. 파일을 저장했으면 파이썬 스크립트를 실행하여 응용 프로그램을 시작할 수 있습니다.

$ python app.py

Output

Bottle v0.12.7 server starting up (using WSGIRefServer())...
Listening on http://localhost:8080/
Hit Ctrl-C to quit.

이 출력은 애플리케이션이 호스트의 로컬 머신에서 실행되고 있음을 보여줍니다. http://localhost 그리고 항구에서 듣기 8080.

앱이 HTTP 요청에 제대로 응답하는지 확인해 보겠습니다. 이 터미널은 Bottle 애플리케이션 서비스를 종료하지 않고는 입력을받을 수 없기 때문에 다른 터미널로 VPS에 로그인해야합니다. 다른 터미널로 VPS에 로그인 한 후 새 터미널에 다음 코드를 입력하여 애플리케이션으로 이동할 수 있습니다.

$ lynx http://localhost:8080/

Lynx는 명령 줄 브라우저이며 일반적으로 Debian 및 Ubuntu와 같은 다양한 Linux 배포판에 기본적으로 설치됩니다. 다음 출력이 표시되면 앱이 제대로 작동하고 있음을 의미합니다.

Output

위의 출력이 표시되면 애플리케이션이 라이브 상태이고 테스트 할 준비가되었음을 의미합니다.

개발 용 웹 서버로 애플리케이션 테스트

ab에 버그가 있으며 localhost에서 애플리케이션을 테스트 할 수 없습니다. 따라서 app.py 파일에서 호스트를 localhost에서 127.0.0.1로 변경합니다. 따라서 파일은 다음과 같이 변경됩니다.

from bottle import Bottle, run

app = Bottle()

@app.route('/')
@app.route('/hello')
def hello():
   return "Hello World!"

run(app, host = '127.0.0.1', port = 8080)

이제 lynx 명령을 실행 한 동일한 터미널에 다음 명령을 입력하여 앱을 테스트 해 보겠습니다.

$ ab -n 100 -c 10  http://127.0.0.1:8080/hello

Output

This is ApacheBench, Version 2.3 <$Revision: 1604373 $>
Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/
Licensed to The Apache Software Foundation, http://www.apache.org/

Benchmarking 127.0.0.1 (be patient).....done


Server Software:        WSGIServer/0.1
Server Hostname:        127.0.0.1
Server Port:            8080

Document Path:          /hello
Document Length:        12 bytes

Concurrency Level:      10
Time taken for tests:   0.203 seconds
Complete requests:      100
Failed requests:        0
Total transferred:      16500 bytes
HTML transferred:       1200 bytes
Requests per second:    493.78 [#/sec] (mean)
Time per request:       20.252 [ms] (mean)
Time per request:       2.025 [ms] (mean, across all concurrent requests)
Transfer rate:          79.56 [Kbytes/sec] received

Connection Times (ms)
              min  mean[+/-sd] median   max
Connect:        0    0   0.1      0       0
Processing:     1    6  28.2      2     202
Waiting:        1    6  28.2      2     202
Total:          1    6  28.2      2     202

Percentage of the requests served within a certain time (ms)
  50%      2
  66%      2
  75%      2
  80%      2
  90%      2
  95%      2
  98%    202
  99%    202
 100%    202 (longest request)

첫 번째 터미널의 출력은 다음과 같이 (100 배)됩니다.

...
127.0.0.1 - - [10/Jun/2017 04:30:26] "GET /hello HTTP/1.0" 200 12
127.0.0.1 - - [10/Jun/2017 04:30:26] "GET /hello HTTP/1.0" 200 12
127.0.0.1 - - [10/Jun/2017 04:30:26] "GET /hello HTTP/1.0" 200 12   
...

ab 결과의 다양한 값이 초기 테스트와 비교하여 어떻게 변했는지 관찰 할 수 있습니다.

다중 스레드 웹 서버로 응용 프로그램 테스트

ab의 이전 테스트에서 우리는 Bottle 프레임 워크에 번들 된 기본 웹 서버를 사용했습니다.

이제 단일 스레드 기본 웹 서버를 다중 스레드로 변경합니다. 따라서 다음과 같은 다중 스레드 웹 서버 라이브러리를 설치하겠습니다.cherrypy 또는 gunicorn보틀에게 사용하라고 말하세요. 여기서 데모 목적으로 gunicorn을 선택했습니다 (다른 것도 선택할 수 있습니다).

$  sudo apt-get install gunicorn

그리고 파일을 수정하면 기본 웹 서버에서 gunicorn으로 변경됩니다.

...
run(server = 'gunicorn'...)
...

두 번째 터미널에서 앱을 테스트 해 보겠습니다.

$ ab -n 100 -c 10  http://127.0.0.1:8080/hello

Output

This is ApacheBench, Version 2.3 <$Revision: 1604373 $>
Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/
Licensed to The Apache Software Foundation, http://www.apache.org/

Benchmarking 127.0.0.1 (be patient).....done


Server Software:        gunicorn/19.0.0
Server Hostname:        127.0.0.1
Server Port:            8080

Document Path:          /hello
Document Length:        12 bytes

Concurrency Level:      10
Time taken for tests:   0.031 seconds
Complete requests:      100
Failed requests:        0
Total transferred:      17200 bytes
HTML transferred:       1200 bytes
Requests per second:    3252.77 [#/sec] (mean)
Time per request:       3.074 [ms] (mean)
Time per request:       0.307 [ms] (mean, across all concurrent requests)
Transfer rate:          546.36 [Kbytes/sec] received

Connection Times (ms)
              min  mean[+/-sd] median   max
Connect:        0    1   0.9      0       4
Processing:     1    2   0.7      3       4
Waiting:        0    2   0.8      2       3
Total:          2    3   0.6      3       5
WARNING: The median and mean for the initial connection time are not within a normal
        deviation These results are probably not that reliable.
WARNING: The median and mean for the processing time are not within a normal deviation
        These results are probably not that reliable.

Percentage of the requests served within a certain time (ms)
  50%      3
  66%      3
  75%      3
  80%      3
  90%      4
  95%      5
  98%      5
  99%      5
 100%      5 (longest request)

초당 요청 수가 493에서 3252로 어떻게 증가했는지 관찰하십시오. 이는 gunicorn이 Python 앱의 프로덕션 서버로 적합하다는 것을 의미합니다.

이 장에서는 여러 URL을 동시에 테스트하는 방법을 배웁니다. 이를 위해 두 개의 URL을 포함하도록 응용 프로그램 파일 app.py를 편집해야합니다.

from bottle import Bottle, run

app = Bottle()

@app.route('/')
@app.route('/hello1')
def hello():
   return "Hello World! It is first URL."

@app.route('/hello2')
def hello():
   return "Hello World! It is second URL."

run(app,server = 'gunicorn',host = '127.0.0.1', port = 8080)

간단한 셸 스크립트 생성

여러 ab 호출로 셸 스크립트를 생성하여이를 수행 할 수 있습니다. test.sh 파일을 만들고 다음 줄을 추가합니다.

ab -n 100 -c 10 http://127.0.0.1:8080/hello1 
ab -n 100 -c 10 http://127.0.0.1:8080/hello2

위의 줄을 추가했으면 파일을 저장하고 닫습니다. 파일을 실행 가능하게 만들기-

chmod u+x test.sh

이제 스크립트를 실행 해 보겠습니다.

./test.sh

반복과 명확성을 피하기 위해 다음과 같이 생략 된 부분을 점으로 표시하여 ab 출력의 관련 만 표시합니다.

산출

.
.
.
Document Path:          /hello1
Document Length:        732 bytes

Concurrency Level:      10
Time taken for tests:   0.040 seconds
Complete requests:      100
Failed requests:        0
Non-2xx responses:      100
Total transferred:      90000 bytes
HTML transferred:       73200 bytes
Requests per second:    2496.13 [#/sec] (mean)
Time per request:       4.006 [ms] (mean)
Time per request:       0.401 [ms] (mean, across all concurrent requests)
Transfer rate:          2193.87 [Kbytes/sec] received

Connection Times (ms)
              min  mean[+/-sd] median   max
Connect:        0    0   0.8      0       3
Processing:     1    3   1.0      4       5
Waiting:        0    3   1.2      4       4
Total:          1    4   0.6      4       5
WARNING: The median and mean for the processing time are not within a normal deviation
        These results are probably not that reliable.
.
.
.

Apache Bench 출력을 파일에 저장하는 셸 스크립트

여러 ab 호출로 셸 스크립트를 생성하여 Apache Bench Output을 파일에 저장할 수 있습니다. 각 줄의 끝에&;이렇게하면 명령이 백그라운드에서 실행되고 다음 명령이 실행을 시작할 수 있습니다. <filename>을 사용하여 각 URL에 대한 파일로 출력을 리디렉션 할 수도 있습니다. 예를 들어, test.sh 파일은 수정 후 다음과 같습니다.

$ ab -n 100 -c 10 http://127.0.0.1:8080/hello1 > test1.txt &
$ ab -n 100 -c 10 http://127.0.0.1:8080/hello2 > test2.txt &

여기, test1.txttest2.txt 출력 데이터를 저장하는 파일입니다.

위의 스크립트가 각 URL에 대한 ab 출력을 포함하는 test1.txt 및 test2.txt 파일을 생성했는지 확인할 수 있습니다.

$ ls -l

산출

...
-rw-r--r-- 1 root root  5225 May 30 12:11 out.data
-rwxr--r-- 1 root root   118 Jun 10 12:24 test.sh
-rw-r--r-- 1 root root  1291 Jun 10 12:31 test1.txt
-rwxr--r-- 1 root root    91 Jun 10 13:22 test2.sh
-rw-r--r-- 1 root root  1291 Jun 10 12:31 test2.txt
...

경계 상황

ab를 사용하는 동안 경고없이 실패한 테스트에 대해 경고해야합니다. 예를 들어, 잘못된 URL을 확인하면 다음과 유사한 내용이 표시 될 수 있습니다 (여기서는 의도적으로 포트를 변경했습니다).

$ ab -l -r -n 100 -c 10 -k -H "Accept-Encoding: gzip, deflate"  http://127.0.0.1:805/

산출

This is ApacheBench, Version 2.3 <$Revision: 1604373 $>
Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/
Licensed to The Apache Software Foundation, http://www.apache.org/

Benchmarking 127.0.0.1 (be patient).....done

Server Software:
Server Hostname:        127.0.0.1
Server Port:            805

Document Path:          /
Document Length:        Variable

Concurrency Level:      10
Time taken for tests:   0.002 seconds
Complete requests:      100
Failed requests:        150
   (Connect: 0, Receive: 100, Length: 0, Exceptions: 50)
Keep-Alive requests:    0
Total transferred:      0 bytes
HTML transferred:       0 bytes
Requests per second:    44984.26 [#/sec] (mean)
Time per request:       0.222 [ms] (mean)
Time per request:       0.022 [ms] (mean, across all concurrent requests)
Transfer rate:          0.00 [Kbytes/sec] received

Connection Times (ms)
              min  mean[+/-sd] median   max
Connect:        0    0   0.0      0       0
Processing:     0    0   0.2      0       0
Waiting:        0    0   0.0      0       0
Total:          0    0   0.2      0       0

Percentage of the requests served within a certain time (ms)
  50%      0
  66%      0
  75%      0
  80%      0
  90%      0
  95%      0
  98%      0
  99%      0
 100%      0 (longest request)

이 장에서는 동적 페이지 테스트에 필요한 준비 사항을 이해합니다. 서버 측 동적 웹 페이지는 구성이 서버 측 스크립트를 처리하는 애플리케이션 서버에 의해 제어되는 웹 페이지입니다. Apache 벤치는 서버 측 동적 웹 페이지 만로드 테스트 할 수 있습니다.

동시성 수준 및 총 요청 수

동시성 수준은 총 요청 수보다 낮아야합니다.

$ ab -l -r -n 30 -c 80 -k -H "Accept-Encoding: gzip, deflate"  http://127.0.0.1:8000/

Output

ab: Cannot use concurrency level greater than total number of requests
Usage: ab [options] [http[s]://]hostname[:port]/path

플래그 사용

이 섹션에서는 ab 명령에 몇 가지 중요한 플래그를 사용하는 방법을 설명합니다. 우리는 용어, 옵션 및 플래그를 같은 의미로 사용할 것입니다.

Verbose -v

verbose 옵션은 실패한 요청이 여러 개있는 경우 분석 및 디버그하는 데 사용할 수 있습니다. 부하 테스트 실패의 일반적인 표시는 테스트가 매우 빠르게 완료되고 초당 요청 값에 대해 좋은 수를 제공한다는 것입니다. 그러나 그것은 잘못된 기준이 될 것입니다. 성공 또는 실패를 식별하기 위해-v 2각 응답의 본문과 헤더를 터미널 출력에 덤프하는 옵션입니다. 다음 명령은 사용 사례를 설명합니다-

$ ab -n 1 -v 2 http://www.generic-example-URL.com/

Output

LOG: header received:
HTTP/1.0 200 OK
…
Content-Length: 2548687

물론, 변수 응답을 테스트하거나 오류 발생시 200이 아닌 HTTP 코드를 반환하는 경우에는 단순히 길이 확인을 무시해야합니다. -l선택권. 다음 장에서 web2py 애플리케이션을 시작할 때 곧 200이 아닌 HTTP를 보게 될 것입니다.

Keep-alive -k

클라이언트가 HTTP 요청을 보내면 서버에 연결되고 서버가 응답을 보내고 요청을 보낸 후 연결이 닫힙니다. 이주기는 각 요청에서 계속됩니다. 그러나 연결 유지 설정 (영구 연결이라고도 함)을 사용하면 클라이언트가 기본 TCP 연결을 열어 여러 요청 및 응답을 용이하게합니다. 이렇게하면 느리고 비용이 많이 드는 연결 초기화 시간이 제거됩니다.

가변 문서 길이 -l

웹 페이지의 길이가 가변적이면 옵션을 사용해야합니다. -l. Apache Bench는 응답 길이가 일정하지 않은 경우 오류를보고하지 않습니다. 이는 동적 페이지에 유용 할 수 있습니다.

-r 옵션 사용

오류 수신시 ab가 종료되지 않도록 강제하는 방법은 무엇입니까? 옵션을 사용해야합니다.-r. 이 옵션이 없으면 요청이 소켓 오류에 도달하자마자 테스트가 중단 될 수 있습니다. 그러나이 옵션을 사용하면 실패한 오류 제목에 오류가보고되지만 테스트는 끝까지 계속됩니다.

옵션 -H 사용

이 옵션은 임의의 헤더 행을 추가하는 데 사용됩니다. 인수는 일반적으로 콜론으로 구분 된 필드 값 쌍 (예 : "Accept-Encoding : zip / zop; 8bit")을 포함하는 유효한 헤더 행 형식입니다.

옵션 -C 사용

다음 섹션에서는 쿠키 값을 사용하는 옵션과 함께 위 옵션을 사용하는 방법에 대해 자세히 알아 봅니다. -C선택권. -C 옵션은 일반적으로name = value쌍. 이 필드는 반복 될 수 있습니다.

Apache Bench에서 세션 쿠키 사용

Apache Bench에서 쿠키를 사용하는 방법을 이해하려면 쿠키 설정을 시도하는 웹 페이지가 필요합니다. 아주 좋은 예는 파이썬 웹 프레임 워크 인 web2py 애플리케이션입니다.

web2py 설치

또 다른 파이썬 앱 web2py를 빠르게 설치할 것입니다. Web2py Framework Overview 에서 사용 방법에 대해 자세히 알아볼 수 있습니다 .

Python은 일반적으로 Ubuntu 및 Debian 서버에 기본적으로 설치됩니다. 따라서 web2py를 성공적으로 실행하기위한 하나의 요구 사항이 이미 충족되었습니다.

그러나 우리가 다운로드 할 zip 파일에서 web2py의 소스 파일을 추출하려면 unzip 패키지를 설치해야합니다.

$ sudo apt-get update
$ sudo apt-get install unzip

프로젝트의 웹 사이트에서 web2py 프레임 워크를 가져 오겠습니다. 이것을 홈 폴더에 다운로드합니다.

$cd ~
$ wget http://www.web2py.com/examples/static/web2py_src.zip

이제 방금 다운로드 한 파일의 압축을 풀고 내부로 이동할 수 있습니다.

$ unzip web2py_src.zip
$ cd web2py

web2py를 실행하기 위해 설치할 필요가 없습니다. web2py 디렉토리에 들어가면 다음 명령을 입력하여 실행할 수 있습니다.

$python web2py.py

모든 것이 성공하면 관리 UI에 대한 암호를 선택하라는 다음 출력이 표시됩니다.

web2py Web Framework
Created by Massimo Di Pierro, Copyright 2007-2017
Version 2.14.6-stable+timestamp.2016.05.10.00.21.47
Database drivers available: sqlite3, imaplib, pymysql, pg8000
WARNING:web2py:GUI not available because Tk library is not installed
choose a password:

please visit:
        http://127.0.0.1:8000/
use "kill -SIGTERM 23904" to shutdown the web2py server

그러나 시작된 웹 인터페이스는 로컬 컴퓨터에서만 액세스 할 수 있다는 사실을 알고 있어야합니다.

출력에서 웹 서버를 중지하려면 인스턴트 터미널에 "CTRL-C"를 입력해야 함을 이해할 수 있습니다. 반면, 동일한 VPS와 관련된 다른 터미널에서 web2py 서버를 중지하려면 kill -SIGTERM <PID> 명령을 삽입 할 수 있습니다. 여기서 <PID>는 web2py 서버의 프로세스 ID입니다. 23904.

web2py의 세션 쿠키

페이지에 로그인 한 사용자 만 액세스 할 수 있고 로그인 페이지에서 직접 액세스 할 수없는 경우 다음을 사용할 수 있습니다. -C깃발. 이 플래그는 ab 명령에 대한 쿠키를 정의합니다. 그러나 유효한 세션에서 세션 식별자 쿠키의 값을 가져와야합니다. 그것을 얻는 방법? 다양한 온라인 자습서가 Chrome (또는 Mozilla) 브라우저 개발자 도구로 안내합니다. 그러나 테스트 사례에서는 응용 프로그램이 명령 줄에서만 사용할 수 있으므로 lynx 브라우저를 사용하여 값을 얻습니다.

먼저 세션의 쿠키 값을 가져 오겠습니다. 다른 터미널을 열고 다음 명령을 입력하십시오-

$ lynx http://127.0.0.1:8000/

위의 명령에 대한 응답으로 lynx는 아래 이미지와 같이 web2py 서버의 쿠키를 수락 할 수있는 권한을 요청합니다.

입력하기 전에 쿠키 값을 기록해 둡니다. y쿠키를 수락합니다. 이제 터미널은 다음 이미지와 유사하게 보일 것입니다 – 터미널의 웹 사이트!

쿠키 값을 얻었으므로 이제 ab 테스트를 실행합니다. 이를 위해 세 번째 터미널을 열어야합니다 (아래 이미지 참조).

이제 세 번째 터미널에서 -C 플래그를 사용하겠습니다.

$ ab -n 100 -c 10 -C session_name = 127.0.0.1-643dad04-3c34  http://127.0.0.1:8000/

산출

This is ApacheBench, Version 2.3 <$Revision: 1604373 $>
Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/
Licensed to The Apache Software Foundation, http://www.apache.org/

Benchmarking 127.0.0.1 (be patient).....done


Server Software:        Rocket
Server Hostname:        127.0.0.1
Server Port:            8000

Document Path:          /
Document Length:        66 bytes

Concurrency Level:      10
Time taken for tests:   0.051 seconds
Complete requests:      100
Failed requests:        0
Non-2xx responses:      100
Total transferred:      27700 bytes
HTML transferred:       6600 bytes
Requests per second:    1968.12 [#/sec] (mean)
Time per request:       5.081 [ms] (mean)
Time per request:       0.508 [ms] (mean, across all concurrent requests)
Transfer rate:          532.39 [Kbytes/sec] received

Connection Times (ms)
              min  mean[+/-sd] median   max
Connect:        1    2   0.9      2       4
Processing:     0    3   0.9      3       5
Waiting:        0    2   1.1      2       4
Total:          4    5   0.7      5       7

Percentage of the requests served within a certain time (ms)
  50%      5
  66%      5
  75%      5
  80%      6
  90%      6
  95%      6
  98%      7
  99%      7
 100%      7 (longest request)

위의 출력에서 ​​몇 가지 사항을 알 수 있습니다. 첫째, web2py는 Rocket 웹 서버를 사용 합니다. 또한 출력에서 ​​이전에 논의한 표제 외에도 '비 -2xx 응답'이 표시됩니다. 일반적으로 Http 프로토콜은 응답 코드를 사용하여 요청에 응답하고 200 초 범위 내의 모든 것은 '좋음'을 의미하고 나머지는 일부 문제에 해당합니다. 예를 들어 400은 404 File Not Found와 같은 리소스 관련 오류입니다. 500은 서버 오류에 해당합니다. 즉석의 경우 -C 옵션을 사용하는 경우를 제외하고는 오류가 없습니다. 이미 설명한대로 -l 옵션을 사용하여 억제 할 수 있습니다.

관리자 페이지 확인

이 섹션에서는 관리자 페이지를 확인하는 방법을 이해합니다. 비교를 위해 web2py 애플리케이션의 다른 URL을 테스트 해 보겠습니다.

$ ab -n 100 -c 10 session_name = 127.0.0.1-643dad04-3c34  http://127.0.0.1:8000/admin

산출

This is ApacheBench, Version 2.3 <$Revision: 1604373 $>
Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/
Licensed to The Apache Software Foundation, http://www.apache.org/

Benchmarking 127.0.0.1 (be patient).....done


Server Software:        Rocket
Server Hostname:        127.0.0.1
Server Port:            8000

Document Path:          /admin
Document Length:        8840 bytes

Concurrency Level:      10
Time taken for tests:   2.077 seconds
Complete requests:      100
Failed requests:        0
Total transferred:      926700 bytes
HTML transferred:       884000 bytes
Requests per second:    48.14 [#/sec] (mean)
Time per request:       207.749 [ms] (mean)
Time per request:       20.775 [ms] (mean, across all concurrent requests)
Transfer rate:          435.61 [Kbytes/sec] received

Connection Times (ms)
          min  mean[+/-sd] median   max
Connect:        0    1   3.2      0      12
Processing:    62  204  52.2    199     400
Waiting:       61  203  52.0    199     400
Total:         62  205  54.3    199     411

Percentage of the requests served within a certain time (ms)
  50%    199
  66%    211
  75%    220
  80%    226
  90%    264
  95%    349
  98%    381
  99%    411
 100%    411 (longest request)

특히 "연결 시간"및 "제공된 요청 비율…"섹션의 각 통계를 확인해야합니다. http://127.0.0.1:8000/http://127.0.0.1:8000/admin. 큰 차이가 있습니다.

시간 제한 옵션 사용

일반적으로 시간 제한 옵션은 까다로운 옵션입니다. 우리가에서 이것을 이해하자 AB의 설명서를 확실히 설명입니다 -

-t timelimit
Maximum number of seconds to spend for benchmarking. This implies a -n 50000 internally.
Use this to benchmark the server within a fixed total amount of time.
Per default there is no timelimit.

이 옵션으로 테스트를 실행 해 보겠습니다. 출력을 살펴본 후 관찰 한 내용을 기록합니다.

$ ab -n 100 -c 10 -t 60   http://127.0.0.1:8000/

산출

This is ApacheBench, Version 2.3 <$Revision: 1604373 $>
Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/
Licensed to The Apache Software Foundation, http://www.apache.org/

Benchmarking 127.0.0.1 (be patient)
Completed 5000 requests
Completed 10000 requests
Completed 15000 requests
Completed 20000 requests
Completed 25000 requests
Completed 30000 requests
Completed 35000 requests
Completed 40000 requests
Completed 45000 requests
Completed 50000 requests
Finished 50000 requests


Server Software:        Rocket
Server Hostname:        127.0.0.1
Server Port:            8000

Document Path:          /
Document Length:        66 bytes

Concurrency Level:      10
Time taken for tests:   22.547 seconds
Complete requests:      50000
Failed requests:        0
Non-2xx responses:      50000
Total transferred:      13850000 bytes
HTML transferred:       3300000 bytes
Requests per second:    2217.61 [#/sec] (mean)
Time per request:       4.509 [ms] (mean)
Time per request:       0.451 [ms] (mean, across all concurrent requests)
Transfer rate:          599.88 [Kbytes/sec] received

Connection Times (ms)
              min  mean[+/-sd] median   max
Connect:        0    2   0.8      2       8
Processing:     0    2   3.2      2     218
Waiting:        0    2   3.2      2     218
Total:          2    4   3.1      4     220

Percentage of the requests served within a certain time (ms)
  50%      4
  66%      4
  75%      4
  80%      5
  90%      5
  95%      5
  98%      7
  99%      8
 100%    220 (longest request)

출력에이 옵션이 -n옵션이며 최대 50K 요청까지 계속됩니다. 그러나 요청이 매우 빠르게 처리 되었기 때문에 ab는 50k 마크가 ​​달성 되 자마자 종료되었습니다. 즉석의 경우 22 초 이내에 (테스트 소요 시간 제목 참조).

동일한 명령을 테스트하여 http://127.0.0.1:8000/http://127.0.0.1:8000/admin (우리의 web2py 응용 프로그램이라고 가정) 또는 https://www.apache.org/와 같은 타사 웹 사이트에서 통계의 차이를 확인하십시오.

부하 테스트를 수행하기 전에 체크리스트

테스트를 성공적으로 실행하고 성능을 정확하게 측정하는 데 도움이되는 몇 가지 검사가 있습니다. 부하 테스트를 수행하기 전에 다음 조건을 고려하십시오.

  • 추가 파이썬 모듈이로드되지 않았는지 확인하십시오.

  • TCP / IP 포트 고갈을 방지하려면 일반적으로 다른 ab 테스트로 이동하기 전에 2-3 분을 기다려야합니다.

  • 동시 연결 수가 Apache 작업자 스레드보다 적은지 확인하십시오.

  • Apache 또는 python이 충돌하는 경우 다른 테스트를 수행하기 전에 서버를 재부팅해야합니다.

이 장에서는 다양한 조합에 대해 설명합니다. -n-c 웹 서버의 부하를 점진적으로 늘리기 위해 중요한 플래그를 사용합니다.

부하가 증가함에 따라 다음 측정 항목이 어떻게 변경되는지에 중점을 두어야합니다.

  • 초당 요청
  • 연결 시간 (ms)
  • 특정 시간 (밀리 초) 내에 제공된 요청 비율

또한 서버가 중단되기 시작하고 실패한 요청을 받기 시작할 때 임계 값을 확인해야합니다.

1 명의 동시 사용자가 100 페이지 조회를 수행

단일 사용자가 100 개의 순차적 페이지로드를 수행해 보겠습니다.

$ ab -l -r -n 100 -c 1 -k -H "Accept-Encoding: gzip, deflate"  http://127.0.0.1:8000/

산출

This is ApacheBench, Version 2.3 <$Revision: 1604373 $>
Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/
Licensed to The Apache Software Foundation, http://www.apache.org/

Benchmarking 127.0.0.1 (be patient).....done


Server Software:        Rocket
Server Hostname:        127.0.0.1
Server Port:            8000

Document Path:          /
Document Length:        Variable

Concurrency Level:      1
Time taken for tests:   0.045 seconds
Complete requests:      100
Failed requests:        0
Non-2xx responses:      100
Keep-Alive requests:    0
Total transferred:      27700 bytes
HTML transferred:       6600 bytes
Requests per second:    2206.24 [#/sec] (mean)
Time per request:       0.453 [ms] (mean)
Time per request:       0.453 [ms] (mean, across all concurrent requests)
Transfer rate:          596.80 [Kbytes/sec] received

Connection Times (ms)
              min  mean[+/-sd] median   max
Connect:        0    0   0.0      0       0
Processing:     0    0   0.0      0       0
Waiting:        0    0   0.0      0       0
Total:          0    0   0.0      0       1

Percentage of the requests served within a certain time (ms)
  50%      0
  66%      0
  75%      0
  80%      0
  90%      1
  95%      1
  98%      1
  99%      1
 100%      1 (longest request)

5 명의 동시 사용자가 각각 10 페이지 조회

이 경우는 한 달에 약 50,000 회 이상의 조회수를 기록하는 웹 사이트의 최대로드에 해당합니다.

$ ab -l -r -n 10 -c 5 -k -H "Accept-Encoding: gzip, deflate"  http://127.0.0.1:8000/

다음 출력에서는 명확성을 위해 공통 헤더를 생략 할 것입니다.

산출

...
Requests per second:    2009.24 [#/sec] (mean)
Time per request:       2.488 [ms] (mean)
Time per request:       0.498 [ms] (mean, across all concurrent requests)
Transfer rate:          543.52 [Kbytes/sec] received

Connection Times (ms)
              min  mean[+/-sd] median   max
Connect:        0    1   0.5      1       2
Processing:     0    1   0.5      1       2
Waiting:        0    1   0.5      1       1
Total:          2    2   0.4      3       3
ERROR: The median and mean for the total time are more than twice the standard
       deviation apart. These results are NOT reliable.

Percentage of the requests served within a certain time (ms)
  50%      3
  66%      3
  75%      3
  80%      3
  90%      3
  95%      3
  98%      3
  99%      3
 100%      3 (longest request)

10 명의 동시 사용자가 각각 10 회 페이지 조회

이 테스트는 10 명의 다른 동시 사용자에 의한 100 페이지로드에 해당하며 각 사용자는 10 회의 순차적 페이지로드를 수행합니다.

$ ab  -r -n 10 -c 10 -k -H "Accept-Encoding: gzip, deflate"  http://127.0.0.1:8000/

산출

...
Requests per second:    2225.68 [#/sec] (mean)
Time per request:       4.493 [ms] (mean)
Time per request:       0.449 [ms] (mean, across all concurrent requests)
Transfer rate:          602.07 [Kbytes/sec] received

Connection Times (ms)
              min  mean[+/-sd] median   max
Connect:        1    2   0.7      2       3
Processing:     0    2   1.0      2       3
Waiting:        0    1   1.0      2       3
Total:          4    4   0.3      4       4
WARNING: The median and mean for the waiting time are not within a normal deviation
        These results are probably not that reliable.

Percentage of the requests served within a certain time (ms)
  50%      4
  66%      4
  75%      4
  80%      4
  90%      4
  95%      4
  98%      4
  99%      4
 100%      4 (longest request)

20 명의 동시 사용자가 각각 20 페이지 조회를 수행

이 테스트는 20 명의 서로 다른 동시 사용자에 의한 400 페이지로드에 해당하며 각 사용자는 20 개의 순차적 페이지로드를 수행합니다.

$ ab -r -n 20 -c 20 -k -H “Accept-Encoding: gzip, deflate” http://127.0.0.1:8000/

산출

...
Requests per second:    1619.96 [#/sec] (mean)
Time per request:       12.346 [ms] (mean)
Time per request:       0.617 [ms] (mean, across all concurrent requests)
Transfer rate:          438.21 [Kbytes/sec] received

Connection Times (ms)
              min  mean[+/-sd] median   max
Connect:        2    6   2.3      6      10
Processing:     1    5   2.9      5      10
Waiting:        0    5   2.9      5       9
Total:         10   11   0.6     11      12

Percentage of the requests served within a certain time (ms)
  50%     11
  66%     11
  75%     12
  80%     12
  90%     12
  95%     12
  98%     12
  99%     12
 100%     12 (longest request)

30 명의 동시 사용자가 각각 30 페이지 조회

이 테스트는 30 명의 서로 다른 동시 사용자에 의한 900 페이지로드에 해당하며 각 사용자는 30 개의 순차적 페이지로드를 수행합니다.

$ ab  -r -n 30 -c 30 -k -H "Accept-Encoding: gzip, deflate"  http://127.0.0.1:8000/

산출

...
Requests per second:    2283.45 [#/sec] (mean)
Time per request:       13.138 [ms] (mean)
Time per request:       0.438 [ms] (mean, across all concurrent requests)
Transfer rate:          617.69 [Kbytes/sec] received

Connection Times (ms)
              min  mean[+/-sd] median   max
Connect:        2    6   2.7      6      11
Processing:     1    6   3.1      6      11
Waiting:        0    5   3.2      5      10
Total:         11   12   0.5     12      13

Percentage of the requests served within a certain time (ms)
  50%     12
  66%     12
  75%     12
  80%     12
  90%     13
  95%     13
  98%     13
  99%     13
 100%     13 (longest request)

이제 웹 사이트에서 부하를 점진적으로 늘리고 성능을 테스트하는 방법을 배웠습니다.

이 장에서는 플래그가있는 출력과없는 출력을 비교합니다. 적절한 플래그를 사용하여 웹 애플리케이션의 성능을 향상시킬 수있는 방법을 살펴 보겠습니다. 그 전에, 우리는 당신의 애플리케이션이 단순하다면 어떻게 그 차이를 눈치 채지 못할 수 있는지 이해해야합니다. 플래그가 있고 플래그가없는 간단한 애플리케이션의 경우와 같습니다. 그런 다음 동일한 테스트를 수행합니다.https://www.apache.org/ URL, 차이점을 확인하십시오.

플래그없이 애플리케이션 테스트

이 섹션에서는 플래그없이 애플리케이션을 테스트하는 방법을 이해합니다.

$ ab -n 100 -c 10 http://127.0.0.1:8000/

산출

This is ApacheBench, Version 2.3 <$Revision: 1604373 $>
Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/
Licensed to The Apache Software Foundation, http://www.apache.org/

Benchmarking 127.0.0.1 (be patient).....done


Server Software:        Rocket
Server Hostname:        127.0.0.1
Server Port:            8000

Document Path:          /
Document Length:        Variable

Concurrency Level:      10
Time taken for tests:   0.244 seconds
Complete requests:      100
Failed requests:        0
Non-2xx responses:      100
Keep-Alive requests:    0
Total transferred:      27700 bytes
HTML transferred:       6600 bytes
Requests per second:    2208.77 [#/sec] (mean)
Time per request:       4.527 [ms] (mean)
Time per request:       0.453 [ms] (mean, across all concurrent requests)
Transfer rate:          597.49 [Kbytes/sec] received

Connection Times (ms)
              min  mean[+/-sd] median   max
Connect:        1    2   0.7      2       3
Processing:     0    2   0.7      2       4
Waiting:        0    2   1.0      2       3
Total:          4    4   0.3      4       5

Percentage of the requests served within a certain time (ms)
  50%      4
  66%      4
  75%      5
  80%      5
  90%      5
  95%      5
  98%      5
  99%      5
 100%      5 (longest request)

플래그로 애플리케이션 테스트

이 섹션에서는 플래그를 사용하여 애플리케이션을 테스트하는 방법을 이해합니다.

$ ab -l -r -n 100 -c 10 -k -H "Accept-Encoding: gzip, deflate"  http://127.0.0.1:8000/

산출

...
Requests per second:    2277.07 [#/sec] (mean)
Time per request:       4.392 [ms] (mean)
Time per request:       0.439 [ms] (mean, across all concurrent requests)
Transfer rate:          615.97 [Kbytes/sec] received

Connection Times (ms)
              min  mean[+/-sd] median   max
Connect:        1    2   0.7      2       3
Processing:     0    2   0.7      2       4
Waiting:        0    2   1.0      2       3
Total:          4    4   0.2      4       5

Percentage of the requests served within a certain time (ms)
  50%      4
  66%      4
  75%      4
  80%      4
  90%      5
  95%      5
  98%      5
  99%      5
 100%      5 (longest request)

출력 통계간에 큰 차이가 없다는 것을 간단히 알 수 있습니다.

플래그없이 Apache 조직 웹 사이트 테스트

이제 플래그없이 Apache 조직 웹 사이트를 테스트하는 방법을 살펴 보겠습니다.

$ ab -n 100 -c 10 http://www.apache.org/

산출

This is ApacheBench, Version 2.3 <$Revision: 1604373 $>
Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/
Licensed to The Apache Software Foundation, http://www.apache.org/

Benchmarking www.apache.org (be patient).....done

Server Software:        Apache/2.4.7
Server Hostname:        www.apache.org
Server Port:            80

Document Path:          /
Document Length:        58433 bytes

Concurrency Level:      10
Time taken for tests:   1.498 seconds
Complete requests:      100
Failed requests:        0
Total transferred:      5877500 bytes
HTML transferred:       5843300 bytes
Requests per second:    66.74 [#/sec] (mean)
Time per request:       149.840 [ms] (mean)
Time per request:       14.984 [ms] (mean, across all concurrent requests)
Transfer rate:          3830.58 [Kbytes/sec] received

Connection Times (ms)
              min  mean[+/-sd] median   max
Connect:       12  110 295.2     12    1012
Processing:    37   38   0.5     38      39
Waiting:       12   13   0.3     13      15
Total:         49  147 295.4     50    1051

Percentage of the requests served within a certain time (ms)
  50%     50
  66%     50
  75%     50
  80%     50
  90%    816
  95%   1050
  98%   1051
  99%   1051
 100%   1051 (longest request)

플래그로 Apache 조직 웹 사이트 테스트

이제 플래그를 사용하여 Apache 조직 웹 사이트를 테스트 해 보겠습니다.

$ ab -l -r -n 100 -c 10 -k -H "Accept-Encoding: gzip, deflate"  http://www.apache.org/

산출

...
Document Length:        Variable

Concurrency Level:      10
Time taken for tests:   0.357 seconds
Complete requests:      100
Failed requests:        0
Keep-Alive requests:    100
Total transferred:      1358510 bytes
HTML transferred:       1317700 bytes
Requests per second:    280.28 [#/sec] (mean)
Time per request:       35.678 [ms] (mean)
Time per request:       3.568 [ms] (mean, across all concurrent requests)
Transfer rate:          3718.41 [Kbytes/sec] received

Connection Times (ms)
              min  mean[+/-sd] median   max
Connect:        0    1   3.7      0      12
Processing:    14   17  21.3     15     227
Waiting:       14   17  21.3     14     227
Total:         14   18  21.5     15     227

Percentage of the requests served within a certain time (ms)
  50%     15
  66%     15
  75%     15
  80%     15
  90%     27
  95%     28
  98%     29
  99%    227
 100%    227 (longest request)

플래그를 사용하여 초당 요청이 어떻게 증가했는지 간단히 확인할 수 있습니다. 즉석의 경우 특히-H "Accept-Encoding: gzip,이 플래그는 Apache 서버가 gzipped 체재.

Apache Bench 결과 고려

Apache Bench 결과와 관련하여 몇 가지 중요한 사항을 고려해야합니다. 이를 통해 애플리케이션의 병목 현상을 제거하고 성능을 개선하기위한 전반적인 전략을 설계 할 수 있습니다.

초당 요청이 필요합니다. 이를 통해 웹 서버 설정이 얼마나 잘 작동하는지 알 수 있습니다. 숫자가 클수록 성능이 향상됩니다. 그런 다음 연결 시간 (ms)과 서비스 요청 비율이 나옵니다. 이러한 메트릭을 원하는 성능으로 변경하려면 웹 서버의 설정을 조정해야 할 수 있습니다.

Apache 또는 사용 된 웹 서버 오류 로그 또는 (일반) 로그에 오류가 있는지 확인하십시오. 부하가 증가함에 따라 상황이 질식하기 시작합니다. 메모리 문제가 발생하기 시작합니다. 많은 파이썬 스크립트는 동시성을 염두에두고 작성되지 않으면 충돌을 시작합니다.

웹 서버가 충돌 및 / 또는 시간 초과되는 임계 동시성 값이 무엇인지 알아야합니다. 일반적으로 이것은 상당히 높은 동시성 수준에서 발생합니다. 이 값이 낮 으면 문제가있는 것이므로이 설정을 더 낮게 / 높게 조정해야합니다.

결론

이 튜토리얼에서 우리는 Apache Bench를 사용하여 웹 사이트 또는 웹 애플리케이션을로드 테스트하는 방법을 배웠습니다. Apache Bench는 병목 현상을 줄이고 성능을 높이기 위해 웹 애플리케이션 서버 설정을 개선하는 방법을 결정하는 데 매우 유용한 도구가 될 수 있습니다. 이제 Apache Bench의 기본 사용법에 익숙해 졌으므로 다양한 시나리오에서 애플리케이션의 성능을 측정하기위한 새로운 테스트 계획을 작성하여 시작할 수 있습니다.