Tsung使用總結

Tsung

Tsung的壓測模式和JMeter等常見壓測工具是不一樣的。Tsung屬于"open system model" 墓毒,算是一種"open-ended load testing tools" , 并且和"Yandex. Tank"一樣性芬,屬于"hit-based mode"形式狐援。它的很多概念和JMeter等常見的壓測工具不一樣衬吆。另外提一點帖族,Gatling缺省是"closed model"的,可以使用repeat和during實現(xiàn)"open-ended load testing"募判。當用JMeter這樣的"closed-ended"壓測工具打壓很高的壓力時荡含,就得增加非常多的slave加壓機器咒唆。Tsung這種"open-ended"型的壓測工具,往往單機就能打壓較高的壓力释液。在測試資源受限時全释,Tsung是較好的選擇。

基礎概念

Tsung的一些基礎概念:

  • Tsung的每一個虛擬用戶就是一個erlang的輕量進程误债。
  • 虛擬用戶完成session后就消失浸船。
  • 每個cpu都會產(chǎn)生一個erlang虛擬機用來發(fā)揮多CPU的優(yōu)勢
  • 大量的虛擬用戶(erlang輕量進程)建立在erlangVM上
  • 一臺測試機可以啟多個erlangVM,目前按照1個cpu啟動1個erlangVM
  • 每個虛擬機下有很多user寝蹈,每個user可以產(chǎn)生很多session,一個session由很多request組成

集群

Tsung 的集群測試使用十分簡單李命,只需要在主節(jié)點上執(zhí)行操作,所有從節(jié)點會自動執(zhí)行箫老,不用去干預封字。只涉及到打通主從節(jié)點的通訊問題(基于Erlang的通訊)。如果基于 SSH 的免密鑰方式耍鬓,很容易出現(xiàn)問題阔籽,可以使用 tsung_rsh,也要在主節(jié)點上修改 tsung.xml 的client段配置界斜。要注意兩點:

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

可以采用以下方式驗證主從節(jié)點之間的通訊各薇。將 remotehost 分別修改為從機進行測試项贺。如果返回 {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").

相關命令

運行腳本:

tsung -s -f users_load.xml start

運時時動態(tài)報表:

http://master-ip:8091

結束后生成報表并查看:

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

多次結果比較:

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

用戶設置策略

  • arrivalrate:時間單位內產(chǎn)生多少個用戶开缎,如arrivalrate=2,unit=second表示每秒產(chǎn)生2個用戶
  • interarrival:多少單位時間內產(chǎn)生一個用戶林螃,如interarrival=2奕删,unit=second表示每2秒產(chǎn)生1個用戶,不要和arrivalrate同時存在

如果你想限制階段內產(chǎn)生的用戶數(shù)量疗认,可以用maxnumber來限定用戶數(shù)完残,如maxnumber="200"(階段內產(chǎn)生的用戶數(shù)量,如果達到后横漏,默認會結束本階段谨设,哪怕在Load上設置了duration也不行)

客戶端證書

可以通過使用客戶端證書來進行ssl驗證。你可以使用動態(tài)變量來設置證書的一些參數(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>標簽中定義match標簽缎浇,可以檢查服務器響應扎拣。常用它來作為請求的斷言。也可以在匹配前對content應用一個函數(shù),例如二蓝,對Http響應的body計算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>標簽中定義dyn_variable,可以處理請求過程中變化的部分刊愚。但此時應用到的<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代碼動態(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取回動態(tài)變量命名md5data琴锭。

腳本文件

Tsung的壓測腳本是xml的晰甚,所以各個標簽之間有順序要求衙传,如果順序不對會報奇怪的錯。在編寫時厕九,不熟悉的要跳到腳本的最開始蓖捶,去查"/usr/share/tsung/tsung-1.0.dtd"。如果用vim扁远,只要gf就可以了俊鱼,然后還能用ctrl+n/p來auto completion。復雜的腳本或長的壓測流程畅买,最好把文件拆分開來:

<?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é)可閱讀官方文檔。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末谷羞,一起剝皮案震驚了整個濱河市帝火,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌湃缎,老刑警劉巖犀填,帶你破解...
    沈念sama閱讀 218,858評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異嗓违,居然都是意外死亡九巡,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,372評論 3 395
  • 文/潘曉璐 我一進店門蹂季,熙熙樓的掌柜王于貴愁眉苦臉地迎上來冕广,“玉大人,你說我怎么就攤上這事偿洁∪龊海” “怎么了?”我有些...
    開封第一講書人閱讀 165,282評論 0 356
  • 文/不壞的土叔 我叫張陵父能,是天一觀的道長神凑。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么溉委? 我笑而不...
    開封第一講書人閱讀 58,842評論 1 295
  • 正文 為了忘掉前任鹃唯,我火速辦了婚禮,結果婚禮上瓣喊,老公的妹妹穿的比我還像新娘坡慌。我一直安慰自己,他們只是感情好藻三,可當我...
    茶點故事閱讀 67,857評論 6 392
  • 文/花漫 我一把揭開白布洪橘。 她就那樣靜靜地躺著,像睡著了一般棵帽。 火紅的嫁衣襯著肌膚如雪熄求。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,679評論 1 305
  • 那天逗概,我揣著相機與錄音弟晚,去河邊找鬼。 笑死逾苫,一個胖子當著我的面吹牛卿城,可吹牛的內容都是我干的。 我是一名探鬼主播铅搓,決...
    沈念sama閱讀 40,406評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼瑟押,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了星掰?” 一聲冷哼從身側響起多望,我...
    開封第一講書人閱讀 39,311評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎蹋偏,沒想到半個月后便斥,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,767評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡威始,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,945評論 3 336
  • 正文 我和宋清朗相戀三年枢纠,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片黎棠。...
    茶點故事閱讀 40,090評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡晋渺,死狀恐怖,靈堂內的尸體忽然破棺而出脓斩,到底是詐尸還是另有隱情木西,我是刑警寧澤,帶...
    沈念sama閱讀 35,785評論 5 346
  • 正文 年R本政府宣布随静,位于F島的核電站八千,受9級特大地震影響吗讶,放射性物質發(fā)生泄漏。R本人自食惡果不足惜恋捆,卻給世界環(huán)境...
    茶點故事閱讀 41,420評論 3 331
  • 文/蒙蒙 一照皆、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧沸停,春花似錦膜毁、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,988評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至能颁,卻和暖如春杂瘸,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背劲装。 一陣腳步聲響...
    開封第一講書人閱讀 33,101評論 1 271
  • 我被黑心中介騙來泰國打工胧沫, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留昌简,地道東北人占业。 一個月前我還...
    沈念sama閱讀 48,298評論 3 372
  • 正文 我出身青樓,卻偏偏與公主長得像纯赎,于是被迫代替她去往敵國和親谦疾。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 45,033評論 2 355