Tsung使用總結(jié)

Tsung

Tsung的壓測(cè)模式和JMeter等常見壓測(cè)工具是不一樣的。Tsung屬于"open system model" ,算是一種"open-ended load testing tools" , 并且和"Yandex. Tank"一樣,屬于"hit-based mode"形式。它的很多概念和JMeter等常見的壓測(cè)工具不一樣。另外提一點(diǎn),Gatling缺省是"closed model"的,可以使用repeat和during實(shí)現(xiàn)"open-ended load testing"。當(dāng)用JMeter這樣的"closed-ended"壓測(cè)工具打壓很高的壓力時(shí),就得增加非常多的slave加壓機(jī)器。Tsung這種"open-ended"型的壓測(cè)工具,往往單機(jī)就能打壓較高的壓力。在測(cè)試資源受限時(shí),Tsung是較好的選擇。

基礎(chǔ)概念

Tsung的一些基礎(chǔ)概念:

  • Tsung的每一個(gè)虛擬用戶就是一個(gè)erlang的輕量進(jìn)程。
  • 虛擬用戶完成session后就消失。
  • 每個(gè)cpu都會(huì)產(chǎn)生一個(gè)erlang虛擬機(jī)用來發(fā)揮多CPU的優(yōu)勢(shì)
  • 大量的虛擬用戶(erlang輕量進(jìn)程)建立在erlangVM上
  • 一臺(tái)測(cè)試機(jī)可以啟多個(gè)erlangVM,目前按照1個(gè)cpu啟動(dòng)1個(gè)erlangVM
  • 每個(gè)虛擬機(jī)下有很多user,每個(gè)user可以產(chǎn)生很多session,一個(gè)session由很多request組成

集群

Tsung 的集群測(cè)試使用十分簡(jiǎn)單,只需要在主節(jié)點(diǎn)上執(zhí)行操作,所有從節(jié)點(diǎn)會(huì)自動(dòng)執(zhí)行,不用去干預(yù)。只涉及到打通主從節(jié)點(diǎn)的通訊問題(基于Erlang的通訊)。如果基于 SSH 的免密鑰方式,很容易出現(xiàn)問題,可以使用 tsung_rsh,也要在主節(jié)點(diǎn)上修改 tsung.xml 的client段配置。要注意兩點(diǎn):

  • 如果要修改監(jiān)聽端口,默認(rèn)值是19999,那也要同時(shí)修改rsh_client.sh的PORT值
  • 內(nèi)網(wǎng)和各機(jī)器要開放 19999 端口

可以采用以下方式驗(yàn)證主從節(jié)點(diǎn)之間的通訊。將 remotehost 分別修改為從機(jī)進(jìn)行測(cè)試。如果返回 {ok,bar@remotehost} ,則說明通訊沒有問題。

erl -rsh /otp/apps/tsung_rsh/rsh_client.sh -sname foo -setcookie mycookie
(foo@myhostname)1>slave:start(remotehost, bar, "-setcookie mycookie").

相關(guān)命令

運(yùn)行腳本:

tsung -s -f users_load.xml start

運(yùn)時(shí)時(shí)動(dòng)態(tài)報(bào)表:

http://master-ip:8091

結(jié)束后生成報(bào)表并查看:

tsung_stats.pl && python -m SimpleHTTPServer 
http://master-ip:8000

多次結(jié)果比較:

tsplot "First test" firsttest/tsung.log "Second test" secondtest/tsung.log -d outputdir

用戶設(shè)置策略

  • arrivalrate:時(shí)間單位內(nèi)產(chǎn)生多少個(gè)用戶,如arrivalrate=2,unit=second表示每秒產(chǎn)生2個(gè)用戶
  • interarrival:多少單位時(shí)間內(nèi)產(chǎn)生一個(gè)用戶,如interarrival=2,unit=second表示每2秒產(chǎn)生1個(gè)用戶,不要和arrivalrate同時(shí)存在

如果你想限制階段內(nèi)產(chǎn)生的用戶數(shù)量,可以用maxnumber來限定用戶數(shù),如maxnumber="200"(階段內(nèi)產(chǎn)生的用戶數(shù)量,如果達(dá)到后,默認(rèn)會(huì)結(jié)束本階段,哪怕在Load上設(shè)置了duration也不行)

客戶端證書

可以通過使用客戶端證書來進(jìn)行ssl驗(yàn)證。你可以使用動(dòng)態(tài)變量來設(shè)置證書的一些參數(shù):

<set_option name="certificate">
  <certificate cacertfile="/etc/ssl/ca.pem"
     keyfile="%%_keyfile%%" keypass="%%_keypass%%" certfile="/home/nobody/.tsung/client.pem"/>
</set_option>

Match

在<request>標(biāo)簽中定義match標(biāo)簽,可以檢查服務(wù)器響應(yīng)。常用它來作為請(qǐng)求的斷言。也可以在匹配前對(duì)content應(yīng)用一個(gè)函數(shù),例如,對(duì)Http響應(yīng)的body計(jì)算md5,并比較它:

<match do='log' when='nomatch' skip_headers='http' apply_to_content='ts_digest:md5hex'>01441debe3d7cc65ba843eee1acff89d</match>
<http url="/usrs/foo" method="GET" version="1.1"/>

Dynamic variables

在<request>標(biāo)簽中定義dyn_variable,可以處理請(qǐng)求過程中變化的部分。但此時(shí)應(yīng)用到的<request>要加上 subst="true" 屬性。

  <request>
    <dyn_variable name="pdbRightId" re="Set-Cookie: pdbRightRandomIds=([^;]+)"/>
...
  <setdynvars sourcetype="random_string" length="10">
    <var name="rndstr1" />
  </setdynvars>
  <request subst="true">
    <http url='http://mp2.web.liantiao.ofcard.com/pdbRight/checkAct?randomId=%%_rndstr1%%' version='1.1'  contents='type=thirty&amp;memberId=%%_pdbRightId%%' content_type='application/x-www-form-urlencoded; charset=UTF-8' method='POST'>    
...

另外,Dynamic variables也可以用Erlang代碼動(dòng)態(tài)賦值生成:

<setdynvars sourcetype="eval"
            code="fun({Pid,DynVars})->
                      {ok,Val}=ts_dynvars:lookup(md5data,DynVars),
                      ts_digest:md5hex(Val) end.">
  <var name="md5sum" />
</setdynvars>

在上面情況下,我們使用tsung函數(shù)ts_dynvars:lookup取回動(dòng)態(tài)變量命名md5data。

腳本文件

Tsung的壓測(cè)腳本是xml的,所以各個(gè)標(biāo)簽之間有順序要求,如果順序不對(duì)會(huì)報(bào)奇怪的錯(cuò)。在編寫時(shí),不熟悉的要跳到腳本的最開始,去查"/usr/share/tsung/tsung-1.0.dtd"。如果用vim,只要gf就可以了,然后還能用ctrl+n/p來auto completion。復(fù)雜的腳本或長的壓測(cè)流程,最好把文件拆分開來:

<?xml version="1.0"?>
<!DOCTYPE tsung SYSTEM "/usr/share/tsung/tsung-1.0.dtd" [
<!ENTITY user_load SYSTEM "./user_load.xml">
<!ENTITY ecstore_session SYSTEM "./tsung_estore_simple.xml">
]>

  ...

  <servers>
    <server host="ecstore-test.ecae.local" port="8000" type="tcp"/>
  </servers>

  &user_load;

  <options>
  ...
  </options>

  &ecstore_session;
</tsung>

條件判斷和循環(huán)處理:

<request>
    <dyn_variable name="result" re="Result: (.*)" />
    <http url="/random" method="GET" version="1.1" />
</request>
<if var="result" eq="3">
    <request><http url="/foo" /></request>
    <request><http url="/bar" /></request>
</if>
<repeat name="myloop" max_repeat="100">
    <request>
        <dyn_variable name="result" re="Result:(.*)" />
        <http url="/random" method="GET" version="1.1" />
    </request>
    ...
    <until var="result" eq="5" />
</repeat>
...
<for from="2" to="10" incr="2" var="cnt">
    ...
    <request subst="true">
        <http url="/page/?id=%%_cnt%%" />
    </request>
    ...
</for>

Tsung官方文檔還是比較簡(jiǎn)單的,具體細(xì)節(jié)可閱讀官方文檔。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

友情鏈接更多精彩內(nèi)容