教你如何精準(zhǔn)統(tǒng)計出你的接口"QPS"
QPS是什么
我們先回憶一下,QPS的概念如下所示:
QPS(Query Per Second):每秒請求數(shù),就是說服務(wù)器在一秒的時間內(nèi)處理了多少個請求。
那我們怎么估出每秒鐘能處理多少請求呢?
OK,用日志來估計!那日志怎么記錄呢,細(xì)分下來,有兩種方式。
方式一:自己在接口里記錄
這種方式指的是在你的接口里,日志記錄了能體現(xiàn)該接口特性的,并具有唯一性的字符串!
例如,下面這一段代碼
@RestController
@RequestMapping("/home")
public class IndexController {
//省略
@RequestMapping("/index")
String index() {
logger.info("渣渣煙");
return "index";
}
}
假設(shè)現(xiàn)在我要統(tǒng)計index這個接口的QPS!
OK,什么叫能體現(xiàn)該接口特性的字符串呢!就像上面的"渣渣煙"這個字符串,只在index這個接口里出現(xiàn)過,沒在其他其他接口里出現(xiàn)過!因此,只要統(tǒng)計出"渣渣煙"這個字符串在日志里的出現(xiàn)次數(shù),就能知道該接口的請求次數(shù)!
什么叫具有唯一性的字符串呢!所謂唯一性,指的是"渣渣煙"這個字符串,在這個接口的一次調(diào)用流程中,只出現(xiàn)一次!如果出現(xiàn)兩次,就會導(dǎo)致到時候統(tǒng)計出來的次數(shù)會多一倍,所以盡量選擇具有唯一性的字段!
方式二:利用tomcat的access log
如果你的日志里沒有我上面提到的字段。OK,那就用tomcat自帶的access log功能吧!
因為我平時內(nèi)置的tomcat比較多,指定下面兩個屬性即可
server.tomcat.accesslog.directory 設(shè)定log的目錄,默認(rèn): logs server.tomcat.accesslog.enabled 是否開啟access log,默認(rèn): false
此時,你訪問一次/home/index地址,會有下面這樣日志
127.0.0.1 - - [19/Aug/2019:23:55:27 +0800] “POST /home/index HTTP/1.1” 200 138
那么,你就可以根據(jù)日志中,該記錄的出現(xiàn)次數(shù),統(tǒng)計index接口的QPS。
實戰(zhàn)
假設(shè),你這會日志已經(jīng)拿到手了,名字為xxx.log。
假設(shè)日志內(nèi)容如下
//省略,都長差不多,貼其中一條就行 0:0:0:0:0:0:0:1 - - [27/Dec/2018:20:41:57 +0800] "GET /mvc2/upload.do HTTP/1.1" 404 949 http-bio-8080-exec-5 43 //省略
這個時候,你執(zhí)行一串命令長下面這樣的,進(jìn)行統(tǒng)計就行!
cat xx.log |grep 'GET /mvc2'|cut -d ' ' -f4|uniq -c|sort -n -r
出來等結(jié)果就是
20 [27/Dec/2018:20:40:44
11 [27/Dec/2018:20:47:58
10 [27/Dec/2018:20:47:42
1 [27/Dec/2018:20:41:57
然后你就知道,原來在20:40:44 分。。這個接口的QPS最高,達(dá)到了驚人的20QPS!
現(xiàn)在,來講一下命令什么意思!
cat xxx.log : 讀文件內(nèi)容
grep ‘GET /mvc2' : 將文件內(nèi)容按照GET /mvc2 進(jìn)行過濾
cut -d ' ' -f4 : 過濾出來的內(nèi)容按照空格進(jìn)行分割,取第四列內(nèi)容
uniq -c : 每列旁邊顯示該行重復(fù)出現(xiàn)的次數(shù)
sort -n -r : 依照數(shù)值的大小排序
那么,如果是其他日志格式,無外乎 ”cut語句“的處理不同而已,道理類似!此法可以估算出單機(jī)的某接口的 “QPS” 是多少!
估算
我們現(xiàn)在估計出了單機(jī)的QPS。接下來,估算集群的QPS。
這就要根據(jù)負(fù)載均衡的策略來估計!
比如,你部署了32臺機(jī)器,負(fù)載均衡的策略恰巧為輪詢,那集群的QPS就是單機(jī)的QPS乘32就好了。
所以,根據(jù)具體的策略,來估計整個集群的QPS多大!一般有2000qps已經(jīng)是很高的了。
總結(jié)
本篇文章就到這里了,希望能給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
Java數(shù)組創(chuàng)建的3種方法6種寫法代碼示例
這篇文章主要給大家介紹了關(guān)于Java數(shù)組創(chuàng)建的3種方法6種寫法,在Java中我們可以使用關(guān)鍵字new來創(chuàng)建一個數(shù)組,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-01-01
Java8如何利用Lambda快速生成map、多層嵌套map
這篇文章主要介紹了Java8如何利用Lambda快速生成map、多層嵌套map問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-09-09
SSH框架網(wǎng)上商城項目第30戰(zhàn)之項目總結(jié)(附源碼下載地址)
這篇文章主要介紹了SSH框架網(wǎng)上商城項目第30戰(zhàn)之項目總結(jié),并附源碼下載地址,感興趣的小伙伴們可以參考一下2016-06-06
SpringBoot中配置雙數(shù)據(jù)源的實現(xiàn)示例
在許多應(yīng)用程序中,可能會遇到需要連接多個數(shù)據(jù)庫的情況,本文主要介紹了SpringBoot中配置雙數(shù)據(jù)源的實現(xiàn)示例,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-08-08
java中l(wèi)ong(Long)與int(Integer)之間的轉(zhuǎn)換方式
這篇文章主要介紹了java中l(wèi)ong(Long)與int(Integer)之間的轉(zhuǎn)換方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-10-10

