샘플 애플리케이션 테스트

이전 장에서 우리는 제 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 앱의 프로덕션 서버로 적합하다는 것을 의미합니다.