- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章通过shell+python实现企业微信预警由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
一 注册企业微信 。
本文所有内容是基于2018年12月26日时的企业微信版本所做的教程。后面可能由于企业微信界面规则更改导致部分流程不一致。(大家看文章时请注意这一点) 。
注册企业微信必备条件 。
之前我有个误区,就是以为注册企业微信就一定要有营业执照之类的证件才可以注册,实际是不需要也可以的,因为我们直接注册后,即使不绑定企业,我们也是可以正常使用的,未绑定实际企业的,有200人的数的上限(难道你们技术部有200人?不存在的,哈哈!) 。
注册 。
注册链接:企业微信 。
企业名称可以随便填,建议填真实的啊,其他的你就按照实际情况填了.
二 创建消息 。
创建部门 。
首先我们需要创建一个部门,然后将成员添加到一个部门里面 。
邀请成员加入 。
我们可以在首页点击进行邀请.
也可以在选中要添加的部门后再选右边的添加成员或者微信邀请.
创建应用 。
创建的时候指定下可以接收的消息的部门 。
关注微工作平台 。
在我的企业 ---》 微工作平台 ---》邀请关注 。
三 实现预警 。
在完成的上面的所有准备工作后,我们还需要获取三个东西 :
1 企业id 。
2 获取应用id和secret 。
获取企业id 。
获取应用id和secret 。
通过shell 脚本实现监控预警 。
该shell 脚本实现的功能: 检测端口是否在监听状态,不在则进行微信预警.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
|
#!/bin/bash
###############
#$auth= djx
#$function= monitoring service
#date= 2018-12-26
###############
# 日志储存文件
log_file
=
'/var/log/ljf_status.log'
# 主机名
hostname
=
`hostname`
# 监听的端口数组
check_port
=
(
"3306"
"3329"
"4567"
)
# 数组长度
num
=
${
#check_port[*]}
# 报警消息
msg
=
""
echo
"--------------------------$(date +%f_%t)-----------------"
>>$log_file
for
i
in
`seq
0
$num`
do
netstat
-
tnlp|grep
"${check_port[${i}]}"
>>
/
dev
/
null
if
[ $?
-
ne
0
]
then
msg
=
"\\n${hostname}:the port ${check_port[${i}]} is down \\n"
${msg}
echo
"$(date +%f_%t) ${hostname}:the port ${check_port[${i}]} is down"
>>$log_file
fi
done
if
[
"${msg}"
!
=
"" ]
then
cropid
=
""
#填入企业id值
secret
=
""
#填入认证密码
gurl
=
"https://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid=$cropid&corpsecret=$secret"
# 获取token
gtoken
=
$(
/
usr
/
bin
/
curl
-
s
-
g $gurl | awk
-
f\"
'{print $10}'
)
purl
=
"https://qyapi.weixin.qq.com/cgi-bin/message/send?access_token=$gtoken"
body
=
'{
"touser"
:
"@all"
,
"msgtype"
:
"text"
,
"agentid"
:
"1000002"
,
#要更改为我们的应用id
"text"
:{
"content"
:"
故障:
'$msg'
"
},
"safe"
:
0
}'
/
usr
/
bin
/
curl
-
-
data
-
ascii
"$body"
$purl >>$log_file
2
>&
1
fi
|
通过python 脚本实现监控预警 。
由于centos7和centos6 默认安装的都是python2版本,所以下面的脚本是基于python2写的,这样我们就可以直接拿到我们的服务器上使用了.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
|
# -*- coding: utf-8 -*-
# @time : 2018/12/27 0021 11:58
# @author : djx
# @email : 1120236774@qq.com
# @file : 微信预警脚本.py
# @software: pycharm
import
os
import
time
import
urllib2
import
json
# 企业号id
wxid
=
""
# 应用id
depid
=
""
# 认证密码
secret
=
""
# 获取主机的名称
hostname
=
os.popen(
"hostname"
).read()
# 日志储存文件
log_file
=
'/var/log/ljf_status.log'
# 监听的端口列表
check_port
=
(
"8500"
,
"3306"
)
# 发送的消息
msg
=
""
# 获取当前的时间
date_time
=
time.strftime(
"%y-%m-%d %x"
)
# 检查端口是否在监听
for
i
in
check_port:
shell
=
"netstat -nutlp |grep \""
+
i
+
"\""
recv
=
os.popen(shell).read()
if
recv
=
=
"":
msg
=
msg
+
hostname
+
": the port "
+
i
+
"is down \n"
# 预警判断
if
msg !
=
"":
url
=
"https://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid="
+
\
wxid
+
"&corpsecret="
+
secret
request
=
urllib2.request(url)
response
=
urllib2.urlopen(request)
recv_info
=
response.read()
recv_info
=
eval
(recv_info)
wx_token
=
recv_info[
'access_token'
]
msg_url
=
"https://qyapi.weixin.qq.com/cgi-bin/message/send?access_token="
+
wx_token
send_msg
=
{
"touser"
:
"@all"
,
"msgtype"
:
"text"
,
"agentid"
: depid,
"text"
: {
"content"
: msg},
"safe"
:
0
}
send_msg_json
=
json.dumps(send_msg)
request_post
=
urllib2.urlopen(msg_url,send_msg_json)
recv_msg
=
request_post.read()
with
open
(log_file,mode
=
'a'
) as f:
f.write(date_time)
f.write(
"\n"
)
f.write(msg)
f.write(recv_msg)
f.write(
"\n"
)
|
上面的脚本也可以应用在zabbix或者是open-falcon.
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我.
原文链接:https://www.cnblogs.com/operationhome/p/10184367.html 。
最后此篇关于通过shell+python实现企业微信预警的文章就讲到这里了,如果你想了解更多关于通过shell+python实现企业微信预警的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我相信我在子 shell 中调用 exit 会导致我的程序继续: #!/bin/bash grep str file | while read line do exit 0 done
我相信我在子 shell 中调用 exit 会导致我的程序继续: #!/bin/bash grep str file | while read line do exit 0 done
我有几个脚本,它们的第一部分看起来是一样的。这部分的功能是识别脚本在哪台机器上运行并相应地设置几个变量。它看起来像这样: ENV=`echo $LOGNAME | cut -c1-8` if
这是我正在尝试做的事情。我有 4 个 shell 脚本。脚本 1 需要先运行,然后是 2,然后是 3,然后是 4,并且它们必须按此顺序运行。脚本 1 需要运行(并在后台等待)2 才能正常运行,但是脚本
我有一个名为 a.sh 的脚本,其中的内容是: //a.sh: #!/bin/bash temp=0 while [ "$temp" -ne 500 ] do echo `date`
在snakemake中,使用shell()函数执行多个命令的推荐方式是什么? 最佳答案 您可以调用shell()多次内run规则块(规则可以指定 run: 而不是 shell: ): rule pro
我有一个 shell 脚本,我向其中传递了一些参数。Test1.sh -a 1 -b 2 -c“一二三” 在 Test1.sh 中,我按以下方式调用另一个 shell 脚本。Test2.sh $* 我
我有 2 个 shell 脚本。 第二个shell脚本包含以下函数第二个.sh func1 func2 first.sh 将使用一些参数调用第二个 shell 脚本, 将使用特定于该函数的一些其他参数
我有一个 Unix shell 脚本 test.sh。在脚本中,我想调用另一个 shell,然后从子 shell 执行 shell 脚本中的其余命令并退出 说清楚: test.sh #! /bin/b
我想在 shell 脚本中更改路径环境变量。路径变量需要在shell脚本执行后修改。 最佳答案 我知道有两种方法可以做到这一点。第一种是在当前 shell 的上下文中运行脚本: . myscript.
此 shell 脚本按预期运行。 trap 'echo exit' EXIT foo() { exit } echo begin foo echo end 这是输出。 $ sh foo.sh
我正在使用 vimshell在 vim 中执行命令 nnoremap vs :VimShellPop 使用此键映射,我可以打开 vim shell 并执行诸如“捆绑安装”之类的命令,然后 输入 exi
我想连接到不同的 shell(csh、ksh 等)并在每个切换的 shell 中执行命令。 下面是反射(reflect)我的意图的示例程序: #!/bin/bash echo $SHELL csh e
我目前正在尝试使用 BNF 和 LL 解析器在 C 中重新编写 shell。 否则,我需要知道 shell 运算符的优先级是什么| , > , > , & , ; ? 有没有人可以提供给我? 谢谢 最
不幸的是,我没有suspend 命令(busybox/ash)。但是我可以使用 kill -STOP $$ 从后台 shell (sh &) 返回到父 shell(以及 fg 之后)。 但是我不想输入
我需要知道,当用户切换到另一个 shell 时,通过单击它。 我试过 shellListener.shellDeactivated()但是当 shell 失去对它自己的控件的焦点时,会触发此事件,这意
file1.txt aaaa bbbb cccc dddd eeee file2.txt DDDD cccc aaaa 结果 bbbb eeee 如果能不区分大小写就更好了! 谢谢! 最佳答案 gre
我见过解压缩目录中所有 zip 文件的循环。但是,在运行此之前,我宁愿确保我将要运行的内容正常工作: for i in dir; do cd $i; unzip '*.zip'; rm -rf *.z
我对编程还很陌生,但我想知道 vim、emacs、nano 等 shell 文本编辑器如何能够控制命令行窗口。我主要是一名 Windows 程序员,所以可能在 *nix 上有所不同。据我所知,只能将文
我有一个包含第 7 列日期的文件,我的要求是将它与今天的日期进行比较,如果小于它,则删除该完整行。 此外,如果第 7 列中提到的任何日期超过 15 天,则将其修改为最多 15 天 下面的例子- now
我是一名优秀的程序员,十分优秀!