shell實現(xiàn)網(wǎng)絡(luò)client方法

需要把線上的access日志發(fā)送到另一個程序接收
開始想著用python實現(xiàn),雖然python也有實現(xiàn)類似tail -f的方式,但太麻煩,而且效率也有折扣
偶然發(fā)現(xiàn)了shell可以實現(xiàn)網(wǎng)絡(luò)client,并且只用幾行代碼就可以實現(xiàn)

先上代碼:

trap "exec 8<&-;exec 8>&-" 0  file='/data/nginx/llogs/access.log'  exec 8<>/dev/tcp/10.3.0.200/9001  tail -F "$file" | grep --line-buffered "sid">&8

超級簡單,實際處理的邏輯的代碼就2行以下是代碼說明:
第一行主要是捕獲程序退出狀態(tài),退出后關(guān)閉連接
第二行定義日志文件
第三行建立網(wǎng)絡(luò)連接,linux有個特殊的文件/dev/(udp|tcp)/ip/port
把這個文件綁定到一個文件描述符上即可建立對應(yīng)的網(wǎng)絡(luò)連接,文件描述符大于3即可
第四行發(fā)送數(shù)據(jù)到這個建立好的通道中
因為grep會有緩沖區(qū),默認等緩沖區(qū)滿了后才會輸出數(shù)據(jù),因此必須加上–line-buffered參數(shù),使用行緩沖
不然server端收到的數(shù)據(jù)會有斷行。

這種agent超級簡單功能性能也不錯但有個弊端
agent和server建立通道后,若server掛了,那么agent通道斷開就也掛了,程序就會退出(tcp client有這個問題,upd沒有)
或是網(wǎng)絡(luò)不好也可能導(dǎo)致agent退出(我這次沒有這個問題都是光纖互聯(lián)網(wǎng)絡(luò))
所以需要有對應(yīng)的監(jiān)控程序檢測agent,異常時自動重啟,或者如果網(wǎng)絡(luò)質(zhì)量不錯的話考慮使用udp

? 版權(quán)聲明
THE END
喜歡就支持一下吧
點贊15 分享