摘要:我們的目的,就像是荒島余生一樣找到一個(gè)信念,在最殘酷的環(huán)境中,生存下去。這樣,會(huì)有很多地方會(huì)發(fā)生。監(jiān)控值排查問(wèn)題也是有過(guò)程的。比如飽和度一般指資源已完全使用,新請(qǐng)求在特定里排隊(duì)。
xin片之爭(zhēng),已經(jīng)暴露了中國(guó)xin的問(wèn)題,我等碼農(nóng)束手無(wú)策;而在操作系統(tǒng)方面,成果也是乏善可陳;現(xiàn)如今酷炫的Web監(jiān)控工具,讓很多研發(fā)喪失了真正處理問(wèn)題的能力。
越接近底層,就越接近真相,在計(jì)算機(jī)的世界,同樣適用。
我們的目的,就像是《荒島余生》一樣:找到一個(gè)信念,在最殘酷的環(huán)境中,生存下去。說(shuō)的比較隱晦,其實(shí)就是:你換公司了,而你的新公司比較推崇devops,你要自己面對(duì)問(wèn)題。
吹的那么高大上,一副拯救世界的感覺(jué),但本系列的文章知識(shí)并不深,很多已經(jīng)在大學(xué)里的操作系統(tǒng)見(jiàn)過(guò)了,雖然照讀課本的叫獸并不能讓你勾起絲毫興趣。
如果本系列能夠勾起你的些許興趣,就算目的達(dá)到了。本來(lái)是想要聊仔細(xì)點(diǎn),但由于時(shí)間有限,又不是寫書(shū),原理性的東西就不多說(shuō)了。
內(nèi)容文章將會(huì)嘗試單純的Cpu、Mem、Net、Disk、IO問(wèn)題排查,然后組合各種元素,解決一些棘手問(wèn)題,就是一些常用命令的組合。當(dāng)然我們是java系的,所以會(huì)多一些java方面的討論。如果你不了解行文風(fēng)格,可以先讀讀:《Java堆外內(nèi)存排查小結(jié)--小姐姐味道》
為什么Linux系統(tǒng)會(huì)出現(xiàn)這樣那樣的問(wèn)題呢?主要的原因就是計(jì)算機(jī)的各個(gè)部件的速度不均衡。Cpu在等cache line,cache 在等內(nèi)存,內(nèi)存在等設(shè)備。就像在連續(xù)17公里高速下坡路口設(shè)個(gè)收費(fèi)站一樣,一不小心就車毀人亡。
設(shè)備五花八門,通常我們接觸的設(shè)備,就是硬盤和網(wǎng)卡。整個(gè)業(yè)務(wù)系統(tǒng)和操作系統(tǒng)充斥著各種各樣的緩沖區(qū),CPU要通過(guò)中斷負(fù)責(zé)他們之間的協(xié)調(diào)。這樣,會(huì)有很多地方會(huì)發(fā)生bottleneck。
監(jiān)控值排查問(wèn)題也是有過(guò)程的。通常,關(guān)注一個(gè)硬件資源,比如CPU,我們關(guān)注以下基本要素:
1) 利用率 一般是瞬時(shí)值,屬于采樣范圍,用來(lái)判斷有沒(méi)有峰值。比如cpu utilization
2) 飽和度 一般指資源已完全使用,新請(qǐng)求在特定queue里排隊(duì)。比如cpu load過(guò)高
3) 錯(cuò)誤信息 硬件或者驅(qū)動(dòng)錯(cuò)誤,比如dmesg命令顯示的OOM
4) 聯(lián)想信息 對(duì)引起的原因進(jìn)行猜測(cè),并用更多的工具驗(yàn)證猜想。比如系統(tǒng)響應(yīng)慢猜測(cè)大量用到了swap
監(jiān)控值只是一種表象,具體引起的原因才是重點(diǎn)。我們通常希望純粹的資源限制所引起的故障,這種問(wèn)題都比較好定位。大多數(shù)情況下都沒(méi)那么幸運(yùn),所以廣度上的信息共享能幫助很多。過(guò)程如下:
1) 信息收集 問(wèn)題起始時(shí)間,上下文
2) 改動(dòng)集合 問(wèn)題發(fā)生前所有變更列表
3) 問(wèn)題抽象 將描述抽象成具體的資源問(wèn)題
4) 問(wèn)題排查 將信息整理完畢,就可以進(jìn)行真正的荒野之旅了
本測(cè)試用來(lái)決定你是不是本文目標(biāo)受眾,如果無(wú)法回答以下問(wèn)題,建議先看一點(diǎn)基本的Linux知識(shí),這將會(huì)節(jié)省你的時(shí)間,因?yàn)槲恼虏粫?huì)對(duì)此提太多。
io wait 是什么意思?
swap是什么分區(qū),怎么關(guān)閉?
/tmp目錄有什么特殊性?
管道是什么東東?
Linux發(fā)行版接下來(lái)熱熱身,瞧瞧Linux有什么發(fā)行版。
將常用腳本加入到PATH中
有些命令組合不好記,頻繁輸入也覺(jué)得煩,可以將這些過(guò)程整理成腳本,扔到path中。
還記得第一次安裝jdk,添加的環(huán)境變量么?Linux和它類似,不過(guò)它有多種shell。
通常我們用的叫bash,平常說(shuō)的shell腳本就是bash腳本。但也有很多其他好用的shell,比如csh、ksh、zsh等。
查看/etc/shells文件看一下你安裝過(guò)的shell
[root@localhost ~]$ cat /etc/shells /bin/sh /bin/bash /bin/zsh /sbin/nologin /bin/dash
在個(gè)人領(lǐng)域,zsh配合oh-my-zsh(推薦)達(dá)到最佳,但服務(wù)器一般不會(huì)去改你的shell,通過(guò)一個(gè)環(huán)境變量,能夠看到你當(dāng)前所使用的shell終端。
[root@localhost ~]$ echo $SHELL /bin/bash
針對(duì)于bash,我們的配置就在用戶目錄下的.bashrc文件中。
在用戶目錄下創(chuàng)建.bin目錄
mkdir ~/.bin
將目錄加入到環(huán)境變量PATH中
echo "export PATH=$PATH:~/.bin/" >> ~/.bashrc
在.bin創(chuàng)建一個(gè)文件xjj,內(nèi)容為
echo "pleasant taste"
cat > ~/.bin/xjj <給xjj增加可執(zhí)行權(quán)限
chmod a+x ~/.bin/xjj這樣,使用你的用戶,在任何地方,都可以執(zhí)行xjj了
[root@localhost ~]$ xjj pleasant taste真是令人愉悅的味道~
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://specialneedsforspecialkids.com/yun/8093.html
摘要:替換模式以上是命令的常用匹配模式,但它還有一個(gè)強(qiáng)大的替換模式,意思就是查找替換其中的某些值,并輸出結(jié)果??磧蓚€(gè)命令的語(yǔ)法好玩由于正則的關(guān)系,很多字符需要轉(zhuǎn)義。注意前半部分的范圍是不能使用這種方式的。sed命令應(yīng)用廣泛,使用簡(jiǎn)單,是快速文本處理的利器。它其實(shí)沒(méi)多少技巧,背誦、使用是最合適的學(xué)習(xí)渠道,屬于硬技能。但它又很復(fù)雜,因?yàn)楦呒?jí)功能太多。本篇不去關(guān)注sed的高級(jí)功能,僅對(duì)常用的一些操作,進(jìn)...
摘要:比如面向連接的功能包發(fā)送接收數(shù)量包發(fā)送接收速率錯(cuò)誤計(jì)數(shù)連接重連次數(shù)調(diào)用延遲連接狀態(tài)等。你要處理的,就是心跳超時(shí)的邏輯,比如延遲重連。發(fā)生異常后,可以根據(jù)不同的類型選擇斷線重連比如一些二進(jìn)制協(xié)議的編解碼紊亂問(wèn)題,或者調(diào)度到其他節(jié)點(diǎn)。 在java界,netty無(wú)疑是開(kāi)發(fā)網(wǎng)絡(luò)應(yīng)用的拿手菜。你不需要太多關(guān)注復(fù)雜的nio模型和底層網(wǎng)絡(luò)的細(xì)節(jié),使用其豐富的接口,可以很容易的實(shí)現(xiàn)復(fù)雜的通訊功能。 和...
摘要:比如面向連接的功能包發(fā)送接收數(shù)量包發(fā)送接收速率錯(cuò)誤計(jì)數(shù)連接重連次數(shù)調(diào)用延遲連接狀態(tài)等。你要處理的,就是心跳超時(shí)的邏輯,比如延遲重連。發(fā)生異常后,可以根據(jù)不同的類型選擇斷線重連比如一些二進(jìn)制協(xié)議的編解碼紊亂問(wèn)題,或者調(diào)度到其他節(jié)點(diǎn)。 在java界,netty無(wú)疑是開(kāi)發(fā)網(wǎng)絡(luò)應(yīng)用的拿手菜。你不需要太多關(guān)注復(fù)雜的nio模型和底層網(wǎng)絡(luò)的細(xì)節(jié),使用其豐富的接口,可以很容易的實(shí)現(xiàn)復(fù)雜的通訊功能。 和...
閱讀 1574·2021-09-23 11:21
閱讀 2345·2021-09-07 10:13
閱讀 834·2021-09-02 10:19
閱讀 1125·2019-08-30 15:44
閱讀 1720·2019-08-30 13:18
閱讀 1913·2019-08-30 11:15
閱讀 1105·2019-08-29 17:17
閱讀 2017·2019-08-29 15:31