Jenkins与钉钉机器人实现手机端获取当前服务日志

马上要过年了,各位运维们除了因为买不到回家的火车票而嚎嚎大哭之外也开始扩容服务器和提前调整监控值,目的就是为了过一个消停的春节。可是这毕竟十天左右不在公司,要是模块真出了什么意外肯定没法第一找到日志分析问题,毕竟这几天都在串门拜年和醉生梦死中度过,走到哪都要再背一个笔记本实在太不方便了。

那么这个时候,我就琢磨使用手机端来启动服务器里脚本,让这个脚本可以去获取当前的日志,然后再把结果返回到手机端。这样就不用到哪里都带那个一看就很扫兴的公司笔记本电脑了。

使用手机端启动服务器里脚本?我又不会开发android和ios,那么肯定就要使用第三方工具,我条件反射的想到了jenkins,因为jenkins是用手机可以登录的,那么在手机端得到结果用什么呢?在微信公众号和钉钉机器人里,我选择了钉钉机器人。

创造钉钉机器人

我的钉钉版本是4.2.6.37,首先在左上角头像的三角菜单有一个机器人管理,如图:

然后选择自定义机器人,给它起个名又换一个图标之后,添加到一个群聊里,如图:

添加的时候,这个机器人会生成一个webhook,它的结构应该是:https://oapi.dingtalk.com/robot/send?access_token=XXX,后面的XXX是标识符,不同的标识符代表不同的机器人,这个标识符如果丢了,可以在机器人头像点击一下然后选择机器人设置重新看到。

编写机器人脚本

机器人的官方说明网址就是https://open-doc.dingtalk.com/docs/doc.htm?spm=a219a.7629140.0.0.zZIvnt&treeId=257&articleId=105735&docType=1,这里面已经把使用方法写的够清楚了。我这里的这个python脚本是用json的格式,如下:

    #!/bin/python
    #coding: utf-8
    import json,urllib2

    #这里是机器人对应的Webhook地址
    url = "https://oapi.dingtalk.com/robot/send?access_token=这里输入你机器人的标识符

    #这里是头,原样复制就好
    header = {
        "Content-Type": "application/json",
        "charset": "utf-8"
        }

    #这里是传送的消息
    data = {
         "msgtype": "text",
            "text": {
                "content": "这里是消息正文!"
            },
         "at": {
             "atMobiles": [
            "A的手机号",
            "B的手机号"
            ],
             "isAtAll":False   #这里True代表要发给所有人,False的话,要代表消息只发给A和B这两个人
          }
     }

    sendData = json.dumps(data)
    request = urllib2.Request(url,data = sendData,headers = header)
    urlopen = urllib2.urlopen(request)
    print urlopen.read()

直接执行这个脚本,就会看到我刚新建的钉钉机器人在群聊里说话了。

机器人搭配nginx

上面那个脚本已经可以初步实现我们的目的,但是有一个缺点,就是正文内容不能过长。但是我想多打印一点日志,至少50行,怎么办?我想了想,可以把日志放进nginx的一个网页里,然后用钉钉机器人反馈这个网页地址啊,这样内容想写多少就可以写多少了。

假设我现在获取到的日志的文件写进一个叫chairmanmao.html里,在浏览器打开看是这样的:

那么上面那个机器人的python脚本就要改成这样:

    #!/bin/python
    #coding: utf-8
    import json,urllib2,commands

    commands.getstatusoutput(‘echo -e "THIS IS TEST MESSAGE! \n" > /路径/chairmantail.html‘)  #这里可以给网页加一个标题
    commands.getstatusoutput(‘cat /路径/chairmanmao.txt >>  /路径/chairmanmao.html‘)        #这里就是把诗词写进html文件里

    #这里是机器人的webhook地址
    url = "https://oapi.dingtalk.com/robot/send?access_token=这里输入你机器人的标识符"

    header = {
        "Content-Type": "application/json",
        "charset": "utf-8"
        }

    data = {
         "msgtype": "link",
            "link": {
                    "text": "点击网址就可获取到本次日志查询的结果",
                    "title": "日志查询结果已经生成!",
                    "picUrl": "http://p1x3hd2at.bkt.clouddn.com/nanshen.jpg",   #这里可以加一个缩略图片
                    "messageUrl": "http://服务器外网IP地址/chairmanmao.html"
        },
         "at": {
                "isAtAll":True   # at为非必须
             }
        }

    sendData = json.dumps(data)
    request = urllib2.Request(url,data = sendData,headers = header)
    urlopen = urllib2.urlopen(request)
    print urlopen.read()

执行这个脚本可以看到机器人发送的信息如下:

然后打开这个网址,就看到完整的网页信息:

到时候把毛主席诗词换成实际的日志文件就好了,不用一口气打印所有的日志出来,tail -n 50 日志文件名,50行足够用了。

配置Jenkins

脚本写完了,机器人也写完了,这个时候就要添加“启动端”。安装Jenkins的步骤我这里就不写了,直接可以去看https://rorschachchan.github.io/2018/02/05/Jenkins安装与创建简单任务/。现在去登录Jenkins的网页,去添加一个新的Job,比如我这个Job就叫“获取模块日志”,如图:

如果是要在Jenkins上去读取其他服务器的日志,就可以在构建project的时候选择参数化构建过程,然后配置参数ip,到时候把这些ip传递给目标脚本。如果觉得这样hold不住,可以不用jenkins的这个功能,把ip写到脚本里去,一了百了:

构建那一步,选择Execute Shell,然后里面写上具体的shell命令,如果在上面使用了参数,那么参数就可以在这里使用,我的脚本里是没有ip这个参数的,在图里写$ip就是做一个例子讲解一下用法而已:

构建后操作这一步可以选择E-mail Notification,这样如果失败了会发送邮件通知。如果用不着就什么都不用选。然后就是保存好这个project,点击左侧菜单栏的立即构建,就会看到下面Build History会多一个#1出来,同时钉钉机器人也在群里发消息,这个#1就是构建的记录,这个纪录多了的话,新纪录会覆盖掉老的记录。

点击这个#1,选择控制台输出,就能看到具体的操作结果了,跟在shell界面里执行的效果差不多的。可见操作成功,目的已经达到了!

以后需要调用脚本,就在手机端浏览器里登陆jenkins,然后构建一下这个project,同时就可以看到钉钉里机器人有反馈了。

参考资料

https://xu3352.github.io/linux/2017/05/01/jenkins-restart-remote-server-tomcat

原文地址:http://blog.51cto.com/chenx1242/2069631

时间: 2024-10-14 19:28:50

Jenkins与钉钉机器人实现手机端获取当前服务日志的相关文章

jenkins 集成钉钉机器人

最早做Jenkins发布完成以后通过邮件发送信息通知相关的联系人,发现邮件会受限于大家接收的设置,导致不能及时的看到相关的发布内容,公司使用钉钉做为公司内部的通讯工具,所以想通过Jenkins发布完成以后通过钉钉来通知大家,研究发现钉钉提供机器人,所以我把机器人集成进来通知相关人员. 1.创建通知人群组,添加机器人(钉钉默认自带了配置好的机器人,但是没有Jenkins机器人): 注意:钉钉机器人的配置需要在PC端完成: 2.获取自定义机器人webhook 3.jenkins 安装"Dingdin

jenkins 集成钉钉机器人通知

公司使用钉钉做为公司内部的通讯工具,所以想通过Jenkins发布完成以后通过钉钉来通知大家,研究发现钉钉提供机器人,所以我把机器人集成进来通知相关人员. 1.创建通知人群组,添加机器人(钉钉默认自带了配置好的机器人,但是没有Jenkins机器人): 注意:钉钉机器人的配置需要在PC端完成: 2.获取自定义机器人webhook 3.jenkins 安装"Dingding[钉钉] Plugin"插件: 4.插件安装完成后,创建/修改任务中,在"构建后的操作"->&

自动化执行 - 钉钉机器人通知

背景 公司内部用钉钉来办公,钉钉支持机器人提醒,有各种各样的机器人提供选择,可以根据需求来定制机器人,达到提醒功能,如提醒某人请下午茶,233 思路 1. 添加机器人到群组中,这次将的是“自定义”机器人: 2. 添加后会发现有一个webhook的链接,可以点击“设置说明”查看详情 3. 可以通过post请求网这个webhook发送信息,机器人就可以在群里展示信息,文档里有定义不同的请求body: 文档地址:https://open-doc.dingtalk.com/docs/doc.htm?sp

jenkins集成钉钉

1.创建通知人群组,添加机器人 2.2.获取自定义机器人webhook 3.jenkins 安装"Dingding[钉钉] Plugin"插件: 4.插件安装完成后,创建/修改任务中,在"构建后的操作"->"增加构建后操作步骤"中,选择"钉钉通知器配置" 5.每次构建后会发送消息 原文地址:https://www.cnblogs.com/dieyaxianju/p/8185716.html

【转】[钉钉通知系列]Jenkins发布后自动通知

转载请注明出处:https://www.cnblogs.com/jianxuanbing/p/7211006.html 阅读目录 一.前言 二.使用钉钉推送的优势 三.配置 一.前言 最近使用Jenkins进行自动化部署,但是发布署后,并没有相应的通知,虽然有邮件发送通知,但是发现邮件会受限于大家接受的设置,导致不能及时看到相关的发布内容.由于之前有用Gitlab推送消息到钉钉的方式,因此考虑Jenkins是否能通知到钉钉的实现方式. 二.使用钉钉推送的优势 实时提醒项目参与人员信息的更新 便于

持续集成之 Jenkins 钉钉通知(八)

一.前言 最近使用 Jenkins 进行自动化部署,但是发布署后,并没有相应的通知,虽然有邮件发送通知,但是发现邮件会受限于大家接受的设置,导致不能及时看到相关的发布内容.由于之前有用 Gitlab 推送消息到钉钉的方式,因此考虑 Jenkins是否能通知到钉钉的实现方式. 二.使用钉钉推送的优势 实时提醒项目参与人员信息的更新. 便于查看. 三.钉钉的配置 1. 成为钉钉群主 进入某个群->点击机器人图标. 注意:如果你不是群主,且群主开启了仅群主可管理,那么你将无法创建机器人. 2.选择自定

Jenkins发布后自动通知【钉钉】

阅读目录 一.前言 二.使用钉钉推送的优势 三.配置 一.前言 最近使用Jenkins进行自动化部署,但是发布署后,并没有相应的通知,虽然有邮件发送通知,但是发现邮件会受限于大家接受的设置,导致不能及时看到相关的发布内容.由于之前有用Gitlab推送消息到钉钉的方式,因此考虑Jenkins是否能通知到钉钉的实现方式. 二.使用钉钉推送的优势 实时提醒项目参与人员信息的更新 便于查看 三.配置 3.1 钉钉的配置 3.1.1 进入钉钉群 进入某个群->点击机器人图标注意:如果你不是群主,且群主开启

使用钉钉通知Jenkins构建结果

Jenkins安装钉钉通知插件 插件下载地址:https://mirrors.tuna.tsinghua.edu.cn/jenkins/plugins/dingding-notifications/ 注:这里使用的是最新的插件 在job中配置钉钉通知 注:这里需要在钉钉上面创建一个团队 钉钉添加机器人: 保存token: 注:token后期Jenkins上需要使用 配置添加机器人测试: 测试结果: 构建过程: 原文地址:https://www.cnblogs.com/Mercury-linux/

zabbix 使用机器人报警到钉钉群聊

钉钉机器人接口脚本下载:https://www.appgao.com/files/192.html 钉钉机器人接口地址(可以点击机器人查看):webhook地址,https://oapi.dingtalk.com/robot/send?access_token=xxxxxxxx 配置报警媒介类型 配置用户报警媒介 配置用户 赋予golang-zabbix-robot-64脚本所属主组和可执行权限 配置动作 默认信息: <?xml version="1.0" encoding=&q