高性能

QPS和TPS

QPS(Query Per Second) :服務(wù)器每秒可以執(zhí)行的查詢次數(shù);
TPS(Transaction Per Second) :服務(wù)器每秒處理的事務(wù)數(shù)(這里的一個事務(wù)可以理解為客戶發(fā)出請求到收到服務(wù)器的過程);

QPS vs TPS:QPS 基本類似于 TPS宜肉,但是不同的是挪拟,對于一個頁面的一次訪問屿储,形成一個 TPS奕污;但一次頁面請求长窄,可能產(chǎn)生多次對服務(wù)器的請求挥唠,服務(wù)器對這些請求抵恋,就可計入“QPS”之中。如宝磨,訪問一個頁面會請求服務(wù)器 2 次弧关,一次訪問,產(chǎn)生一個“T”唤锉,產(chǎn)生 2 個“Q”世囊。

吞吐量

吞吐量指的是系統(tǒng)單位時間內(nèi)系統(tǒng)處理的請求數(shù)量。

一個系統(tǒng)的吞吐量與請求對系統(tǒng)的資源消耗等緊密關(guān)聯(lián)窿祥。請求對系統(tǒng)資源消耗越多株憾,系統(tǒng)吞吐能力越低,反之則越高晒衩。

TPS嗤瞎、QPS 都是吞吐量的常用量化指標墙歪。

QPS(TPS) = 并發(fā)數(shù)/平均響應(yīng)時間(RT)
并發(fā)數(shù) = QPS * 平均響應(yīng)時間(RT)

系統(tǒng)活躍度

PV(Page View)

訪問量, 即頁面瀏覽量或點擊量,衡量網(wǎng)站用戶訪問的網(wǎng)頁數(shù)量猫胁;在一定統(tǒng)計周期內(nèi)用戶每打開或刷新一個頁面就記錄 1 次箱亿,多次打開或刷新同一頁面則瀏覽量累計。UV 從網(wǎng)頁打開的數(shù)量/刷新的次數(shù)的角度來統(tǒng)計的弃秆。

UV(Unique Visitor)

獨立訪客届惋,統(tǒng)計 1 天內(nèi)訪問某站點的用戶數(shù)。1 天內(nèi)相同訪客多次訪問網(wǎng)站菠赚,只計算為 1 個獨立訪客脑豹。UV 是從用戶個體的角度來統(tǒng)計的。

常見軟件的 QPS

這里給出的 QPS 僅供參考衡查,實際項目需要進行壓測來計算瘩欺。

Nginx :一般情況下,系統(tǒng)的性能瓶頸基本不會是 Nginx拌牲。單機 Nginx 可以達到 30w +俱饿。
Redis: Redis 官方的性能測試報告:https://redis.io/topics/benchmarks 。從報告中塌忽,我們可以得出 Redis 的單機 QPS 可以達到 8w+(CPU 性能有關(guān)系拍埠,也和執(zhí)行的命令也有關(guān)系比如執(zhí)行 SET 命令甚至可以達到 10w+QPS)。
MySQL: MySQL 單機的 QPS 為 大概在 4k 左右土居。
Tomcat :單機 Tomcat 的 QPS 在 2w 左右枣购。這個和你的 Tomcat 配置有很大關(guān)系,舉個例子 Tomcat 支持的連接器有 NIO擦耀、NIO.2 和 APR棉圈。AprEndpoint 是通過 JNI 調(diào)用 APR 本地庫而實現(xiàn)非阻塞 I/O 的,性能更好眷蜓,Tomcat 配置 APR 為 連接器的話分瘾,QPS 可以達到 3w 左右。更多相關(guān)內(nèi)容可以自行搜索 Tomcat 性能優(yōu)化吁系。

常見的性能優(yōu)化策略

性能優(yōu)化之前我們需要對請求經(jīng)歷的各個環(huán)節(jié)進行分析芹敌,排查出可能出現(xiàn)性能瓶頸的地方,定位問題垮抗。

下面是一些性能優(yōu)化時,我經(jīng)常拿來自問的一些問題:

當前系統(tǒng)的 SQL 語句是否存在問題碧聪?
當前系統(tǒng)是否需要升級硬件冒版?
系統(tǒng)是否需要緩存?
系統(tǒng)架構(gòu)本身是不是就有問題逞姿?
系統(tǒng)是否存在死鎖的地方辞嗡?
數(shù)據(jù)庫索引使用是否合理捆等?
系統(tǒng)是否存在內(nèi)存泄漏?(Java 的自動回收內(nèi)存雖然很方便续室,但是栋烤,有時候代碼寫的不好真的會造成內(nèi)存泄漏)
系統(tǒng)的耗時操作進行了異步處理?

性能優(yōu)化必知法則

SQL 優(yōu)化挺狰,JVM明郭、DB,Tomcat 參數(shù)調(diào)優(yōu) > 硬件性能優(yōu)化(內(nèi)存升級丰泊、CPU 核心數(shù)增加薯定、機械硬盤—>固態(tài)硬盤等等)> 業(yè)務(wù)邏輯優(yōu)化/緩存 > 讀寫分離、集群等 > 分庫分表

參考:
https://mp.weixin.qq.com/s/1Jl8ee0jJoFdGMfIhl_qaQ
https://github.com/donnemartin/system-design-primer
https://www.acecodeinterview.com/intro/
https://gist.github.com/vasanthk/485d1c25737e8e72759f

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末瞳购,一起剝皮案震驚了整個濱河市话侄,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌学赛,老刑警劉巖年堆,帶你破解...
    沈念sama閱讀 206,126評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異盏浇,居然都是意外死亡变丧,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,254評論 2 382
  • 文/潘曉璐 我一進店門缠捌,熙熙樓的掌柜王于貴愁眉苦臉地迎上來锄贷,“玉大人,你說我怎么就攤上這事曼月∫耆矗” “怎么了?”我有些...
    開封第一講書人閱讀 152,445評論 0 341
  • 文/不壞的土叔 我叫張陵哑芹,是天一觀的道長炎辨。 經(jīng)常有香客問我,道長聪姿,這世上最難降的妖魔是什么碴萧? 我笑而不...
    開封第一講書人閱讀 55,185評論 1 278
  • 正文 為了忘掉前任,我火速辦了婚禮末购,結(jié)果婚禮上破喻,老公的妹妹穿的比我還像新娘。我一直安慰自己盟榴,他們只是感情好曹质,可當我...
    茶點故事閱讀 64,178評論 5 371
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般羽德。 火紅的嫁衣襯著肌膚如雪几莽。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 48,970評論 1 284
  • 那天宅静,我揣著相機與錄音章蚣,去河邊找鬼。 笑死姨夹,一個胖子當著我的面吹牛纤垂,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播匀伏,決...
    沈念sama閱讀 38,276評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼洒忧,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了够颠?” 一聲冷哼從身側(cè)響起熙侍,我...
    開封第一講書人閱讀 36,927評論 0 259
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎履磨,沒想到半個月后蛉抓,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,400評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡剃诅,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,883評論 2 323
  • 正文 我和宋清朗相戀三年巷送,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片矛辕。...
    茶點故事閱讀 37,997評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡笑跛,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出聊品,到底是詐尸還是另有隱情飞蹂,我是刑警寧澤,帶...
    沈念sama閱讀 33,646評論 4 322
  • 正文 年R本政府宣布翻屈,位于F島的核電站陈哑,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏伸眶。R本人自食惡果不足惜惊窖,卻給世界環(huán)境...
    茶點故事閱讀 39,213評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望厘贼。 院中可真熱鬧界酒,春花似錦、人聲如沸嘴秸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,204評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至署辉,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間岩四,已是汗流浹背哭尝。 一陣腳步聲響...
    開封第一講書人閱讀 31,423評論 1 260
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留剖煌,地道東北人材鹦。 一個月前我還...
    沈念sama閱讀 45,423評論 2 352
  • 正文 我出身青樓,卻偏偏與公主長得像耕姊,于是被迫代替她去往敵國和親桶唐。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 42,722評論 2 345