हमारे नमूना आवेदन परीक्षण

पिछले अध्याय में, हमने अपाचे बेंच के मूल उपयोग को तीसरे पक्ष की वेबसाइट का परीक्षण करने के लिए समझा। इस अनुभाग में, हम इस टूल का उपयोग अपने स्वयं के सर्वर पर वेब एप्लिकेशन का परीक्षण करने के लिए करेंगे। ट्यूटोरियल को संभव हद तक आत्म-निहित रखने के लिए, हमने प्रदर्शन उद्देश्य के लिए एक अजगर आवेदन स्थापित करने के लिए चुना है; आप अपनी विशेषज्ञता के स्तर के आधार पर PHP या रूबी जैसी कोई अन्य भाषा चुन सकते हैं।

पायथन की स्थापना

आमतौर पर, लिनक्स सर्वर पर डिफ़ॉल्ट रूप से पायथन स्थापित होता है।

बोतल फ्रेमवर्क स्थापित करना और एक सरल अनुप्रयोग बनाना

बोतल एक माइक्रो-फ्रेमवर्क है जिसे वेब एप्लिकेशन बनाने के लिए अजगर में लिखा गया है, और पाइप एक अजगर पैकेज मैनेजर है। बोतल स्थापित करने के लिए टर्मिनल में निम्नलिखित कमांड टाइप करें -

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

आइए अब हम एक छोटा बॉटल एप्लिकेशन बनाते हैं। उसके लिए, एक निर्देशिका बनाएं और उसके अंदर जाएं -

$ mkdir webapp
$ cd webapp

हम एक नई अजगर स्क्रिप्ट बनाएंगे, app.py, वेब निर्देशिका के अंदर -

$ 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 रिक्वेस्ट का ठीक से जवाब दे रहा है तो हमें चेक करें। चूंकि यह टर्मिनल बॉटल एप्लिकेशन की सेवा लिए बिना कोई इनपुट नहीं ले सकता, इसलिए हमें दूसरे वीपीएन के साथ अपने वीपीएस में लॉगिन करना होगा। दूसरे टर्मिनल के साथ VPS में लॉग इन करने के बाद, आप नए टर्मिनल में निम्न कोड लिखकर अपने एप्लिकेशन पर नेविगेट कर सकते हैं।

$ lynx http://localhost:8080/

लिंक्स एक कमांड लाइन ब्राउज़र है और आमतौर पर डिबियन और उबंटू जैसे विभिन्न लिनक्स वितरणों में डिफ़ॉल्ट रूप से स्थापित होता है। यदि आप निम्नलिखित आउटपुट देखते हैं, तो इसका मतलब है कि आपका ऐप ठीक काम कर रहा है।

Output

यदि आप उपरोक्त आउटपुट देखते हैं, तो इसका मतलब है कि हमारा एप्लिकेशन लाइव है और परीक्षण के लिए तैयार है।

विकास वेब सर्वर के साथ अनुप्रयोग का परीक्षण

कृपया ध्यान दें कि एब में एक बग है, और यह स्थानीयहोस्ट पर एप्लिकेशन का परीक्षण करने में सक्षम नहीं है। इसलिए हम लोकलहोस्ट से ऐप्पलॉक फ़ाइल में 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 के पिछले परीक्षणों में, हमने बॉटल फ्रेमवर्क में बंडल किए गए डिफ़ॉल्ट वेब सर्वर का उपयोग किया है।

अब हम बहु-थ्रेडेड एकल-थ्रेडेड डिफ़ॉल्ट वेब सर्वर को बदल देंगे। इसलिए, आइए हम एक बहु-थ्रेडेड वेब सर्वर लाइब्रेरी स्थापित करें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 तक कैसे बढ़ा। इसका मतलब है कि python ऐप्स के लिए उत्पादन सर्वर के रूप में gunicorn उपयुक्त है।