एकाधिक URL का समवर्ती परीक्षण करना

इस अध्याय में, हम सीखेंगे कि एक से अधिक 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)

एक सरल शैल स्क्रिप्ट बनाना

आप एक शेल स्क्रिप्ट बनाकर ऐसा कर सकते हैं, जिसमें कई एब कॉल हैं। एक फ़ाइल 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

पुनरावृत्ति और स्पष्टता के उद्देश्य से बचने के लिए, हम एब आउटपुट के केवल प्रासंगिक को दर्शाएंगे, यह इंगित करते हुए कि किस भाग को छोड़ दिया गया है, निम्नानुसार।

उत्पादन

.
.
.
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.
.
.
.

शेल स्क्रिप्ट एक फ़ाइल के लिए अपाचे बेंच आउटपुट को बचाने के लिए

आप एकाधिक स्क्रिप्ट के साथ शेल स्क्रिप्ट बनाकर फाइल करने के लिए अपाचे बेंच आउटपुट को सेव कर सकते हैं। प्रत्येक पंक्ति के अंत में, a&;यह पृष्ठभूमि में कमांड चलाता है, और अगले कमांड को इसका निष्पादन शुरू करने देता है। आप <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.txt तथा test2.txt आउटपुट डेटा को सहेजने के लिए फ़ाइलें हैं।

आप जांच सकते हैं कि उपरोक्त स्क्रिप्ट ने दो फाइलें बनाई हैं, test1.txt और test2.txt जिसमें संबंधित URL के लिए ab आउटपुट शामिल है -

$ 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
...

वॉच-आउट स्थिति

एब का उपयोग करते समय, आपको चेतावनी के बिना असफल परीक्षण के लिए सतर्क होना चाहिए। उदाहरण के लिए, यदि आप एक गलत 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)