壓測(cè)

一泪幌、 數(shù)據(jù)庫(kù)壓測(cè)

1. 為什么要進(jìn)行數(shù)據(jù)庫(kù)壓測(cè)

不斷給數(shù)據(jù)庫(kù)施加壓力,驗(yàn)證數(shù)據(jù)庫(kù)處理的性能

2.? 如何進(jìn)行數(shù)據(jù)庫(kù)壓測(cè)

測(cè)試的過(guò)程中玄渗,我們經(jīng)常要對(duì)數(shù)據(jù)庫(kù)表數(shù)據(jù)進(jìn)行查詢(xún)座菠、修改狸眼、添加等操作藤树。在用 JMeter 做性能或者接口等 測(cè)試時(shí),也可以讓 JMeter 連接數(shù)據(jù)庫(kù)然后對(duì)數(shù)據(jù)庫(kù)數(shù)據(jù)進(jìn)行相關(guān)操作拓萌。下面先來(lái)學(xué)習(xí)如何使用 JMeter 連接 MySql 數(shù)據(jù)庫(kù)進(jìn)行操作岁钓。

2.1 JDBC配置

首先創(chuàng)建一個(gè)測(cè)試計(jì)劃和線程組,然后在線程組下添加配置元件 JDBC Connection Configuration 微王。

image.png

接下來(lái)要對(duì)數(shù)據(jù)庫(kù)連接的配置項(xiàng)進(jìn)行設(shè)置屡限。

image.png

VariableNameforcreated pool: 創(chuàng)建池的變量名 。這個(gè)變量在后面介紹的JDBCRequest請(qǐng)求中用到炕倘。MaxNumberofConnections: 池中允許的最大連接數(shù)钧大。在大多數(shù)情況下,將其設(shè)置為零(0)罩旋,這意味 著每個(gè)線程都將擁有自己的池啊央,其中只有一個(gè)連接,即線程之間不共享連接涨醋。如果您真的想使用共享池瓜饥,那么 將 max count 設(shè)置為與線程數(shù)量相同,以確保線程不會(huì)彼此等待浴骂。MaxWait(ms):在試圖檢索連接的過(guò)程中超過(guò)了超時(shí)時(shí)間乓土,則池會(huì)拋出一個(gè)錯(cuò)誤 。TimeBetweenEvictionRuns(ms):在被逐出的時(shí)間間隔(ms)。在空閑對(duì)象驅(qū)逐線程之間運(yùn)行的毫 秒數(shù)趣苏。當(dāng)非正的時(shí)候狡相,就不會(huì)運(yùn)行無(wú)用的對(duì)象驅(qū)逐線程(默認(rèn)為"60000",1分鐘) 拦键。AutoCommit:將自動(dòng)提交或關(guān)閉連接到連接上 谣光。 transaction isolation:事務(wù)隔離 。這個(gè)默認(rèn)即可芬为,具體用法暫時(shí)還沒(méi)有研究過(guò)萄金,會(huì)的可以分享一下。TestWhileIdle:測(cè)試池的空閑連接 媚朦,后面的驗(yàn)證查詢(xún)將用于測(cè)試它氧敢。SoftMinEvictableIdleTime(ms):軟Min可驅(qū)逐空閑時(shí)間(ms) 。在它有資格被閑置的對(duì)象驅(qū) 逐者強(qiáng)制驅(qū)逐之前询张,一個(gè)連接可能閑置在池中孙乖,并且至少在池中存在空閑連接的額外條件,默認(rèn)值為5000(5秒) 份氧。ValidationQuery:驗(yàn)證查詢(xún) 唯袄。一個(gè)簡(jiǎn)單的查詢(xún),用來(lái)確定數(shù)據(jù)庫(kù)是否仍在響應(yīng)蜗帜。 這個(gè)驗(yàn)證查詢(xún)?cè)诔貏?chuàng) 建中使用恋拷,即使“空閑測(cè)試”建議查詢(xún)只在空閑連接上使用,也可以驗(yàn)證它厅缺。DatabaseURL:數(shù)據(jù)鏈接url蔬顾,格式:jdbc:mysql://localhost:3306/host 注釋?zhuān)簲?shù)據(jù)庫(kù)的ip地址+端口/數(shù)據(jù)庫(kù)名(查詢(xún)數(shù)據(jù)庫(kù)端口號(hào)show global variables like'port') jdbc:mysql://127.0.0.1:3306/mydb2?serverTimezone=UTC&allowMultiQueries=trueJDBCDriverclass:JDBC驅(qū)動(dòng)程序類(lèi) 。MySql選擇 com.mysql.jdbc.DriverUsername:連接數(shù)據(jù)庫(kù)的用戶(hù)名湘捎。Password:連接數(shù)據(jù)庫(kù)的密碼诀豁。

2.2 設(shè)置完成后,接下來(lái)在線程組下創(chuàng)建一個(gè) JDBC Request 請(qǐng)求窥妇。

image.png

image.png

image.png

接著在 JMeter 中添加一個(gè)查看結(jié)果樹(shù)監(jiān)聽(tīng)器舷胜,運(yùn)行一次腳本。

image.png

2.3 select statement

只支持單條查詢(xún)活翩,只支持第一條數(shù)據(jù)查詢(xún)

//如果多條會(huì)報(bào)錯(cuò)烹骨,修改,但是仍然只能查詢(xún)到一條數(shù)據(jù)allowMultiQueries=true

2.4 updata statement

修改數(shù)據(jù)

//首先修改查詢(xún)類(lèi)型Updata S纱新、tatementupdata stusetname="大飛"whereid=1;

新增數(shù)據(jù)

//首先修改查詢(xún)類(lèi)型updata statementinsertinto

同時(shí)新增支持和修改語(yǔ)句

支持多條語(yǔ)句展氓,但是select只能放最后一行

2.5 Callable Statement

支持查詢(xún)、修改

支持多個(gè)查詢(xún)

2.6 Prepared Select Statement

image.png

注意:類(lèi)型必須為varchar

結(jié)合CSV處理多條查詢(xún)

創(chuàng)建文件數(shù)據(jù):

image.png

添加CSV數(shù)據(jù)文件設(shè)置脸爱,并編寫(xiě)對(duì)應(yīng)的變量:

image.png

引用變量值${id}

image.png

結(jié)合函數(shù)助手多條查詢(xún)

創(chuàng)建文件編寫(xiě)數(shù)據(jù)

在選項(xiàng)中添加函數(shù)助手遇汞,選擇csvread函數(shù),填寫(xiě)路徑索引,拿到對(duì)應(yīng)的字符串

講拿到的字符串當(dāng)成值進(jìn)行傳遞

二空入、 jmeter對(duì)服務(wù)器壓測(cè)(Windows)

在使用Jmeter工具進(jìn)行性能測(cè)試或者壓力測(cè)試的時(shí)候要對(duì)服務(wù)器的資源進(jìn)行監(jiān)控络它,如cup的使用情況、服務(wù)器的內(nèi)存資源等歪赢,這個(gè)時(shí)候我們就需要配置一下相關(guān)插件進(jìn)行監(jiān)控化戳。

1. 資源準(zhǔn)備

插件:JMeterPlugins-Extras.jar、JMeterPlugins-Standard.jar

將JMeterPlugins-Extras.jar和JMeterPlugins-Standard.jar放到apache-jmeter-3.0\lib\ext目錄下

服務(wù):ServerAgent-2.2.1

2. 先在服務(wù)器上開(kāi)啟server的監(jiān)聽(tīng)

image.png

3. 給服務(wù)器(用本地?cái)?shù)據(jù)庫(kù)模擬服務(wù)器)添加監(jiān)聽(tīng)器-jp@gc - PerfMon Metrics Collector

image.png

4. 添加性能指標(biāo)埋凯,線程組設(shè)置線程數(shù)和時(shí)間

image.png

二点楼、 jmeter對(duì)服務(wù)器壓測(cè)(Linux)

很多服務(wù)都是部署在Linux上 的,所以我們要在Linux上做服務(wù)器壓測(cè)白对。

1. 資源準(zhǔn)備

將JMeterPlugins-Extras.jar和JMeterPlugins-Standard.jar放到apache-jmeter-3.0\lib\ext目錄下

將ServerAgent-2.2.1放到linux服務(wù)器opt目錄下掠廓,并解壓unzip

2. 環(huán)境準(zhǔn)備

ServerAgent服務(wù)端口號(hào)默認(rèn)為4444,需要設(shè)置防火墻對(duì)此端口不攔截:

開(kāi)放Linux的對(duì)外訪問(wèn)的端口4444

/sbin/iptables-I INPUT-p tcp--dport4444-j ACCEPT/etc/rc.d/init.d/iptables save---將修改永久保存到防火墻中

3. 然后在服務(wù)器中啟動(dòng)監(jiān)控服務(wù)

./startagent.sh

4. 修改JDBC Connection Configuration中配置

本地地址改為遠(yuǎn)程地址

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末甩恼,一起剝皮案震驚了整個(gè)濱河市蟀瞧,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌条摸,老刑警劉巖悦污,帶你破解...
    沈念sama閱讀 216,372評(píng)論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異钉蒲,居然都是意外死亡切端,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,368評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門(mén)子巾,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)帆赢,“玉大人小压,你說(shuō)我怎么就攤上這事线梗。” “怎么了怠益?”我有些...
    開(kāi)封第一講書(shū)人閱讀 162,415評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵仪搔,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我蜻牢,道長(zhǎng)烤咧,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,157評(píng)論 1 292
  • 正文 為了忘掉前任抢呆,我火速辦了婚禮煮嫌,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘抱虐。我一直安慰自己昌阿,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,171評(píng)論 6 388
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著懦冰,像睡著了一般灶轰。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上刷钢,一...
    開(kāi)封第一講書(shū)人閱讀 51,125評(píng)論 1 297
  • 那天笋颤,我揣著相機(jī)與錄音,去河邊找鬼内地。 笑死伴澄,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的阱缓。 我是一名探鬼主播秉版,決...
    沈念sama閱讀 40,028評(píng)論 3 417
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼茬祷!你這毒婦竟也來(lái)了清焕?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 38,887評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤祭犯,失蹤者是張志新(化名)和其女友劉穎秸妥,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體沃粗,經(jīng)...
    沈念sama閱讀 45,310評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡粥惧,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,533評(píng)論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了最盅。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片突雪。...
    茶點(diǎn)故事閱讀 39,690評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖涡贱,靈堂內(nèi)的尸體忽然破棺而出咏删,到底是詐尸還是另有隱情,我是刑警寧澤问词,帶...
    沈念sama閱讀 35,411評(píng)論 5 343
  • 正文 年R本政府宣布督函,位于F島的核電站,受9級(jí)特大地震影響激挪,放射性物質(zhì)發(fā)生泄漏辰狡。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,004評(píng)論 3 325
  • 文/蒙蒙 一垄分、第九天 我趴在偏房一處隱蔽的房頂上張望宛篇。 院中可真熱鬧,春花似錦薄湿、人聲如沸叫倍。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,659評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)段标。三九已至涯冠,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間逼庞,已是汗流浹背蛇更。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,812評(píng)論 1 268
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留赛糟,地道東北人派任。 一個(gè)月前我還...
    沈念sama閱讀 47,693評(píng)論 2 368
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像璧南,于是被迫代替她去往敵國(guó)和親掌逛。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,577評(píng)論 2 353

推薦閱讀更多精彩內(nèi)容

  • Jmeter本身是不能夠展示內(nèi)存司倚,cpu和吞吐量的豆混,但是可以通過(guò)添加插件的方式來(lái)對(duì)jmeter添加這些功能Jmet...
    SONY3閱讀 251評(píng)論 0 2
  • Jmeter本身是不能夠展示內(nèi)存,cpu和吞吐量的动知,但是可以通過(guò)添加插件的方式來(lái)對(duì)jmeter添加這些功能 Jme...
    淺色年華_7d4f閱讀 269評(píng)論 0 0
  • Jmeter本身是不能夠展示內(nèi)存皿伺,cpu和吞吐量的,但是可以通過(guò)添加插件的方式來(lái)對(duì)jmeter添加這些功能 Jme...
    zflain閱讀 189評(píng)論 0 0
  • 一盒粮、 數(shù)據(jù)庫(kù)壓測(cè) 1. 為什么要進(jìn)行數(shù)據(jù)庫(kù)壓測(cè) 不斷給數(shù)據(jù)庫(kù)施加壓力鸵鸥,驗(yàn)證數(shù)據(jù)庫(kù)處理的性能 2. 如何進(jìn)行數(shù)據(jù)庫(kù)壓...
    boke閱讀 222評(píng)論 0 0
  • Jmeter本身是不能夠展示內(nèi)存,cpu和吞吐量的丹皱,但是可以通過(guò)添加插件的方式來(lái)對(duì)jmeter添加這些功能Jmet...
    Anwfly閱讀 1,629評(píng)論 0 2