watchdog
(看門狗)是
redis
2.6 版本將發布的乙個新特性,它用於診斷redis的延遲問題,這一功能有點類似於慢日誌。主要是記錄一些太慢的行為,以便排查原因。其具體工作原理和流程如下:
redis作者指出,watchdog還是乙個實驗性功能,開啟它可能會對資料產生影響,所以建議在使用時做好資料備份。
watchdog的具體設定方法如下例所示:
config set watchdog-period 500通過config set命令設定watchdog-period引數,其值單位為毫秒,在上例中,執行時間超過500毫秒的操作將會被記錄下來。
注意:這個引數只能通過config set來設定,在配置檔案裡是無法設定的,因為在預設情況下,是絕不推薦開啟它的。對效能和穩定性都有影響。當你診斷完成後,可以再通過上面的命令,將延遲時間設定為0來關閉watchdog的功能。
watchdog在日誌中的輸出如下例:
[8547 | signal handler] (1333114359)上面日誌是通過debug sleep命令來產生的,你在診斷自己具體問題的時候可能會出現不同的日誌。在診斷問題時,如果同時打出了多段日誌,盡可能的都發出來,這樣方便開發人員進行錯誤排查。--- watchdog timer expired ---
/lib/libc.so.6(nanosleep+0x2d) [0x7f16b5c2d39d]
/lib/libpthread.so.0(+0xf8f0) [0x7f16b5f158f0]
/lib/libc.so.6(nanosleep+0x2d) [0x7f16b5c2d39d]
/lib/libc.so.6(usleep+0x34) [0x7f16b5c62844]
./redis-server(debugcommand+0x3e1) [0x43ab41]
./redis-server(call+0x5d) [0x415a9d]
./redis-server(processcommand+0x375) [0x415fc5]
./redis-server(processinputbuffer+0x4f) [0x4203cf]
./redis-server(readqueryfromclient+0xa0) [0x4204e0]
./redis-server(aeprocessevents+0x128) [0x411b48]
./redis-server(aemain+0x2b) [0x411dbb]
./redis-server(main+0x2b6) [0x418556]
/lib/libc.so.6(__libc_start_main+0xfd) [0x7f16b5ba1c4d]
./redis-server() [0x411099]
------
硬體看門狗和軟體看門狗
看門狗,又叫watchdog timer,從本質上來說就是乙個定時器電路,一般有乙個輸入和乙個輸出,其中的輸入叫做餵狗,輸出一般連線到另外乙個部分的復位端,另外乙個部分就是所要處理的部分,暫且稱之為mcu。在mcu正常工作的時候,每隔一段時間輸出乙個訊號到餵狗端,給看門狗電路清零,如果在超過規定的時...
關閉看門狗
看門狗作用 在嵌入式領域,有些系統需要長期執行在無人看守的環境。在執行過程中,難免不出現系統宕機的情況,這時就需要系統自身帶有一種自動重啟的功能。watchdog一般是乙個硬體模組,其作用就是在系統宕機時,幫助系統實現重新啟動。看門狗工作方式 watchdog在硬體上實現了計時功能,啟動計時後,使用...
獨立看門狗
用我自己的話來解釋一下看門狗 看門狗就是一段程式正常執行時,阻止程式復位的 另一方面也就是說,程式非正常執行時,不能執行,程式就會產生復位,從而跳出非正常程式執行狀態。在由微控制器構成的微型計算機系統中,由於微控制器的工作常常會受到來自外界電磁場的干擾,造成程式的跑飛,而陷入死迴圈,程式的正常執行被...