Kubernetes 中日志重要性
10年積累的網(wǎng)站設(shè)計(jì)制作、成都網(wǎng)站設(shè)計(jì)經(jīng)驗(yàn),可以快速應(yīng)對(duì)客戶對(duì)網(wǎng)站的新想法和需求。提供各種問(wèn)題對(duì)應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識(shí)你,你也不認(rèn)識(shí)我。但先制作網(wǎng)站后付款的網(wǎng)站建設(shè)流程,更有富拉爾基免費(fèi)網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。通常日志最基礎(chǔ)的作用是記錄程序的運(yùn)行軌跡,在此之上會(huì)衍生出非常多的功能,例如線上監(jiān)控、告警、運(yùn)營(yíng)分析、安全分析等等(詳情可以參見(jiàn)第一篇文章《6 個(gè) K8s 日志系統(tǒng)建設(shè)中的典型問(wèn)題,你遇到過(guò)幾個(gè)?》,這些功能反過(guò)來(lái)也對(duì)日志具備一定的要求,我們需要盡可能的將日志規(guī)范化,以減少收集、解析、分析的代價(jià)。
在 Kubernetes 中,環(huán)境的動(dòng)態(tài)性很強(qiáng),日志基本上都是易失的,因此需要實(shí)時(shí)將日志采集到中心的存儲(chǔ)中,為了配合日志采集,對(duì)于日志的輸出、采集會(huì)有更多的要求。
下述我們列舉了 Kubernetes 中,日志輸出的常見(jiàn)注意事項(xiàng)(其中標(biāo)記 (*)的是 Kubernetes 中特有的項(xiàng)目):
日志等級(jí)是用來(lái)區(qū)分日志對(duì)應(yīng)事件嚴(yán)重程度的說(shuō)明,這是所有日志中必須具備的一個(gè)選項(xiàng)。通常日志會(huì)分為 6 個(gè)不同的等級(jí):
作為程序員,一定要合理設(shè)置日志等級(jí),個(gè)人在開(kāi)發(fā)過(guò)程中總結(jié)了以下幾點(diǎn)經(jīng)驗(yàn):
通常在沒(méi)有約束的情況下,程序員的發(fā)揮天馬行空,各種日志內(nèi)容都會(huì)出現(xiàn),這些只有開(kāi)發(fā)自己才能看懂的日志很難進(jìn)行分析和告警。因此我們需要一個(gè)日志頂向下的規(guī)范來(lái)約束項(xiàng)目中的開(kāi)發(fā)人員,讓所有的日志看起來(lái)是一個(gè)人打印的而且是易于分析的。
日志中通常必備的字段有:Time、Level、Location。對(duì)于特定模塊/流程/業(yè)務(wù),還需要有一些 Common 的字段,例如:
日志的字段規(guī)約最好由運(yùn)維平臺(tái)/中間件平臺(tái)自頂向下推動(dòng),約束每個(gè)模塊/流程的程序員按照規(guī)定打印日志。
通常我們建議使用 KeyValue 對(duì)形式的日志格式,比如我們阿里的飛天日志庫(kù)采用的就是這種形式:
[2019-12-30 21:45:30.611992] [WARNING] [958] [block_writer.cpp:671] path:pangu://localcluster/index/3/prom/7/1577711464522767696_0_1577711517 min_time:1577712000000000 max_time:1577715600000000 normal_count:27595 config:prom start_line:57315569 end_line:57343195 latency(ms):42 type:AddBlock
KeyValue 對(duì)的日志可以完全自解析且易于理解,同時(shí)便于日志采集時(shí)自動(dòng)解析。
另外推薦的是 JSON 日志格式,支持以 JSON 格式輸出的日志庫(kù)很多,而且大部分的日志采集 Agent 都支持 JSON 格式的日志收集。
{"addr":"tcp://0.0.0.0:10010","caller":"main.go:98","err":"listen tcp: address tcp://0.0.0.0:10010: too many colons in address","level":"error","msg":"Failed to listen","ts":"2019-03-08T10:02:47.469421Z"}
注意:絕大部分場(chǎng)景不建議使用非可讀的日志格式(例如 ProtoBuf、Binlog 等)。
非必要情況下,盡量不要一條日志輸出成多行,這種對(duì)于采集、解析和索引的代價(jià)都比較高。
日志的輸出量直接影響到磁盤使用以及對(duì)于應(yīng)用的性能消耗,日志太多不利于查看、采集、分析;日志太少不利于監(jiān)控,同時(shí)在出現(xiàn)問(wèn)題的時(shí)候沒(méi)辦法調(diào)查。
一般線上應(yīng)用需合理控制日志的數(shù)據(jù)量:
建議一個(gè)應(yīng)用不同類型的日志輸出到不同的目標(biāo)(文件),這樣便于分類采集、查看和監(jiān)控。例如:
日志作為業(yè)務(wù)系統(tǒng)的輔助模塊,一定不能影響到業(yè)務(wù)正常的工作,因此日志模塊的性能消耗需要單獨(dú)額外注意,一般在選擇/開(kāi)發(fā)日志庫(kù)時(shí),需要對(duì)日志庫(kù)進(jìn)行性能測(cè)試,確保正常情況下日志的性能消耗不超過(guò)整體 CPU 占用的 5%。
注意:一定要確保日志打印是異步的,不能阻塞業(yè)務(wù)系統(tǒng)運(yùn)行。
開(kāi)源的日志庫(kù)非常多,基本每個(gè)語(yǔ)言都有數(shù)十種,選擇一個(gè)符合公司/業(yè)務(wù)需求的日志庫(kù)需要精挑細(xì)選,有一個(gè)簡(jiǎn)單的指導(dǎo)原則是盡可能使用比較流行的日志庫(kù)的穩(wěn)定版本,入坑的幾率要小一點(diǎn)。例如:
在虛擬機(jī)/物理機(jī)的場(chǎng)景中,絕大部分應(yīng)用都以文件的形式輸出日志(只有一些系統(tǒng)應(yīng)用輸出到 syslog/journal);而在容器場(chǎng)景中,多了一個(gè)標(biāo)準(zhǔn)輸出的方式,應(yīng)用把日志打到 stdout 或 stderr 上,日志會(huì)自動(dòng)進(jìn)入到 docker 的日志模塊,可以通過(guò) docker logs 或 kubectl logs 直接查看。
容器的標(biāo)準(zhǔn)輸出只適應(yīng)于比較單一的應(yīng)用,例如 K8s 中的一些系統(tǒng)組件,線上的服務(wù)類應(yīng)用通常都會(huì)涉及到多個(gè)層級(jí)(中間件)、和各種服務(wù)交互,一般日志都會(huì)分為好幾類,如果全部打印到容器的標(biāo)準(zhǔn)輸出,很難區(qū)分處理。<br />同時(shí)容器標(biāo)準(zhǔn)輸出對(duì)于 DockerEngine 的性能消耗特別大,實(shí)測(cè) 10W/s 的日志量會(huì)額外占用 DockerEngine 1 個(gè)核心的 CPU(單核 100%)。
在 Kubernetes 中,還可以將日志庫(kù)直接對(duì)接日志系統(tǒng),日志打印的時(shí)候不落盤而直接傳輸?shù)饺罩鞠到y(tǒng)后端。這種使用方式免去了日志落盤、Agent 采集的過(guò)程,整體性能會(huì)高很多。
這種方式我們一般只建議日志量極大的場(chǎng)景使用,普通情況下還是直接落盤,相比直接發(fā)送到后端的方式,落盤增加了一層文件緩存,在網(wǎng)絡(luò)失敗的情況下還能緩存一定的數(shù)據(jù),在日志系統(tǒng)不可用的情況下我們的研發(fā)運(yùn)維同學(xué)可以直接查看文件的日志,提高整體的可靠性。
Kubernetes 提供了多種存儲(chǔ)方式,一般在云上,都會(huì)提供本地存儲(chǔ)、遠(yuǎn)程文件存儲(chǔ)、對(duì)象存儲(chǔ)等方式。由于日志寫(xiě)入的 QPS 很高,和應(yīng)用也直接相關(guān),如果使用遠(yuǎn)程類型的存儲(chǔ),會(huì)額外多 2-3 次網(wǎng)絡(luò)通信開(kāi)銷。我們一般建議使用本地存儲(chǔ)的方式,可以使用 HostVolume 或者 EmptyDir 的方式,這樣對(duì)于寫(xiě)入和采集的性能影響會(huì)盡可能的小。
相比傳統(tǒng)虛擬機(jī)/物理機(jī)的場(chǎng)景,Kubernetes 對(duì)于節(jié)點(diǎn)、應(yīng)用層提供了強(qiáng)大的調(diào)度、容錯(cuò)、縮/擴(kuò)容能力,我們通過(guò) Kubernetes 很容易就能讓?xiě)?yīng)用獲得高可靠運(yùn)行、極致彈性。這些優(yōu)勢(shì)帶來(lái)的一個(gè)現(xiàn)象是:節(jié)點(diǎn)動(dòng)態(tài)創(chuàng)建/刪除、容器動(dòng)態(tài)創(chuàng)建/刪除,這樣日志也會(huì)隨時(shí)銷毀,沒(méi)辦法保證日志的存儲(chǔ)周期能夠滿足 DevOps、審計(jì)等相關(guān)的需求。
在動(dòng)態(tài)的環(huán)境下實(shí)現(xiàn)日志的長(zhǎng)期存儲(chǔ)只能通過(guò)中心化的日志存儲(chǔ)來(lái)實(shí)現(xiàn),通過(guò)實(shí)時(shí)的日志采集方式,將各個(gè)節(jié)點(diǎn)、各個(gè)容器的日志在秒級(jí)內(nèi)采集到日志中心系統(tǒng)上,即使節(jié)點(diǎn)/容器掛掉也能夠通過(guò)日志還原當(dāng)時(shí)的現(xiàn)場(chǎng)。
日志輸出是日志系統(tǒng)建設(shè)中非常重要的環(huán)節(jié),公司/產(chǎn)品線一定要遵循一個(gè)統(tǒng)一的日志規(guī)范,這樣才能保證后續(xù)日志采集、分析、監(jiān)控、可視化能夠順利進(jìn)行。
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)cdcxhl.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。
標(biāo)題名稱:Kubernetes中的日志詳細(xì)介紹-創(chuàng)新互聯(lián)
分享地址:http://muchs.cn/article48/dgcjep.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供移動(dòng)網(wǎng)站建設(shè)、手機(jī)網(wǎng)站建設(shè)、標(biāo)簽優(yōu)化、搜索引擎優(yōu)化、全網(wǎng)營(yíng)銷推廣、品牌網(wǎng)站設(shè)計(jì)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容
移動(dòng)網(wǎng)站建設(shè)知識(shí)