Ab: Difference between revisions

From ICO wiki
Jump to navigationJump to search
Taliiv (talk | contribs)
No edit summary
Taliiv (talk | contribs)
No edit summary
Line 1: Line 1:
kirjutab Tambet Liiv A22 -2011
=Mis on Ab?=
Ab on Apache HTTP serveri reeperporgramm (''benchmarking tool''). See on loodud sellejaoks, et anda ülevaade hetkelisest Apache installatsiooni tomimimisest. Selle programmi peaülesanne on näidata palju päringuid sekundis see Apache server on võimeline ära täitma.
=Ab erinevad võimalused=
'''<nowiki>ab [ -A kasutajanimi:parool ] [ -c päringute_arv ] [ -C küpsise_nimi=väärtus ] [ -d ] [ -e csv-fail ] [ -g gnuplot-fail ] [ -h ] [ -H kohaldatud_päis ] [ -i ] [ -k ] [ -n päringute_arv ] [ -p POST-fail ] [ -P proksi-kasutajanimi:parool ] [ -q ] [ -s ] [ -S ] [ -t ajapiirang ] [ -T sisu_tüüp ] [ -v verbosity] [ -V ] [ -w ] [ -x <table>-atribuudid ] [ -X proksi[:port] ] [ -y <tr>-atribuudid ] [ -z <td>-atribuudid ] [http://]hostinimi[:port]/rada</nowiki>'''
<br />
*'''-A kasutajanimi:parool''' - <nowiki>Saab anda ette BASIC mandaadid. Kasutajanimi ja parool on eraldatud ühe kooloniga (:) ning saadedaks ''base64'' kodeeringus. See sõne saadetakse isegi siis kui kasutaja sellist argumenti ära ei määra.</nowiki>
*'''-c päringute_arv''' - Saab ette anda mitu päringut korraga saadetakse. Vaikimisi on üks päring korraga.
*'''-C küpsise_nimi=väärtus''' - Lisa küpsise rida päringule. Selle argumendi formaat on tavaliselt nimi=väärtus. Seda atribuuti on võimalik mitu seada.
*'''-d''' - Mitte näidata ''percentage served within XX [ms] table''. Pärandsüsteemide toeks.
*'''-e csv-fail''' - Kirjutab CSV faili, mis sisaldab palju kulus iga individuaalse protsendi (1-100%) päringute täitmiseks aega (millisekundites).
*'''-g gnuplot-fail''' - Kirjutab kõik mõõdetud tulemused ''gnuplot'' ehk TSV (väärtused tabeldamisega eraldatud) faili. Seda faili on väga lihtne importida erinevatesse programmidesse nagu Gnuplot, IDL, Mathematica, Igor või isegi Excel. Veergude pealkirjad on iga rea alguses.
*'''-h''' - Näitab kasutus informatsiooni.
*'''-H kohaldatud_päis''' - Lisab juurde päiseid. See argument tavaliselt lisatakse valiidse HTTP päisena sisaldades kooloniga eraldatud välja-väärtuse paari (näiteks: "Accept-Encoding: zip/zop;8bit").
*'''-i''' - GET päringu asemel tehakse HEAD päringuid.
*'''-k''' - Võimaldab HoiaElus (''KeepAlive'') funktsiooni (Näiteks teeb mitu päringut samas HTTP sessioonis). Vaikimisi ei ole see võimaldatud.
*'''-n päringute_arv''' - Mitu päringut tehakse selle reeperdamissessiooni vältel. Vaikimisi on ainult üks päring, mis ei anna täielikku ülevaadet serveri jõudlusest.
*'''-p POST-fail''' - POST päringuga saadetavate andmete fail.
*'''-P proksi-kasutajanimi:parool''' - Saab anda ette vajalikud BASIC mandaadid proksi jaoks. Kasutajanimi ja parool on eraldatud ühe kooloniga (:) ning saadedaks base64 kodeeringus. See sõne saadetakse isegi siis kui kasutaja sellist argumenti ära ei määra.
*'''-q'''' - Kui töödeldakse rohkem kui 150 päringut siis ab väljastab edenemisnäidu ''stderr''<nowiki>'i</nowiki> iga 10% pärigute kohta. -q lipp keelab need teated ära.
*'''-s''' - Kasutab tavalise HTTP asemel HTTPS (SSL) protokolli. See lisa on eksperimentaalne ja väga rudimentaarne. Soovitavalt mitte kasutada.
*'''-S''' - Ei kuva mediaani ega standarthälvet ega kuva hoiatus/veateateid kui keskmine ja mediaan erinevad rohekm kui kaks standardhälvet. Pärandsüsteemide toeks.
*'''-t ajapiirang''' - Maksimaalne aeg (sekundites) mis kulutatakse reeperdamissessiooni läbiviimiseks. See implementeerib -n 50000. Seda kasutatakse kui reeperdamine on vaja ära teha mingis kindlas ajavahemikus. Vaikimisi siis ajapiirangut pole seatud.
*'''-T sisutüüp''' - POST andmete päise sisutüüp.
*'''-v infotase''' - Määrab palju programm oma tööst teada annab. 4 - prindib informatsiooni päiste kohta. 3 ja kõrgem - prindib veakoodid (404, 200 jne). 2 ja kõrgem - prindib hoiatused ja muu info.
*'''-V''' - Näitab versiooni ja väljub programmist.
*'''-w''' - Väljastab tulemused HTML tabelitesse. Vaikimisi tabel on kaks veergu lai ning valge tagataustaga.
*'''-x <nowiki><table></nowiki>-atribuudid''' - Sõne mida kasutatakse tabeli atribuutitena. Need sisestatakse <nowiki><table siia ></nowiki>
*'''-X proksi[:port]''' - Määrab proksiserveri ja selle pordi.
*'''-y <nowiki><tr></nowiki>-atribuudid''' - Sõne <nowiki><tr></nowiki> atribuutideks.
*'''-z <nowiki><td></nowiki>-atribuudid''' - Sõne <nowiki><td></nowiki> atribuutideks.


=Installeerimine=
Ab'd üksiku pakettina installeerida ei saa, kuid ta sisaldub pakis ''apache2-utils''.
<pre>sudo apt-get install apache2-utils</pre>
Samuti tuleb ab ka kaasa, kui installeerida Apache veebiserver.
<pre>sudo apt-get install apache2</pre>
=Näited=
Kõik toodud näited on teostatud Ubuntu Server 11.10 (32-bit) operatsioonisüsteemiga.
Jooksutame ab'd neti.ee veebiserveri vastu päringuid tegema. Seame argumendid nii et tehakse 100 päringut ja korraga 5 päringut.
<pre>ab -n 100 -c 5 http://www.neti.ee/</pre>
Tulemuseks saame sellised andmed:
<pre>This is ApacheBench, Version 2.3 <$Revision: 655654 $>
Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/
Licensed to The Apache Software Foundation, http://www.apache.org/
Benchmarking www.neti.ee (be patient).....done
Server Software:        Apache
Server Hostname:        www.neti.ee
Server Port:            80
Document Path:          /
Document Length:        38830 bytes
Concurrency Level:      5
Time taken for tests:  9.193 seconds
Complete requests:      100
Failed requests:        0
Write errors:          0
Total transferred:      3914000 bytes
HTML transferred:      3883000 bytes
Requests per second:    10.88 [#/sec] (mean)
Time per request:      459.671 [ms] (mean)
Time per request:      91.934 [ms] (mean, across all concurrent requests)
Transfer rate:          415.76 [Kbytes/sec] received
Connection Times (ms)
              min  mean[+/-sd] median  max
Connect:      23  42  11.9    42      75
Processing:  220  411 152.2    362    1026
Waiting:      26  49  18.3    46    165
Total:        263  452 152.7    406    1065
Percentage of the requests served within a certain time (ms)
  50%    406
  66%    474
  75%    503
  80%    523
  90%    683
  95%    771
  98%  1017
  99%  1065
100%  1065 (longest request)</pre>
Tulemuseks näitab, et keskmine päringu täitmise aeg oli 452 ms +- 152.7 usaldusväärsusega.
Kõige pikem vastamise aeg oli 1065 ms.
Alati peab olema ettevaatlik kui on tegemist veebiserveriga mida ei oma, kuna seda võib lugeda DDoS rünnakuks (palju päringuid samalt kliendilt).
=Kasutatud kirjandus=
http://stackoverflow.com/questions/66606/what-package-includes-ab-the-apache-server-benchmarking-tool-in-ubuntu
http://www.php-developer.org/apachebench-tutorial-ab-testing-tool-example-in-ubuntu-lucid-lynx/
=Autor=
Tambet Liiv
A22
2011
[[Category:Operatsioonisüsteemide administreerimine ja sidumine]]
[[Category:Operatsioonisüsteemide administreerimine ja sidumine]]

Revision as of 17:06, 24 November 2011

Mis on Ab?

Ab on Apache HTTP serveri reeperporgramm (benchmarking tool). See on loodud sellejaoks, et anda ülevaade hetkelisest Apache installatsiooni tomimimisest. Selle programmi peaülesanne on näidata palju päringuid sekundis see Apache server on võimeline ära täitma.

Ab erinevad võimalused

ab [ -A kasutajanimi:parool ] [ -c päringute_arv ] [ -C küpsise_nimi=väärtus ] [ -d ] [ -e csv-fail ] [ -g gnuplot-fail ] [ -h ] [ -H kohaldatud_päis ] [ -i ] [ -k ] [ -n päringute_arv ] [ -p POST-fail ] [ -P proksi-kasutajanimi:parool ] [ -q ] [ -s ] [ -S ] [ -t ajapiirang ] [ -T sisu_tüüp ] [ -v verbosity] [ -V ] [ -w ] [ -x <table>-atribuudid ] [ -X proksi[:port] ] [ -y <tr>-atribuudid ] [ -z <td>-atribuudid ] [http://]hostinimi[:port]/rada

  • -A kasutajanimi:parool - Saab anda ette BASIC mandaadid. Kasutajanimi ja parool on eraldatud ühe kooloniga (:) ning saadedaks ''base64'' kodeeringus. See sõne saadetakse isegi siis kui kasutaja sellist argumenti ära ei määra.
  • -c päringute_arv - Saab ette anda mitu päringut korraga saadetakse. Vaikimisi on üks päring korraga.
  • -C küpsise_nimi=väärtus - Lisa küpsise rida päringule. Selle argumendi formaat on tavaliselt nimi=väärtus. Seda atribuuti on võimalik mitu seada.
  • -d - Mitte näidata percentage served within XX [ms] table. Pärandsüsteemide toeks.
  • -e csv-fail - Kirjutab CSV faili, mis sisaldab palju kulus iga individuaalse protsendi (1-100%) päringute täitmiseks aega (millisekundites).
  • -g gnuplot-fail - Kirjutab kõik mõõdetud tulemused gnuplot ehk TSV (väärtused tabeldamisega eraldatud) faili. Seda faili on väga lihtne importida erinevatesse programmidesse nagu Gnuplot, IDL, Mathematica, Igor või isegi Excel. Veergude pealkirjad on iga rea alguses.
  • -h - Näitab kasutus informatsiooni.
  • -H kohaldatud_päis - Lisab juurde päiseid. See argument tavaliselt lisatakse valiidse HTTP päisena sisaldades kooloniga eraldatud välja-väärtuse paari (näiteks: "Accept-Encoding: zip/zop;8bit").
  • -i - GET päringu asemel tehakse HEAD päringuid.
  • -k - Võimaldab HoiaElus (KeepAlive) funktsiooni (Näiteks teeb mitu päringut samas HTTP sessioonis). Vaikimisi ei ole see võimaldatud.
  • -n päringute_arv - Mitu päringut tehakse selle reeperdamissessiooni vältel. Vaikimisi on ainult üks päring, mis ei anna täielikku ülevaadet serveri jõudlusest.
  • -p POST-fail - POST päringuga saadetavate andmete fail.
  • -P proksi-kasutajanimi:parool - Saab anda ette vajalikud BASIC mandaadid proksi jaoks. Kasutajanimi ja parool on eraldatud ühe kooloniga (:) ning saadedaks base64 kodeeringus. See sõne saadetakse isegi siis kui kasutaja sellist argumenti ära ei määra.
  • -q' - Kui töödeldakse rohkem kui 150 päringut siis ab väljastab edenemisnäidu stderr'i iga 10% pärigute kohta. -q lipp keelab need teated ära.
  • -s - Kasutab tavalise HTTP asemel HTTPS (SSL) protokolli. See lisa on eksperimentaalne ja väga rudimentaarne. Soovitavalt mitte kasutada.
  • -S - Ei kuva mediaani ega standarthälvet ega kuva hoiatus/veateateid kui keskmine ja mediaan erinevad rohekm kui kaks standardhälvet. Pärandsüsteemide toeks.
  • -t ajapiirang - Maksimaalne aeg (sekundites) mis kulutatakse reeperdamissessiooni läbiviimiseks. See implementeerib -n 50000. Seda kasutatakse kui reeperdamine on vaja ära teha mingis kindlas ajavahemikus. Vaikimisi siis ajapiirangut pole seatud.
  • -T sisutüüp - POST andmete päise sisutüüp.
  • -v infotase - Määrab palju programm oma tööst teada annab. 4 - prindib informatsiooni päiste kohta. 3 ja kõrgem - prindib veakoodid (404, 200 jne). 2 ja kõrgem - prindib hoiatused ja muu info.
  • -V - Näitab versiooni ja väljub programmist.
  • -w - Väljastab tulemused HTML tabelitesse. Vaikimisi tabel on kaks veergu lai ning valge tagataustaga.
  • -x <table>-atribuudid - Sõne mida kasutatakse tabeli atribuutitena. Need sisestatakse <table siia >
  • -X proksi[:port] - Määrab proksiserveri ja selle pordi.
  • -y <tr>-atribuudid - Sõne <tr> atribuutideks.
  • -z <td>-atribuudid - Sõne <td> atribuutideks.

Installeerimine

Ab'd üksiku pakettina installeerida ei saa, kuid ta sisaldub pakis apache2-utils.

sudo apt-get install apache2-utils

Samuti tuleb ab ka kaasa, kui installeerida Apache veebiserver.

sudo apt-get install apache2

Näited

Kõik toodud näited on teostatud Ubuntu Server 11.10 (32-bit) operatsioonisüsteemiga.

Jooksutame ab'd neti.ee veebiserveri vastu päringuid tegema. Seame argumendid nii et tehakse 100 päringut ja korraga 5 päringut.

ab -n 100 -c 5 http://www.neti.ee/

Tulemuseks saame sellised andmed:

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

Benchmarking www.neti.ee (be patient).....done


Server Software:        Apache
Server Hostname:        www.neti.ee
Server Port:            80

Document Path:          /
Document Length:        38830 bytes

Concurrency Level:      5
Time taken for tests:   9.193 seconds
Complete requests:      100
Failed requests:        0
Write errors:           0
Total transferred:      3914000 bytes
HTML transferred:       3883000 bytes
Requests per second:    10.88 [#/sec] (mean)
Time per request:       459.671 [ms] (mean)
Time per request:       91.934 [ms] (mean, across all concurrent requests)
Transfer rate:          415.76 [Kbytes/sec] received

Connection Times (ms)
              min  mean[+/-sd] median   max
Connect:       23   42  11.9     42      75
Processing:   220  411 152.2    362    1026
Waiting:       26   49  18.3     46     165
Total:        263  452 152.7    406    1065

Percentage of the requests served within a certain time (ms)
  50%    406
  66%    474
  75%    503
  80%    523
  90%    683
  95%    771
  98%   1017
  99%   1065
 100%   1065 (longest request)

Tulemuseks näitab, et keskmine päringu täitmise aeg oli 452 ms +- 152.7 usaldusväärsusega. Kõige pikem vastamise aeg oli 1065 ms.

Alati peab olema ettevaatlik kui on tegemist veebiserveriga mida ei oma, kuna seda võib lugeda DDoS rünnakuks (palju päringuid samalt kliendilt).

Kasutatud kirjandus

http://stackoverflow.com/questions/66606/what-package-includes-ab-the-apache-server-benchmarking-tool-in-ubuntu

http://www.php-developer.org/apachebench-tutorial-ab-testing-tool-example-in-ubuntu-lucid-lynx/

Autor

Tambet Liiv A22 2011