गतिशील पृष्ठों के परीक्षण की तैयारी

इस अध्याय में, हम गतिशील पृष्ठों के परीक्षण के लिए आवश्यक तैयारी को समझेंगे। सर्वर-साइड डायनामिक वेब पेज एक वेब पेज है, जिसका निर्माण एक एप्लिकेशन सर्वर प्रोसेसिंग सर्वर-साइड स्क्रिप्ट द्वारा नियंत्रित किया जाता है। अपाचे बेंच केवल सर्वर-साइड डायनामिक वेब पेज का परीक्षण लोड कर सकती है।

सम्‍मिलन स्तर और अनुरोधों की कुल संख्या

सम्‍मिलन स्तर कुल अनुरोधों की तुलना में कम होना चाहिए।

$ 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

झंडे का उपयोग

इस खंड में, हम एब कमांड के साथ कुछ महत्वपूर्ण झंडे के उपयोग का वर्णन करेंगे। हम शब्द, विकल्प और झंडे का उपयोग करेंगे, परस्पर विनिमय।

Verbose -v

कई विकल्प विफल अनुरोध मौजूद होने पर विश्लेषण और डिबग करने के लिए क्रिया विकल्प का उपयोग किया जा सकता है। लोड परीक्षण की विफलता का एक सामान्य संकेत यह है कि परीक्षण बहुत तेजी से समाप्त होता है और यह प्रति सेकंड मूल्य के अनुरोध के लिए एक अच्छी संख्या देता है। लेकिन यह एक गलत बेंचमार्क होगा। सफलता या विफलता की पहचान करने के लिए, आप इसका उपयोग कर सकते हैं-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विकल्प। हम जल्द ही गैर-200 HTTP देखेंगे जब हम बाद के अध्यायों में एक web2py एप्लिकेशन लॉन्च करेंगे।

जीवित रखना -क

जब क्लाइंट HTTP अनुरोध भेजता है, तो कनेक्शन सर्वर से किया जाता है, सर्वर प्रतिक्रिया भेजता है, और अनुरोध भेजने के बाद कनेक्शन बंद हो जाता है। यह चक्र प्रत्येक अनुरोध के साथ जारी है। हालाँकि, साथ-साथ रहने वाली सेटिंग (लगातार कनेक्शन के रूप में भी जाना जाता है), क्लाइंट कई अनुरोधों और प्रतिक्रिया को सुविधाजनक बनाने के लिए एक अंतर्निहित टीसीपी कनेक्शन को बनाए रखता है; यह धीमा और महंगा कनेक्शन आरंभीकरण समय को समाप्त करता है जो अन्यथा मौजूद होगा।

चर दस्तावेज़ लंबाई -l

यदि वेब पेज परिवर्तनशील लंबाई का है, तो आपको विकल्प का उपयोग करना चाहिए -l। यदि प्रतिक्रियाओं की लंबाई स्थिर नहीं है, तो अपाचे बेंच त्रुटियों की रिपोर्ट नहीं करती है। यह गतिशील पृष्ठों के लिए उपयोगी हो सकता है।

विकल्प -r का उपयोग

कैसे त्रुटियों को प्राप्त करने पर बाहर निकलने के लिए मजबूर नहीं करें? आपको विकल्प का उपयोग करना चाहिए-r। इस विकल्प के बिना, जैसे ही कोई अनुरोध सॉकेट त्रुटि से टकराता है, आपका परीक्षण टूट सकता है। हालांकि, इस विकल्प के साथ, त्रुटियों को विफल होने वाली शीर्षकों में रिपोर्ट किया जाएगा, लेकिन परीक्षण अंत तक जारी रहेगा।

विकल्प का उपयोग -H

इस विकल्प का उपयोग मनमाने हेडर लाइन को जोड़ने के लिए किया जाता है। तर्क आम तौर पर एक वैध हेडर लाइन के रूप में होता है, जिसमें एक बृहदान्त्र-पृथक फ़ील्ड-वैल्यू पेयर होता है (जैसे, "स्वीकार-एनकोडिंग: ज़िप / ज़िप; 8 बिट")।

विकल्प -सी का उपयोग

निम्नलिखित अनुभाग में, हम विस्तार से जानेंगे कि कुकी मूल्य का उपयोग करने के विकल्प के साथ संयोजन में उपरोक्त विकल्पों का उपयोग कैसे किया जाता है, अर्थात। -Cविकल्प। -सी विकल्प आम तौर पर ए के रूप में होता हैname = valueजोड़ी। इस क्षेत्र को दोहराया जा सकता है।

अपाचे बेंच के साथ सेशन कुकी का उपयोग करना

अपाचे बेंच के साथ कुकी का उपयोग कैसे करें, यह समझने के लिए, हमें एक वेब पेज की आवश्यकता है जो कुकी को सेट करने की कोशिश करता है। एक बहुत अच्छा उदाहरण web2py अनुप्रयोग है जो एक अजगर वेब फ्रेमवर्क है।

Web2py स्थापित करना

हम जल्दी से एक और अजगर ऐप web2py स्थापित करने जा रहे हैं। आप Web2py फ्रेमवर्क ओवरव्यू पर इसका उपयोग करने के तरीके के बारे में अधिक पढ़ सकते हैं ।

पाइथन आमतौर पर उबंटू और डेबियन सर्वर पर डिफ़ॉल्ट रूप से स्थापित होता है। इसलिए, web2py को सफलतापूर्वक चलाने के लिए एक आवश्यकता पहले से ही पूरी होती है।

हालाँकि, हमें ज़िप फ़ाइल से web2py के स्रोत फ़ाइलों को निकालने के लिए अनज़िप पैकेज स्थापित करने की आवश्यकता है जिसे हम डाउनलोड करेंगे -

$ 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 सर्वर को रोकने के लिए, आप कमांड किल -SIGTERM <PID> डाल सकते हैं, जहां <PID> web2py सर्वर के लिए प्रक्रिया आईडी है, जो इस मामले में है 23,904।

वेब कुकी से सत्र कुकी

यदि कोई पेज केवल लॉग इन उपयोगकर्ता द्वारा ही एक्सेस किया जाता है, लॉगिन पेज से सीधे एक्सेस नहीं किया जाता है, तो उस स्थिति में आप उपयोग कर सकते हैं -Cझंडा। यह ध्वज ab कमांड के लिए कुकी को परिभाषित करता है। लेकिन आपको एक मान्य सत्र से सत्र पहचानकर्ता कुकी का मूल्य प्राप्त करना होगा। कैसे प्राप्त करें? विभिन्न ऑनलाइन ट्यूटोरियल आपको क्रोम (या मोज़िला) ब्राउज़र डेवलपर टूल की ओर मार्गदर्शन करेंगे। लेकिन हमारे परीक्षण के मामले में, चूंकि एप्लिकेशन केवल कमांड लाइन पर उपलब्ध है, हम मूल्य प्राप्त करने के लिए lynx ब्राउज़र का उपयोग करेंगे।

हमें पहले एक सत्र का कुकी मान मिलता है। एक और टर्मिनल खोलें और निम्न कमांड टाइप करें -

$ lynx http://127.0.0.1:8000/

उपरोक्त कमांड के जवाब में, lynx वेब 2py सर्वर से कुकी को स्वीकार करने की आपकी अनुमति मांगेगा जैसा कि नीचे दी गई छवि में दिखाया गया है।

टाइप करने से पहले कुकी मान को नोट करें yकुकी को स्वीकार करने के लिए। अब टर्मिनल निम्नलिखित छवि के समान होगा - टर्मिनल पर वेबसाइट!

कुकी मान प्राप्त करने के बाद, हम अब एब परीक्षण चलाएंगे। उसके लिए, हमें तीसरा टर्मिनल खोलना होगा (नीचे दी गई छवि देखें) -

अब, तीसरे टर्मिनल में -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 रॉकेट वेब सर्वर का उपयोग करता है। हम यह भी ध्यान देते हैं कि हमें आउटपुट में पहले से चर्चा किए गए शीर्षकों के अलावा 'गैर -2xx प्रतिक्रियाएं' मिल रही हैं। सामान्य तौर पर, Http प्रोटोकॉल एक प्रतिक्रिया कोड का उपयोग करके अनुरोध का जवाब देता है, और 200 के दशक की सीमा के भीतर कुछ भी 'ठीक है' का अर्थ है, और बाकी कुछ समस्या से मेल खाता है। उदाहरण के लिए, 400 संसाधन से संबंधित त्रुटियां हैं जैसे कि 404 फाइल नॉट फाउंड। 500s सर्वर त्रुटियों के अनुरूप हैं। हमारे तत्काल मामले में, जब हम -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। एक बहुत बड़ा अंतर है।

Timelimit विकल्प का उपयोग करना

आम तौर पर, टाइमलीमिट विकल्प एक मुश्किल है। आइए इसे एब के मैनुअल से समझते हैं , जो काफी व्याख्यात्मक है -

-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 अनुरोधों तक जारी है। हालाँकि, जैसे ही अनुरोधों को बहुत तेजी से संभाला गया था, तत्काल मामले में 50 सेकंड के भीतर - जैसे ही 22k सेकंड (परीक्षणों के लिए लिया जाने वाला समय लग रहा है) प्राप्त होते ही ab को समाप्त कर दिया गया।

आप एक ही कमांड की जगह परीक्षण कर सकते हैं http://127.0.0.1:8000/ साथ में http://127.0.0.1:8000/admin (यह मानते हुए कि यह हमारी वेब 2 सी एप्लीकेशन है) या https://www.apache.org/ जैसी थर्ड पार्टी वेबसाइट है, जो आंकड़ों में अंतर को नोटिस करती है।

लोड टेस्ट करने से पहले चेकलिस्ट

कुछ जाँचें हैं जो आपको सफलतापूर्वक परीक्षण चलाने में मदद करेंगी, और प्रदर्शन को सही तरीके से मापेंगी। लोड टेस्ट करने से पहले निम्नलिखित शर्तों पर विचार करें -

  • सुनिश्चित करें कि कोई अतिरिक्त अजगर मॉड्यूल लोड नहीं किया गया है।

  • टीसीपी / आईपी पोर्ट थकावट से बचने के लिए, आपको आमतौर पर किसी अन्य एब परीक्षण में जाने से पहले 2-3 मिनट इंतजार करना चाहिए।

  • सुनिश्चित करें कि अपाचे वर्कर थ्रेड्स की तुलना में समवर्ती कनेक्शन की संख्या कम है।

  • Apache या python क्रैश होने पर आपको दूसरा टेस्ट करने से पहले सर्वर को रिबूट करना चाहिए।