(1)向全棧工程師轉(zhuǎn)變
應(yīng)用開發(fā)工程師不僅要能開發(fā)前端、無線和后端的代碼,還要具備線上運維能力,包括
排查瀏覽器端的前端問題;
排査域名解析和DNS劫持等常見問題
解決前端JS的錯誤定位和資源加載限制問題;
掌握無線端的網(wǎng)絡(luò)特性:無線情況下建立TCP連接的耗時、數(shù)據(jù)下載的影響、WiFi和4G以及弱網(wǎng)絡(luò)下的內(nèi)容適度匹配等;
掌握無線端請求的全鏈路過程:包括手機端到基站的接入,從省級網(wǎng)關(guān)出口到服務(wù)端網(wǎng)關(guān)再到應(yīng)用系統(tǒng)等;
排查無線端的問題:鏈路染色、日志上報、輿情收集等;掌握無線端的開發(fā)技能;
理解服務(wù)端 Nginx、 Cache、 Tomcat等服務(wù)器的配置文件理解JDK的基本配置參數(shù)、內(nèi)存分配方式和GC調(diào)優(yōu);
具備線上Java運行環(huán)境的排查技能。包括一些開源中間件的報錯定位、操作系統(tǒng)的端口沖突、JWM的異常退出等;
掌握線上應(yīng)用系統(tǒng)的性能指標,包括網(wǎng)絡(luò)、QPS、RT、線程級的CPU消耗、Load、內(nèi)存的dump;
熟悉線上網(wǎng)絡(luò)部署架構(gòu),應(yīng)用服務(wù)器和交換機的連接情況、跨機房和跨單元之間的網(wǎng)絡(luò)情況
熟悉CDN的部署分布;
熟悉源站DNS的解析步驟,包括VIP的管理、LVS的流量分配、應(yīng)用服務(wù)器之間的健康檢查機制等。
以上是工作中經(jīng)常會遇到的問題和常用的技能知識,掌握這些內(nèi)容對排查線上問題非常有幫助。
(2)向全鏈路運維轉(zhuǎn)變
以前開發(fā)人員參與線上運維通常只會關(guān)注應(yīng)用系統(tǒng)本身的問題和業(yè)務(wù)日志錯誤信息,較少關(guān)注整個應(yīng)用的全鏈路問題,所以當問題出現(xiàn)時,由于信息掌握不全,很難具體定位問題。工程師的關(guān)注點應(yīng)從單系統(tǒng)轉(zhuǎn)向全鏈路,必須掌握如下內(nèi)容。
掌握資源依賴的關(guān)聯(lián)系統(tǒng):頁面的資源依賴情況、JS和CSS如何發(fā)布到CDN節(jié)點以及圖片的回源方式等
掌握請求鏈路:掌握無線請求鏈路上每個關(guān)鍵環(huán)節(jié)的信息透出,能夠根據(jù)關(guān)系數(shù)據(jù)追蹤請求軌跡;頁面的輸出、信息是如何聚合的、動態(tài)內(nèi)容和靜態(tài)內(nèi)容頁面中的異步加載等;請求的來源和請求的去向。
(3)向工具化和規(guī)劃化轉(zhuǎn)變
工具化能提升效率和把不規(guī)范的流程程序化,減少人為操作的出錯概率,它包括如下內(nèi)容。
信息的輸出要標準化和規(guī)范化,包括端上的Log、請求跟蹤、應(yīng)用日志輸出格式等;
數(shù)據(jù)的采集要工具化、集中化;數(shù)據(jù)的統(tǒng)計和分析要多維度化;數(shù)據(jù)的展示可以個性化和可視化;
建立長期可以跟蹤變化的網(wǎng)站制作基線數(shù)據(jù),包括性能、成本、鏈路變更基線。
本文地址:http://jiujiu9.com//article/4549.html