shell 操作釘釘機器人實現(xiàn)告警提醒的方法
我們知道,之前的運維告警多通過mail 等方式通知到相應的人員,難以實現(xiàn)隨時隨地的查看。隨著手機APP的發(fā)展,很多告警開始發(fā)送到IM軟件上去。目前比較常用的是發(fā)送到微信和釘釘上,今天我們將重點放在釘釘上。群機器人是釘釘群的高級擴展功能,群機器人可以將第三方服務的信息聚合到群聊中,實現(xiàn)自動化的信息同步。借助釘釘機器人,通過官方提供的API,可以很方便的post數(shù)據到相應的接收人 。群機器人支持Webhook協(xié)議的自定義接入,支持更多可能性,例如:你可將運維報警通過自定義機器人聚合到釘釘群實現(xiàn)提醒功能。
Shell 腳本語言是實現(xiàn)Linux系統(tǒng)管理及自動化所必須的重要工具。熟練地編寫Shell語言可以提升運維人員的工作效率,適應復雜的工作環(huán)境。
在本文,我們聚焦通過shell腳本語言實現(xiàn)借助釘釘機器人發(fā)送告警信息。
1: 了解更多群機器人的信息,大家可登入官網學習
https://ding-doc.dingtalk.com/doc
2.給自己的機器人起個好聽的名字
操作如下:
3.使用命令行工具curl
curl是一個命令行工具,通過指定的URL來上傳或下載數(shù)據,并將數(shù)據展示出來。curl中的c
表示client,而URL,就是URL。
3.1 與curl一起使用的協(xié)議,最多的還是HTTP
在每一個HTTP請求中,都有一個對應的方法,常用的方法有:GET
、POST
、HEAD
和PUT
。如果在一個curl命令中不指定具體的方法,那么默認的就是使用GET
方法。對于其它的方法,可以在curl命令中指定:
method | option |
---|---|
POST | -d或-F |
HEAD | -I |
PUT | -T |
POST
是HTTP中向服務端提交數(shù)據的一種方法。在瀏覽器中,可以在表單中填寫完數(shù)據后,瀏覽器就會默認將填寫的數(shù)據使用key=value
串的形式進行轉化。在curl中,我們可以使用-d
或--data
選項來指定具體的數(shù)據。
3.2 釘釘使用curl工具主要相關的兩個參數(shù)
參數(shù)(短形式) | 參數(shù)(長形式) | 解釋 | 具體描述 |
-d | --data | HTTP POST data (H) | 把指定的數(shù)據發(fā)送到服務器上. |
-H | --header | Custom header to pass to server (H) |
當使用POST方法提交數(shù)據時,對于提交的數(shù)據主要有如下四種形式:
Content-Type是一個Header,如果不指定的話,默認使用application/x-www-form-urlencoded形式傳輸數(shù)據,當需要使用別的形式進行數(shù)據傳輸?shù)脑挘枰付℉eader。 |
3.3 調用格式(案例)
curl 'https://oapi.dingtalk.com/robot/send?access_token=xxxxxxxx' \ -H 'Content-Type: application/json' \ -d '{"msgtype": "text", "text": { "content": "我就是我, 是不一樣的煙火" } }'
測試過程中,請將上面命令直接復制到命令行,再將xxxxxxxx替換為真實access_token。
4.不一樣的markdown類型
官網中除markdown類型,其它的消息類型的 測試例子(腳本) 都可以直接在shell中演示
官網markdown類型的測試案例
{ "msgtype": "markdown", "markdown": { "title":"杭州天氣", "text": "#### 杭州天氣 @156xxxx8827\n" + "> 9度,西北風1級,空氣良89,相對溫度73%\n\n" + "> \n" + "> ###### 10點20分發(fā)布 [天氣](http://www.thinkpage.cn/) \n" }, "at": { "atMobiles": [ "156xxxx8827", "189xxxx8325" ], "isAtAll": false } }
在shell中執(zhí)行報錯信息,錯誤信息為:
{"errcode":40035,"errmsg":"缺少參數(shù) json"}
報錯原因是 "text" 欄位對應的 value 值中的 “+” 運算符導致,將中間的
" +
"
刪除。
即可執(zhí)行代碼更新為:
{ "msgtype": "markdown", "markdown": { "title":"杭州天氣", "text": "#### 杭州天氣 @156xxxx8827\n> 9度,西北風1級,空氣良89,相對溫度73%\n\n> \n> ###### 10點20分發(fā)布 [天氣](http://www.thinkpage.cn/) \n" }, "at": { "atMobiles": [ "156xxxx8827", "189xxxx8325" ], "isAtAll": false } }
執(zhí)行OK,錯誤消失。
執(zhí)行情況如下:
成功收到的信息,內容截圖如下:
5. 將釘釘機器人代碼放到文件中,方便調用
例如:創(chuàng)建用于監(jiān)控當QQOrder_ERP集群的VIP漂移時,調用用來發(fā)送釘釘告警的可執(zhí)行文件ddalarm.sh。
其主要代碼如下:
#!/bin/bash webhook='https://oapi.dingtalk.com/robot/send?access_token=34XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX' cluster='QQOrder_ERP' host=`hostname -I | awk '{print $1}'` vip=$1 function SendMsgToDingding() { curl $webhook -H 'Content-Type: application/json' -d " { 'msgtype': 'text', 'text': { 'content': '集群名稱:$cluster\n告警信息:虛擬IP<$vip>已漂移至節(jié)點<$host>,請注意\n' }, 'at': { 'isAtAll': true } }" } SendMsgToDingding
此測試文件,調用執(zhí)行時需要傳入一個參數(shù)(VIP)。
觸發(fā)執(zhí)行,案例如下:
手機釘釘收到的告警信息
參考資料:
1.釘釘群機器人
https://ding-doc.dingtalk.com/doc#/serverapi2/krgddi
2.curl使用指南
https://www.jianshu.com/p/fc0eb6c60816
到此這篇關于shell 操作釘釘機器人實現(xiàn)告警提醒的方法的文章就介紹到這了,更多相關shell 釘釘告警提醒內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
linux shell實現(xiàn)隨機數(shù)幾種方法分享(date,random,uuid)
這篇文章主要介紹了linux shell實現(xiàn)隨機數(shù)多種方法(date,random,uuid),需要的朋友可以參考下2015-10-10linux shell字符串內置的常用操作(獲取長度、查找、替換)
在編寫shell程序時,經常會涉及到字符串相關操作。有許多命令語句,如awk,sed都能夠做字符串各種操作。 事實上shell內置一系列操作符號,能夠達到相似效果,使用內部操作符會省略啟動外部程序等時間,因此速度會很的快。如果內置的操作符能夠做到的,優(yōu)先使用內置的2015-12-12Shell腳本實現(xiàn)監(jiān)控iptables規(guī)則是否被修改
這篇文章主要介紹了Shell腳本實現(xiàn)監(jiān)控iptables規(guī)則是否被修改,本文直接給出實現(xiàn)代碼,需要的朋友可以參考下2014-12-12