vrrp_script chk_http_port { tcp
script "</dev/tcp/127.0.0.1/8088"
interval 1
weight -2
} rest
keepalived讀配置文件遇到錯誤是不給任何提示的,這個每每讓初用着摸不着頭腦——明明配了xxx,怎麼不起做用呢?——好比說關鍵字TCP_CHECK後面得有個空格才能寫{,不然就是不生效!這個蛋疼的設定讓我抓狂了一個上午。日誌
有個方法可以縮短抓狂的時間,就是利用keepalived的啓動參數:
1
keepalived -D -S 0 -d"ip
-D是讓keepalived詳細記錄log
-d是在日誌裏打出keepalived讀到的配置信息
-S 0是到會將日誌發送給syslog,且日誌定爲LOCAL0it
這裏須要讓syslog幫忙把接收到的日誌寫到文件以便咱們查看:加一行配置到syslog.conf,而後重啓syslog服務。
1
echo "local0.* /var/log/keepalived.log">> /etc/syslog.conf
2
/etc/init.d/syslog restart配置
這樣,你就能夠經過查看/var/log/keepalived.log來檢查你是否成功地使用了keepalived了。
例如我有這樣的配置
1
MISC_CHECK {
2
misc_path "/root/pingM.sh"
3
# misc_timeout 5
4
}keepalived
啓動時下面這段log就反映了個人配置,而若是我配置文件中的MISC_CHECK以後不加空格,這段信息是絕對不會出現的。
1
Nov 22 01:13:52 localhost Keepalived_healthcheckers: ------< Health checkers >------
2
Nov 22 01:13:52 localhost Keepalived_healthcheckers: 10.224.178.164:3306
3
Nov 22 01:13:52 localhost Keepalived_healthcheckers: Keepalive method = MISC_CHECK
4
Nov 22 01:13:52 localhost Keepalived_healthcheckers: script = /root/pingM.sh
5
Nov 22 01:13:52 localhost Keepalived_healthcheckers: timeout = 0
6
Nov 22 01:13:52 localhost Keepalived_healthcheckers: dynamic = NO
Share on:FacebookTwitter方法