精品国产一级在线观看,国产成人综合久久精品亚洲,免费一级欧美大片在线观看

當(dāng)前位置:大數(shù)據(jù)業(yè)界動態(tài) → 正文

調(diào)試大規(guī)模服務(wù)器集群的五大策略

責(zé)任編輯:editor005 作者:伍昆 |來源:企業(yè)網(wǎng)D1Net  2015-01-13 13:28:46 本文摘自:CSDN

隨著互聯(lián)網(wǎng)迅速發(fā)展,用戶訪問量以及服務(wù)器規(guī)模的越來越大,因此,創(chuàng)建一個可靠、穩(wěn)定、優(yōu)質(zhì)的互聯(lián)網(wǎng)服務(wù)是開發(fā)者的首要目標(biāo)。而對于開發(fā)者而言,是否具備一個完善的服務(wù)器調(diào)試策略將對整個部署維護工作有著至關(guān)重要的影響。作者Alex Zhitnitsky現(xiàn)就職于Takipi,其經(jīng)常幫助Java、Scala開發(fā)人員解決服務(wù)器端的錯誤和對常用軟件進行測試。本文是Alex分享的一些經(jīng)驗。

  譯文如下:

  對運行中的真實環(huán)境進行調(diào)試,比在IDE中進行要困難很多。斷點,單步執(zhí)行等都會變得非常奢侈。因此要做的第一件事是要做出周密的調(diào)試計劃,否則漫無目的單純依靠日志記錄的做法,將是非常低效的。其次,規(guī)模越大的架構(gòu)會更容易出現(xiàn)差錯。因此,如何篩查出錯誤源頭,明確哪個步驟出錯是非常重要的。

  一、分布式日志

  對于每條記錄,我們需要認真分析并了解其背后的含義。但是對于龐大的日志記錄我們需要高效的方法來處理,具體請參考這篇文章Logback調(diào)節(jié)的7個方法。


  什么樣的記錄是真正需要的?

  答案是全部!因為代碼會影響到整個應(yīng)用的方方面面。此外,事務(wù)ID也是很重要的。它能有助于處理異常,因為事務(wù)ID經(jīng)常會貫穿于節(jié)點、進程、線程之間。一個較好的處理方法是在App的每個線程入口生成一個UUID。然后把該ID附加到日志記錄中,進行全程監(jiān)視。該方法在分布式和異步日志中起著舉足輕重的作用,特別是與日志管理工具如Logstash和Loggly等一起使用時。

  異常處理

  未知異常很容易會導(dǎo)致系統(tǒng)崩潰。所以建議在代碼末端設(shè)置一個全局異常處理句柄,例如在Java中進行下面的代碼編寫:

這或許看起來與Tomcat或Akka框架有點類似。最后這里給出三種處理未知異常時的方法:

  1. 線程名:根據(jù)需要處理的請求來變更線程名是個巧妙的方法。例如在事務(wù)處理的任何時間,把事務(wù)ID先附加到線程,然后在結(jié)束時移除掉。

  2. 本地線程存儲(Thread-local storage,TLS):這是一種使線程特定數(shù)據(jù)從線程對象分離的方法。借助這些特定數(shù)據(jù)能便于對出現(xiàn)的錯誤進行排查。例如事務(wù)ID,時間或用戶名。否則在欠缺這些數(shù)據(jù)和線程名的情況下,我們將不得不花費更多時間來處理未知異常。

  3. 線程映射表(Mapped Diagnostic Context,MDC):MDC類似于本地線程概念,是日志框架的一部分如Log4j或Logback。它在日志級別生成了一個靜態(tài)映射表,能夠較TLS實現(xiàn)更多高級特性。

  二、快人一步的Jstack

  Jstack對Java開發(fā)者來說并不陌生,這是一款強大的JDK工具。簡單來說,Jstack能夠進入一個正在運行的進程然后輸出所有的線程meta信息,例如堆跟蹤,框架,鎖等等。此外它能夠?qū)σ唁N毀的進程進行heap dumps或core dumps分析。

  不過很多時候Jstack是用在回顧的環(huán)節(jié),如果錯誤已經(jīng)發(fā)生,它反饋的可能是過時的信息。因此如何更主動地使用Jstack是關(guān)鍵所在。例如,設(shè)置一個吞吐量閥值然后在該值下降時啟動jstack。

三、 Stateful Jstack

  Jstack應(yīng)用時需要注意的另一個問題是由于它會返回非常多的線程meta數(shù)據(jù),如果缺乏相關(guān)的實際狀態(tài)數(shù)據(jù),將會對錯誤排查造成不便。以數(shù)據(jù)庫查詢?yōu)槔樱梢约由先缦乱恍写a:

我們來比較加入前后的數(shù)據(jù)輸出:

  加入前:

  “pool-1-thread-1″ #17 prio=5 os_prio=31 tid=0x00007f9d620c9800 nid=0x6d03 in Object.wait() [0x000000013ebcc000]

  加入后:

  ”Queue Processing Thread, MessageID: AB5CAD, type: AnalyzeGraph, queue: ACTIVE_PROD, Transaction_ID: 5678956, Start Time: 10/8/2014 18:34″ #17 prio=5 os_prio=31 tid=0x00007f9d620c9800 nid=0x6d03 in Object.wait() [0x000000013ebcc000]

  不難看出,加入代碼后的信息輸出顯得更加清晰了。例如線程正在做什么,接收了什么參數(shù)如事務(wù)ID和消息ID。這些對后續(xù)的回滾,錯誤重現(xiàn)、分離等步驟都是很有幫助的。

  四、 開源追蹤工具BTrace

  如果在不依靠日志和改變代碼的前提下,如何去追蹤運行時JVM狀態(tài)呢?答案是BTrace Java代理。在添加該代理后,可使用BTrace腳本語言來獲取相關(guān)信息。

  例如以下腳本:

上述代碼對全部ClassLoaders及其子類進行跟蹤,當(dāng)defineClass返回時,該腳本會列出載入的類并啟動JStack。但是我們不建議在實際環(huán)境中長期使用BTrace。因為Java代理會造成一定的資源開銷,同時需要編寫不同的腳本來進行追蹤。不過在想避免重啟JVM的情況下在運行時環(huán)境修改跟蹤腳本,BTrace是個不錯的選擇。

  五、自定義JVM代理

  在不改動服務(wù)器代碼的前提下進行調(diào)試,JVM代理是最佳選擇。類似于BTrace,我們可以嘗試編寫自定義Java代理。這種代理可以進入對象結(jié)構(gòu)體然后在對象實例化的時候進行堆追蹤。然后我們可以對結(jié)果進行分析并掌握具體的載入過程。這是BTrace所不具備的,因為BTrace有限制和只能進行讀操作。請看下面的示例代碼:

這里創(chuàng)建了一個transformer對象,并注冊到一個能對類進行變更的對象之上。完整代碼請點擊這里進行查看。

  小結(jié)

  綜上所述,獲得的有價值數(shù)據(jù)越多,解決問題的速度就越快。在當(dāng)今信息為王的時代,宕機時間的影響幾以秒計,因此是否具備一個完善的服務(wù)器調(diào)試策略將對整個部署維護工作有著至關(guān)重要的影響。

關(guān)鍵字:線程Jstack實例化

本文摘自:CSDN

x 調(diào)試大規(guī)模服務(wù)器集群的五大策略 掃一掃
分享本文到朋友圈
當(dāng)前位置:大數(shù)據(jù)業(yè)界動態(tài) → 正文

調(diào)試大規(guī)模服務(wù)器集群的五大策略

責(zé)任編輯:editor005 作者:伍昆 |來源:企業(yè)網(wǎng)D1Net  2015-01-13 13:28:46 本文摘自:CSDN

隨著互聯(lián)網(wǎng)迅速發(fā)展,用戶訪問量以及服務(wù)器規(guī)模的越來越大,因此,創(chuàng)建一個可靠、穩(wěn)定、優(yōu)質(zhì)的互聯(lián)網(wǎng)服務(wù)是開發(fā)者的首要目標(biāo)。而對于開發(fā)者而言,是否具備一個完善的服務(wù)器調(diào)試策略將對整個部署維護工作有著至關(guān)重要的影響。作者Alex Zhitnitsky現(xiàn)就職于Takipi,其經(jīng)常幫助Java、Scala開發(fā)人員解決服務(wù)器端的錯誤和對常用軟件進行測試。本文是Alex分享的一些經(jīng)驗。

  譯文如下:

  對運行中的真實環(huán)境進行調(diào)試,比在IDE中進行要困難很多。斷點,單步執(zhí)行等都會變得非常奢侈。因此要做的第一件事是要做出周密的調(diào)試計劃,否則漫無目的單純依靠日志記錄的做法,將是非常低效的。其次,規(guī)模越大的架構(gòu)會更容易出現(xiàn)差錯。因此,如何篩查出錯誤源頭,明確哪個步驟出錯是非常重要的。

  一、分布式日志

  對于每條記錄,我們需要認真分析并了解其背后的含義。但是對于龐大的日志記錄我們需要高效的方法來處理,具體請參考這篇文章Logback調(diào)節(jié)的7個方法。


  什么樣的記錄是真正需要的?

  答案是全部!因為代碼會影響到整個應(yīng)用的方方面面。此外,事務(wù)ID也是很重要的。它能有助于處理異常,因為事務(wù)ID經(jīng)常會貫穿于節(jié)點、進程、線程之間。一個較好的處理方法是在App的每個線程入口生成一個UUID。然后把該ID附加到日志記錄中,進行全程監(jiān)視。該方法在分布式和異步日志中起著舉足輕重的作用,特別是與日志管理工具如Logstash和Loggly等一起使用時。

  異常處理

  未知異常很容易會導(dǎo)致系統(tǒng)崩潰。所以建議在代碼末端設(shè)置一個全局異常處理句柄,例如在Java中進行下面的代碼編寫:

這或許看起來與Tomcat或Akka框架有點類似。最后這里給出三種處理未知異常時的方法:

  1. 線程名:根據(jù)需要處理的請求來變更線程名是個巧妙的方法。例如在事務(wù)處理的任何時間,把事務(wù)ID先附加到線程,然后在結(jié)束時移除掉。

  2. 本地線程存儲(Thread-local storage,TLS):這是一種使線程特定數(shù)據(jù)從線程對象分離的方法。借助這些特定數(shù)據(jù)能便于對出現(xiàn)的錯誤進行排查。例如事務(wù)ID,時間或用戶名。否則在欠缺這些數(shù)據(jù)和線程名的情況下,我們將不得不花費更多時間來處理未知異常。

  3. 線程映射表(Mapped Diagnostic Context,MDC):MDC類似于本地線程概念,是日志框架的一部分如Log4j或Logback。它在日志級別生成了一個靜態(tài)映射表,能夠較TLS實現(xiàn)更多高級特性。

  二、快人一步的Jstack

  Jstack對Java開發(fā)者來說并不陌生,這是一款強大的JDK工具。簡單來說,Jstack能夠進入一個正在運行的進程然后輸出所有的線程meta信息,例如堆跟蹤,框架,鎖等等。此外它能夠?qū)σ唁N毀的進程進行heap dumps或core dumps分析。

  不過很多時候Jstack是用在回顧的環(huán)節(jié),如果錯誤已經(jīng)發(fā)生,它反饋的可能是過時的信息。因此如何更主動地使用Jstack是關(guān)鍵所在。例如,設(shè)置一個吞吐量閥值然后在該值下降時啟動jstack。

三、 Stateful Jstack

  Jstack應(yīng)用時需要注意的另一個問題是由于它會返回非常多的線程meta數(shù)據(jù),如果缺乏相關(guān)的實際狀態(tài)數(shù)據(jù),將會對錯誤排查造成不便。以數(shù)據(jù)庫查詢?yōu)槔樱梢约由先缦乱恍写a:

我們來比較加入前后的數(shù)據(jù)輸出:

  加入前:

  “pool-1-thread-1″ #17 prio=5 os_prio=31 tid=0x00007f9d620c9800 nid=0x6d03 in Object.wait() [0x000000013ebcc000]

  加入后:

  ”Queue Processing Thread, MessageID: AB5CAD, type: AnalyzeGraph, queue: ACTIVE_PROD, Transaction_ID: 5678956, Start Time: 10/8/2014 18:34″ #17 prio=5 os_prio=31 tid=0x00007f9d620c9800 nid=0x6d03 in Object.wait() [0x000000013ebcc000]

  不難看出,加入代碼后的信息輸出顯得更加清晰了。例如線程正在做什么,接收了什么參數(shù)如事務(wù)ID和消息ID。這些對后續(xù)的回滾,錯誤重現(xiàn)、分離等步驟都是很有幫助的。

  四、 開源追蹤工具BTrace

  如果在不依靠日志和改變代碼的前提下,如何去追蹤運行時JVM狀態(tài)呢?答案是BTrace Java代理。在添加該代理后,可使用BTrace腳本語言來獲取相關(guān)信息。

  例如以下腳本:

上述代碼對全部ClassLoaders及其子類進行跟蹤,當(dāng)defineClass返回時,該腳本會列出載入的類并啟動JStack。但是我們不建議在實際環(huán)境中長期使用BTrace。因為Java代理會造成一定的資源開銷,同時需要編寫不同的腳本來進行追蹤。不過在想避免重啟JVM的情況下在運行時環(huán)境修改跟蹤腳本,BTrace是個不錯的選擇。

  五、自定義JVM代理

  在不改動服務(wù)器代碼的前提下進行調(diào)試,JVM代理是最佳選擇。類似于BTrace,我們可以嘗試編寫自定義Java代理。這種代理可以進入對象結(jié)構(gòu)體然后在對象實例化的時候進行堆追蹤。然后我們可以對結(jié)果進行分析并掌握具體的載入過程。這是BTrace所不具備的,因為BTrace有限制和只能進行讀操作。請看下面的示例代碼:

這里創(chuàng)建了一個transformer對象,并注冊到一個能對類進行變更的對象之上。完整代碼請點擊這里進行查看。

  小結(jié)

  綜上所述,獲得的有價值數(shù)據(jù)越多,解決問題的速度就越快。在當(dāng)今信息為王的時代,宕機時間的影響幾以秒計,因此是否具備一個完善的服務(wù)器調(diào)試策略將對整個部署維護工作有著至關(guān)重要的影響。

關(guān)鍵字:線程Jstack實例化

本文摘自:CSDN

電子周刊
回到頂部

關(guān)于我們聯(lián)系我們版權(quán)聲明隱私條款廣告服務(wù)友情鏈接投稿中心招賢納士

企業(yè)網(wǎng)版權(quán)所有 ©2010-2024 京ICP備09108050號-6 京公網(wǎng)安備 11010502049343號

^
  • <menuitem id="jw4sk"></menuitem>

    1. <form id="jw4sk"><tbody id="jw4sk"><dfn id="jw4sk"></dfn></tbody></form>
      主站蜘蛛池模板: 星子县| 察隅县| 青田县| 扬州市| 政和县| 安龙县| 鹿泉市| 玉田县| 安顺市| 肃北| 龙岩市| 建宁县| 鱼台县| 遵义县| 广水市| 靖安县| 克拉玛依市| 普兰店市| 观塘区| 长乐市| 旬邑县| 莒南县| 沐川县| 陇川县| 香港| 镇原县| 余姚市| 梁山县| 南召县| 布尔津县| 乐平市| 海安县| 南和县| 新竹市| 林西县| 眉山市| 万盛区| 镇宁| 乡宁县| 开封县| 简阳市|