阿里如何做到百萬量級硬件故障自愈? 頂 原

隨着阿里大數據產品業務的增長,服務器數量不斷增多,IT運維壓力也成比例增大。各種軟、硬件故障而造成的業務中斷,成爲穩定性影響的重要因素之一。本文詳細解讀阿里如何實現硬件故障預測、服務器自動下線、服務自愈以及集羣的自平衡重建,真正在影響業務之前實現硬件故障自動閉環策略,對於常見的硬件故障無需人工干預即可自動閉環解決。

1.背景

1.1.面臨挑戰

對於承載阿里巴巴集團95%數據存儲及計算的離線計算平臺MaxCompute,隨着業務增長,服務器規模已達到數十萬臺,而離線作業的特性導致硬件故障不容易在軟件層面被發現,同時集團統一的硬件報障閾值常常會遺漏一些對應用有影響的硬件故障,對於每一起漏報,都對集羣的穩定性構成極大的挑戰。

針對挑戰,我們面對兩個問題:硬件故障的及時發現與故障機的業務遷移。下面我們會圍繞這兩個問題進行分析,並詳細介紹落地的自動化硬件自愈平臺——DAM。在介紹之前我們先了解下飛天操作系統的應用管理體系——天基(Tianji)。

1.2.天基應用管理

MaxCompute是構建在阿里數據中心操作系統——飛天(Apsara)之上,飛天的所有應用均由天基管理。天基是一套自動化數據中心管理系統,管理數據中心中的硬件生命週期與各類靜態資源(程序、配置、操作系統鏡像、數據等)。而我們的硬件自愈體系正是與天基緊密結合,利用天基的Healing機制構建面向複雜業務的硬件故障發現、自愈維修閉環體系。

477062ebbd519ce80cd2ff3c1c84b2e8b99f6f79

透過天基,我們可以將各種物理機的指令(重啓、重裝、維修)下發,天基會將其翻譯給這臺物理機上每個應用,由應用根據自身業務特性及自愈場景決策如何響應指令。

2.硬件故障發現

2.1.如何發現

我們所關注的硬件問題主要包含:硬盤、內存、CPU、網卡電源等,下面列舉對於常見硬件問題發現的一些手段和主要工具:

e9fb6f6e229091c5e72f40b5837914e6e16b3803

在所有硬件故障中,硬盤故障佔比50%以上,下面分析一下最常見的一類故障:硬盤媒介故障。通常這個問題表象就是文件讀寫失敗/卡住/慢。但讀寫問題卻不一定是媒介故障產生,所以我們有必要說明一下媒介故障的在各層的表象。

e78561896e582a4a2f29f469213820676252f36a

a. 系統日誌報錯是指在/var/log/messages中能夠找到類似下面這樣的報錯

 
 

 

Sep 3 13:43:22 host1.a1 kernel: : [14809594.557970] sd 6:0:11:0: [sdl] Sense Key : Medium Error [current]
Sep 3 20:39:56 host1.a1 kernel: : [61959097.553029] Buffer I/O error on device sdi1, logical block 796203507

b. tsar io指標變化是指rs/ws/await/svctm/util等這些指標的變化或突變,由於報錯期間會引起讀寫的停頓,所以通常會體現在iostat上,繼而被採集到tsar中。

 ●  在tsar io指標中,存在這樣一條規則讓我們區分硬盤工作是否正常 qps=ws+rs<100 & util>90,假如沒有大規模的kernel問題,這種情況一般都是硬盤故障引起的。

c. 系統指標變化通常也由於io變化引起,比如D住引起load升高等。

d. smart值跳變具體是指197(Current_Pending_Sector)/5(Reallocated_Sector_Ct)的跳變。這兩個值和讀寫異常的關係是:

 ●  媒介讀寫異常後,在smart上能觀察到197(pending) +1,表明有一個扇區待確認。
 ●  隨後在硬盤空閒的時候,他會對這個197(pending)中攢的各種待確認扇區做確認,如果讀寫通過了,則197(pending) -1,如果讀寫不通過則 197(pending)-1 且 5(reallocate)+1。

總結下來,在整條報錯鏈路中,只觀察一個階段是不夠的,需要多個階段綜合分析來證明硬件問題。由於我們可以嚴格證明媒介故障,我們也可以反向推導,當存在未知問題的時候能迅速地區分出是軟件還是硬件問題。

上述的工具是結合運維經驗和故障場景沉澱出來,同時我們也深知單純的一個發現源是遠遠不夠的,因此我們也引入了其他的硬件故障發現源,將多種檢查手段結合到一起來最終確診硬件故障。

2.2.如何收斂

上一章節提到的很多工具和路徑用來發現硬件故障,但並不是每次發現都一定報故障,我們進行硬件問題收斂的時候,保持了下面幾個原則:

 ●  指標儘可能與應用/業務無關:有些應用指標和硬件故障相關性大,但只上監控,不作爲硬件問題的發現來源。 舉一個例子,當io util大於90%的時候硬盤特別繁忙,但不代表硬盤就存在問題,可能只是存在讀寫熱點。我們只認爲io util>90且iops<30 超過10分鐘的硬盤可能存在硬件問題。
 ●  採集敏感,收斂謹慎:對於可能的硬件故障特徵都進行採集,但最終自動收斂分析的時候,大多數採集項只做參考,不作爲報修依據。 還是上一個硬盤io util的例子,如果單純出現io util>90且iops<30的情況,我們不會自動報修硬盤,因爲kernel問題也可能會出現這個情況。只有當 smartctl超時/故障扇區 等明確故障項出現後,兩者關聯才確診硬盤故障,否則只是隔離觀察,不報修。

2.3.覆蓋率

以某生產集羣,在20xx年x月的IDC工單爲例,硬件故障及工單統計如下:

dc7e6c43c566778447740e4868bbc2bbdd6928b3

去除帶外故障的問題,我們的硬件故障發現佔比爲97.6%。

3.硬件故障自愈

3.1 自愈流程

針對每臺機器的硬件問題,我們會開一個自動輪轉工單來跟進,當前存在兩套自愈流程:【帶應用維修流程】和【無應用維修流程】,前者針對的是可熱拔插的硬盤故障,後者是針對餘下所有的整機維修硬件故障。

50fb2499fd65be81aadaf65bed95d71a43f9945f

在我們的自動化流程中,有幾個比較巧妙的設計:

a. 無盤診斷

 ●  對於宕機的機器而言,無法進無盤(ramos)纔開【無故宕機】維修工單,這樣能夠大量地減少誤報,減少服務檯同學負擔。
 ●  無盤中的壓測可以完全消除當前版本的kernel或軟件的影響,真實地判斷出硬件是否存在性能問題。

b. 影響面判斷/影響升級

 ●  對於帶應用的維修,我們也會進行進程是否D住的判斷。如果存在進程D住時間超過10分鐘,我們認爲這個硬盤故障的影響面已擴大到了整機,需要進行重啓消除影響。
 ●  在重啓的時候如果出現了無法啓動的情況,也無需進行人工干預,直接進行影響升級,【帶應用維修流程】直接升級成【無應用維修流程】。

c. 未知問題自動化兜底

 ●  在運行過程中,會出現一些機器宕機後可以進無盤,但壓測也無法發現任何硬件問題,這個時候就只能讓機器再進行一次裝機,有小部分的機器確實在裝機過程中,發現了硬件問題繼而被修復了。

d. 宕機分析

 ●  整個流程巧妙的設計,使得我們在處理硬件故障的時候,同時具備了宕機分析的能力。
 ●  不過整機流程還以解決問題爲主導向,宕機分析只是副產品。
 ●  同時,我們也自動引入了集團的宕機診斷結果進行分析,達到了1+1>2的效果。

3.2.流程統計分析

如果是同樣的硬件問題反覆觸發自愈,那麼在流程工單的統計,能夠發現問題。例如聯想RD640的虛擬串口問題,在還未定位出根因前,我們就通過統計發現了:同個機型的機器存在反覆宕機自愈的情況,即使機器重裝之後,問題也還是會出現。接下來我們就隔離了這批機器,保障集羣穩定的同時,爲調查爭取時間。

3.3.業務關聯誤區

事實上,有了上面這套完整的自愈體系之後,某些業務上/kernel上/軟件上需要處理的問題,也可以進入這個自愈體系,然後走未知問題這個分支。其實硬件自愈解決業務問題,有點飲鴆止渴,容易使越來越多還沒想清楚的問題,嘗試通過這種方式來解決兜底。

fca6aad501e4892eb6e8e3920805b40e22dace11

當前我們逐步地移除對於非硬件問題的處理,迴歸面向硬件自愈的場景(面向軟件的通用自愈也有系統在承載,這類場景與業務的耦合性較大,無法面向集團通用化),這樣也更利於軟硬件問題分類和未知問題發現。

4.架構演進

4.1.雲化

最初版本的自愈架構是在每個集羣的控制機上實現,因爲一開始時候運維同學也是在控制機上處理各種問題。但隨着自動化地不斷深入,發現這樣的架構嚴重阻礙了數據的開放。於是我們採用中心化架構進行了一次重構,但中心化架構又會遇到海量數據的處理問題,單純幾個服務端根本處理不過來。

因此我們對系統進一步進行分佈式服務化的重構,以支撐海量業務場景,將架構中的各個模塊進行拆解,引入了 阿里雲日誌服務(sls)/阿里雲流計算(blink)/阿里雲分析數據庫(ads) 三大神器,將各個採集分析任務由雲產品分擔,服務端只留最核心的硬件故障分析和決策功能。

下面是DAM1與DAM3的架構對比

2b1df4ab3fb4b6f537d2fe61bae8a0c6b760206a

4.2.數據化

隨着自愈體系的不斷深入,各階段的數據也有了穩定的產出,針對這些數據的更高維分析,能讓我們發現更多有價值且明確的信息。同時,我們也將高維的分析結果進行降維,採用健康分給每臺機器打標。通過健康分,運維的同學可以快速知曉單臺機器、某個機櫃、某個集羣的硬件情況。

4.3.服務化

基於對全鏈路數據的掌控,我們將整個故障自愈體系,作爲一個硬件全生命週期標準化服務,提供給不同的產品線。基於對決策的充分抽象,自愈體系提供各類感知閾值,支持不同產品線的定製,形成適合個性化的全生命週期服務。

5.故障自愈閉環體系

在AIOps的感知、決策、執行閉環體系中,軟件/硬件的故障自愈是最常見的應用場景,行業中大家也都選擇故障自愈作爲首個AIOps落地點。在我們看來,提供一套通用的故障自愈閉環體系是實現AIOps、乃至NoOps(無人值守運維)的基石,應對海量系統運維,智能自愈閉環體系尤爲重要。

5.1.必要性

在一個複雜的分佈式系統中,各種架構間不可避免地會出現運行上的衝突,而這些衝突的本質就在於信息不對稱。而信息不對稱的原因是,每種分佈式軟件架構在設計都是內斂閉環的。現在,通過各種機制各種運維工具,可以抹平這些衝突,然而這種方式就像是在打補丁,伴隨着架構的不斷升級,補丁似乎一直都打不完,而且越打越多。因此,我們有必要將這個行爲抽象成自愈這樣一個行爲,在架構層面顯式地聲明這個行爲,讓各軟件參與到自愈的整個流程中,將原本的衝突通過這種方式轉化爲協同。

當前我們圍繞運維場景中最大的衝突點:硬件與軟件衝突,進行架構和產品設計,通過自愈的方式提升複雜的分佈式系統的整體魯棒性。

5.2.普適性

透過大量機器的硬件自愈輪轉,我們發現:

 ●  被納入自愈體系的運維工具的副作用逐漸降低(由於大量地使用運維工具,運維工具中的操作逐漸趨於精細化)。
 ●  被納入自愈體系的人工運維行爲也逐漸變成了自動化。
 ●  每種運維動作都有了穩定的SLA承諾時間,不再是隨時可能運行報錯的運維腳本。

因此,自愈實際上是在複雜的分佈式系統上,將運維自動化進行充分抽象後,再構築一層閉環的架構,使得架構生態形成更大的協調統一。

作者: 隱林
原文鏈接
本文爲雲棲社區原創內容,未經允許不得轉載。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章