源
【1-1】如果有镜像源可以忽略此步骤
mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.backup
wget -O /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-7.repo
wget -O /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-7.repo
1.下载源的rpm包
一.zabbix安装
【1-1】 安 装 源
rpm -ivh https://repo.zabbix.com/zabbix/4.4/rhel/7/x86_64/zabbix-release-4.4-1.el7.noarch.rpm
#rpm -uvh 包升级
【1-2】清理缓存
yum clean all
【1-3】服务安装
yum install -y zabbix-server-mysql zabbix-agent zabbix-web-mysql zabbix-nginx-conf
【1-4】修改配置
1.#备份并修改【/etc/nginx/nginx.conf】
cp /etc/nginx/nginx.conf /etc/nginx/nginx.conf.bak
vim /etc/nginx/nginx.conf
user nginx;
worker_processes auto;
error_log /var/log/nginx/error.log;
pid /run/nginx.pid;
include /usr/share/nginx/modules/*.conf;
events {
worker_connections 1024;
}
http {
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
access_log /var/log/nginx/access.log main;
sendfile on;
tcp_nopush on;
tcp_nodelay on;
keepalive_timeout 65;
types_hash_max_size 2048;
include /etc/nginx/mime.types;
default_type application/octet-stream;
include /etc/nginx/conf.d/*.conf;
}
2.#修改【/etc/nginx/conf.d/zabbix.conf】
vim /etc/nginx/conf.d/zabbix.conf
server {
listen 80; #修改端口
server_name dev-picture-xssh.bilibiligame.jp; #公司域名
root /usr/share/zabbix;
allow 114.86.224.135; # 放行公司IP
deny all;
index index.php;
location = /favicon.ico {
log_not_found off;
}
location / {
try_files $uri $uri/ =404;
}
location /assets {
access_log off;
expires 10d;
}
location ~ /.ht {
deny all;
}
location ~ /(api/|conf[^.]|include|locale) {
deny all;
return 404;
}
location ~ [^/].php(/|$) {
fastcgi_pass unix:/run/php-fpm/zabbix.sock;
fastcgi_split_path_info ^(.+.php)(/.+)$;
fastcgi_index index.php;
fastcgi_param DOCUMENT_ROOT /usr/share/zabbix;
fastcgi_param SCRIPT_FILENAME /usr/share/zabbix$fastcgi_script_name;
fastcgi_param PATH_TRANSLATED /usr/share/zabbix$fastcgi_script_name;
include fastcgi_params;
fastcgi_param QUERY_STRING $query_string;
fastcgi_param REQUEST_METHOD $request_method;
fastcgi_param CONTENT_TYPE $content_type;
fastcgi_param CONTENT_LENGTH $content_length;
fastcgi_intercept_errors on;
fastcgi_ignore_client_abort off;
fastcgi_connect_timeout 60;
fastcgi_send_timeout 180;
fastcgi_read_timeout 180;
fastcgi_buffer_size 128k;
fastcgi_buffers 4 256k;
fastcgi_busy_buffers_size 256k;
fastcgi_temp_file_write_size 256k;
}
}
3.#修改区时
vim /etc/php-fpm.d/zabbix.conf
php_value[date.timezone] = Asia/Tokyo
4.#启动并开机自启
systemctl start nginx.service && systemctl enable nginx.service
systemctl start php-fpm.service && systemctl enable php-fpm.service
二.安装数据库
【2-1】下载工具
yum install -y ncurses-devel libaio-devel cmake gcc gcc-c++ glibc rpm-build autoconf numactl
【2-2】上 传 包
下载地址 wget https://downloads.mysql.com/archives/get/p/23/file/mysql-5.7.28-linux-glibc2.12-x86_64.tar.gz
【2-3 】 配 置
(一)【创建目录,用户,解压,改名,软连接】
mkdir /data
useradd mysql -s /sbin/nologin -M
tar xf mysql-5.7.28-linux-glibc2.12-x86_64.tar.gz
ln -s /data/mysql.5.7.28/ /data/mysql
【在support-flie目录下创建default.cnf文件】
cat <<EOF> /data/mysql/support-files/my_default.cnf
[mysqld]
server_id=2
log-bin = /data/mysql/logs/mysql-bin.log
#设置mysql的安装目录
basedir =/data/mysql/
#设置mysql数据库的数据存放目录
datadir = /data/mysql/data
#设置端口
port = 3306
socket = /var/lib/mysql/mysql.sock
#设置字符集
character-set-server=utf8
#日志存放目录
log-error = /data/mysql/logs/mysqld.log
pid-file = /data/mysql/data/mysqld.pid
EOF
(三)【复制启动配置文件】
cp /data/mysql/support-files/my_default.cnf /etc/my.cnf
创建目录
mkdir -p /data/mysql/logs/
(四)【授权目录,初始化】
chown mysql.mysql /data/mysql/ -R
/data/mysql/bin/mysqld --initialize --user=mysql --basedir=/data/mysql/ --datadir=/data/mysql/data/
(五)【复制初始化脚本并替换启动脚本中的路径】
cp /data/mysql/support-files/mysql.server /etc/init.d/mysqld
sed -i "s#usr/local#data#g" /etc/init.d/mysqld /data/mysql/bin/mysqld_safe
(六)【设置成systemctl启动】
cat <<EOF> /usr/lib/systemd/system/mysqld.service
[Unit]
Description=MySQL Server
Documentation=man:mysqld(8)
Documentation=https://dev.mysql.com/doc/refman/en/using-systemd.html
After=network.target
After=syslog.target
[Install]
WantedBy=multi-user.target
[Service]
User=mysql
Group=mysql
ExecStart=/data/mysql/bin/mysqld --defaults-file=/etc/my.cnf
LimitNOFILE = 5000
EOF
(七)【配置环境变量 ,加载环境变量 ,给启动脚本授权700】
echo 'PATH=/data/mysql/bin/:$PATH' >/etc/profile.d/mysql.sh
source /etc/profile.d/mysql.sh
chmod 700 /etc/init.d/mysqld
(八)【启动数据库,做链接,】
systemctl start mysqld && systemctl enable mysqld.service
ln -s /var/lib/mysql/mysql.sock /tmp/mysql.sock
(九)【查找mysql密码,登陆数据库】
[root@suzhu ~]# grep "local" /data/mysql/logs/mysqld.log
mysql -uroot -p
set password=password('qazwsx123456');
flush privileges;
create database zabbix character set utf8 collate utf8_bin;
grant all privileges on zabbix.* to zabbix@"192.168.24.%" identified by 'zabbix';
(十)导入zabbix数据
zcat /usr/share/doc/zabbix-server-mysql-4.2.8/create.sql.gz |mysql -uroot -p zabbix
三.zabbix配置
【3-1】server端
vim /etc/zabbix/zabbix_server.conf
#在如下行进行修改
91 DBHost=localhost
100 DBName=zabbix
116 DBUser=zabbix
124 DBPassword=zabbix
【3-2】agent端
vim /etc/zabbix/zabbix_agentd.conf
Server=192.168.24.132
ServerActive=192.168.24.132
【3-3】启动
systemctl start zabbix-agent.service && systemctl enable zabbix-agent.service
systemctl start zabbix-server.service && systemctl enable zabbix-server.service
#浏览器输入192.168.24.132即可安装
【3-3】补 充
修改zabbix web界面字体
电脑 C:WindowsFonts拉出来一个字体msyh.ttc ,传上去,重命名为DejaVuSans.ttf
ll /etc/alternatives |grep zabbix-web-font
cd /usr/share/fonts/dejavu
mv DejaVuSans.ttf DejaVuSans.ttf.bak
mv msyh.ttc DejaVuSans.ttf
刷新zabbix web页面即可
四.服务指标监控
【4-1】监控1:java监控
1.【监控内容】 针对java的堆,老年代,新生代,gc回收
2.【命令提权】 java程序时,由于部分命令zabbix没有权限,我们需要给zabbix提权,在93行左右
3.【脚本样例】下面例子是监控GameServer的脚本
2.#命令提权
vim /etc/sudoers +101
zabbix ALL=(ALL) NOPASSWD:/usr/lib/jvm/java-1.8.0-openjdk-1.8.0.242.b08-0.el7_7.x86_64/bin/jstat
3.#创建脚本目录放置脚本
mkdir -p /etc/zabbix/scripts
4.#创建监控脚本
vim /etc/zabbix/scripts/GameServer.sh
#获取服务进程(pid)
pid=`ps -ef | grep "GameServer" |grep -v $$| grep -v "cgroup" | grep -v "grep" | awk '{print $2}'`
sudo=/usr/bin/sudo
###################################################################################
#s0c 年轻代中第一块survivor容量
#s1c 年轻代中第二个survivor(幸存区)的容量
#s0u 年轻代中第一个survivor(幸存区)目前已使用空间 (字节)
#s1u 年轻代中第二个survivor(幸存区)目前已使用空间 (字节)
#s1u_per 幸存区使用的容量百分比
###################################################################################
#ec EdenCount 年轻代中Eden(伊甸园)的容量 (字节)
#eu EdenUsed年轻代中Eden(伊甸园)目前已使用空间 (字节)
#ecu_per EdenUsed %
###################################################################################
#oc OldCount Old代的容量 (字节)
#ocu Oldcount Used代的容量 (字节)
#ocuper Old used%
###################################################################################
#ygc 年轻代gc回收次
#ygct 年轻代gc回收时间
#ogc 老年代gc回收次数
#ogct 老年代gc回收时间
#all_gct 老年代&&和年轻代总的回收时间
###################################################################################
#heap Game堆的大小
#heapused Game堆的使用情况
#heap_per GAME堆的使用百分比
###################################################################################
#MB=kb/1024
#GC
s0c=`$sudo jstat -gc $pid|awk 'NR==2{print $1/1024}'`
s1c=`$sudo jstat -gc $pid|awk 'NR==2{print $2/1024}'`
s0u=`$sudo jstat -gc $pid|awk 'NR==2{print $3/1024}'`
s1u=`$sudo jstat -gc $pid|awk 'NR==2{print $4/1024}'`
s1u_per=`$sudo jstat -gc $pid|awk 'NR==2{print $4/$2*100}'`
ec=`$sudo jstat -gc $pid|awk 'NR==2{print $5/1024}'`
ecu=`$sudo jstat -gc $pid|awk 'NR==2{print $6/1024}'`
ecu_per=`$sudo jstat -gc $pid|awk 'NR==2{print $6/$5*100}'`
oc=`/usr/bin/sudo jstat -gc $pid|awk 'NR==2{print $7/1024}'`
ocu=`$sudo jstat -gc $pid|awk 'NR==2{print $8/1024}'`
ocu_per=`$sudo jstat -gc $pid|awk 'NR==2{print $8/$7*100}'`
ygc=`$sudo jstat -gcnew $pid|awk 'NR==2{print $(NF-1)}'`
ygct=`$sudo jstat -gcnew $pid|awk 'NR==2{print $NF}'`
ogc=`$sudo jstat -gcoldcapacity $pid|awk 'NR==2{print $(NF-2)}'`
ogct=`$sudo jstat -gcoldcapacity $pid|awk 'NR==2{print $(NF-1)}'`
all_gct=`$sudo jstat -gcoldcapacity $pid|awk 'NR==2{print $NF}'`
heap=`$sudo jstat -gc $pid|awk 'NR==2{print ($2+$5+$7)/1024}'`
heapused=`$sudo jstat -gc $pid|awk 'NR==2{print ($4+$6+$8)/1024}'`
heap_per=`$sudo jstat -gc $pid|awk 'NR==2{print ($4+$6+$8)/($2+$5+$7)*100}'`
case $1 in
s0c)
echo $s0c
;;
s1c)
echo $s1c
;;
s0u)
echo $s1u
;;
s1u)
echo $s1u
;;
s1u_per)
echo $s1u_per
;;
ec)
echo $ec
;;
ecu)
echo $ecu
;;
ecu_per)
echo $ecu_per
;;
oc)
echo $oc
;;
ocu)
echo $ocu
;;
ocu_per)
echo $ocu_per
;;
ygc)
echo $ygc
;;
ygct)
echo $ygct
;;
ogc)
echo $ogc
;;
ogct)
echo $ogct
;;
all_gct)
echo $all_gct
;;
heap)
echo $heap
;;
heapused)
echo $heapused
;;
heap_per)
echo $heap_per
;;
*)
echo "USAGE:{heap|heap_per|...}"
;;
esac
######
5.【客户端配置】获取参数,添加如下
vim /etc/zabbix/zabbix_agentd.d/system.conf
#GameServer的性能指标
UserParameter=Game[*],/usr/bin/sh /etc/zabbix/scripts/GameServer.sh $1
6.重启
systemctl restart zabbix-agent.service
【4-2】监控2: cpu 内存
1【监控内容】针对各种服务的cpu占用,内存占用 脚本如下
vim /etc/zabbix/scripts/processstatus.sh
# auth-tomcat forest-friend forest-gateway forest-server gm-tomcat idip-tomcat pay-tomcat
auth-memory(){
ps aux|grep "auth-tomcat"|grep -v "grep"|grep -v "processstatus.sh"|awk '{sum+=$6}; END{print sum*1024}'
}
auth-cpu(){
ps aux|grep "auth-tomcat"|grep -v "grep"|grep -v "processstatus.sh"|awk '{sum+=$3}; END{print sum}'
}
friend-memory(){
ps aux|grep "FriendServer"|grep -v "grep"|grep -v "processstatus.sh"|awk '{sum+=$6}; END{print sum*1024}'
}
forest-cpu(){
ps aux|grep "FriendServer"|grep -v "grep"|grep -v "processstatus.sh"|awk '{sum+=$3}; END{print sum}'
}
gateway-memory(){
ps aux|grep "forest-gateway"|grep -v "grep"|grep -v "processstatus.sh"|awk '{sum+=$6}; END{print sum*1024}'
}
gateway-cpu(){
ps aux|grep "forest-gateway"|grep -v "grep"|grep -v "processstatus.sh"|awk '{sum+=$3}; END{print sum}'
}
game-memory(){
ps aux|grep "GameServer"|grep -v "grep"|grep -v "processstatus.sh"|awk '{sum+=$6}; END{print sum*1024}'
}
game-cpu(){
ps aux|grep "GameServer"|grep -v "grep"|grep -v "processstatus.sh"|awk '{sum+=$3}; END{print sum}'
}
gm-memory(){
ps aux|grep "gm-tomcat"|grep -v "grep"|grep -v "processstatus.sh"|awk '{sum+=$6}; END{print sum*1024}'
}
gm-cpu(){
ps aux|grep "gm-tomcat"|grep -v "grep"|grep -v "processstatus.sh"|awk '{sum+=$3}; END{print sum}'
}
idip-memory(){
ps aux|grep "idip-tomcat"|grep -v "grep"|grep -v "processstatus.sh"|awk '{sum+=$6}; END{print sum*1024}'
}
idip-cpu(){
ps aux|grep "idip-tomcat"|grep -v "grep"|grep -v "processstatus.sh"|awk '{sum+=$3}; END{print sum}'
}
pay-memory(){
ps aux|grep "pay-tomcat"|grep -v "grep"|grep -v "processstatus.sh"|awk '{sum+=$6}; END{print sum*1024}'
}
pay-cpu(){
ps aux|grep "pay-tomcat"|grep -v "grep"|grep -v "processstatus.sh"|awk '{sum+=$3}; END{print sum}'
}
case "$1" in
'auth-memory')
auth-memory
;;
'auth-cpu')
auth-cpu
;;
'friend-memory')
friend-memory
;;
'friend-cpu')
friend-cpu
;;
'gateway-memory')
gateway-memory
;;
'gateway-cpu')
gateway-cpu
;;
'game-memory')
game-memory
;;
'game-cpu')
game-cpu
;;
'gm-memory')
gm-memory
;;
'gm-cpu')
gm-cpu
;;
'idip-memory')
idip-memory
;;
'idip-cpu')
idip-cpu
;;
'pay-memory')
pay-memory
;;
'pay-cpu')
pay-cpu
;;
*)
echo "Usage: $0 {auth-memory|....}"
;;
esac
1.【客户端配置】获取参数
echo "UserParameter=process[*],/etc/zabbix/scripts/processstatus.sh $1" >>/etc/zabbix/zabbix_agentd.d/system.conf
2.重启
systemctl restart zabbix-agent.service
【4-3】监控3: 端 口
1.【监控内容】各个服务的存活状态,0表示非存活,1表示存活,脚本如下
vim /etc/zabbix/scripts/check_process_id.sh
# auth-tomcat forest-friend forest-gateway forest-server gm-tomcat idip-tomcat pay-tomcat
auth(){
ps aux|grep "auth-tomcat"|grep -v "grep"|grep -v "check_process_id.sh"| wc -l
}
friend(){
ps aux|grep "FriendServer"|grep -v "grep"|grep -v "check_process_id.sh" | wc -l
}
gateway(){
ps aux|grep "forest-gateway"|grep -v "grep"|grep -v "check_process_id.sh" | wc -l
}
game(){
ps aux|grep "GameServer"|grep -v "grep"|grep -v "check_process_id.sh" | wc -l
}
gm(){
ps aux|grep "gm-tomcat"|grep -v "grep"|grep -v "check_process_id.sh" | wc -l
}
idip(){
ps aux|grep "idip-tomcat"|grep -v "grep"|grep -v "check_process_id.sh" | wc -l
}
pay(){
ps aux|grep "pay-tomcat"|grep -v "grep"|grep -v "check_process_id.sh"|wc -l
}
case "$1" in
'auth')
auth
;;
'friend')
friend
;;
'gateway')
gateway
;;
'game')
game
;;
'gm')
gm
;;
'idip')
idip
;;
'pay')
pay
;;
*)
echo "Usage: $0 {auth|friend|...}"
;;
esac
1.【客户端配置】获取参数
echo "UserParameter=check[*],/usr/bin/sh /etc/zabbix/scripts/check_process_id $1" >>/etc/zabbix/zabbix_agentd.d/system.conf
重启客户端
systemctl restart zabbix-agent.service
五.系统指标监控
【5-1】系统指标
1.【监控内容】此监控脚本包含系统内存,CPU,磁盘的Io读写,目录的使用大小
vim /etc/zabbix/scripts/system_status1.sh
#内存空余(%)
mem_ava=`free -m|awk '/^Mem/{print $NF*100/$2}'`
#交换分区空余(%)
swap_ava=`free -m|awk '/^Swap/{print $NF*100/$2}'`
#服务器的开机时间(days)
system_runtime=`w|awk 'NR==1{print $3}'`
#/data目录的使用大小(Gb)
data_size=`/usr/bin/sudo du -sh /data/|awk -F G 'NR==1{print $1*1000*1000*1000}'`
#buffer缓存(Mb)
buffer_size=`free -m|awk 'NR==2{print $(NF-1)}'`
#swap的容量(Mb)
swap_size=`free -m|awk 'NR==3{print $2}'`
#CPU监控(%)
#1.cpu平均1min的利用百分比
cpu_load_1min=`w |awk -F \, 'NR==1{print $(NF-2)}'|awk '{print $3}'`
#2.cpu平均5min的利用百分比
cpu_load_5min=`uptime |awk -F \, '{print $(NF-1)}'`
#3.cpu平均15min的利用百分比
cpu_load_15min=`w|awk '/load average/{print $(NF)}'`
case $1 in
mem_ava)
echo $mem_ava
;;
swap_ava)
echo $swap_ava
;;
system_runtime)
echo $system_runtime
;;
data_size)
echo $data_size
;;
buffer_size)
echo $buffer_size
;;
swap_size)
echo $swap_size
;;
cpu_load_1min)
echo $cpu_load_1min
;;
cpu_load_5min)
echo $cpu_load_5min
;;
cpu_load_15min)
echo $cpu_load_15min
;;
*)
echo "USAGE:{mem_ava|swap_ava|....}"
;;
esac
1.【客户端配置】获取参数
vim /etc/zabbix/zabbix_agentd.d/system.conf
2.#添加如下
echo "UserParameter=system[*],/usr/bin/sh /etc/zabbix/scripts/system_status1.sh $1" >>/etc/zabbix/zabbix_agentd.d/system.conf
3.【重启客户端】
systemctl restart zabbix-agent.service
【5-2】磁盘监控
1【监控内容】磁盘的各项指标监控
2【监控脚本】仅供参考
vim /etc/zabbix/scripts/zbx_parse_iostat_values.sh
dev=$1
type=$2
#enable debug mode
debug=0
if [[ -z "$dev" ]]; then
echo "error: wrong input value (device)"
exit 1
fi
if [[ -z "$type" ]]; then
echo "error: wrong input value (type)"
exit 1
fi
columns=`iostat -xN |egrep -o "^Device.*"`
columnsarray=($columns)
column_id=1
for i in "${columnsarray[@]}"
do
#echo "column: $i"
if [[ "$i" = "$type" ]]; then
if [[ $debug -eq 1 ]]; then
echo "right column (${i}) found...column_id: $column_id "
fi
id="$"
column_id_id=$id$column_id
iostats=`iostat -dxk 1 2|tail -5|egrep -o "^${dev}[[:space:]]+.*" |awk "{print ${column_id_id}}"`
fi
column_id=$[column_id + 1]
done
if [ -z "$iostats" ]; then
echo "error: "device" or "type" not found (${dev},${type})"
exit 3
fi
iostats_lines=`wc -l <<< "$iostats"`
if [ $iostats_lines -ne 1 ]; then
echo "error: wrong output value (${iostats_lines})"
exit 2
fi
echo $iostats
if [[ $debug -eq 1 ]]; then
echo "- - - - - - - - - -"
echo $columns
iostats_debug=`iostat -xN |egrep -o "^${dev}[[:space:]]+.*"`
echo $iostats_debug
echo "- - - - - - - - - -"
fi
exit 0
1.【客户端配置】获取参数.
vim /etc/zabbix/zabbix_agentd.d/system.conf
# 磁盘读写
#UserParameter=discovery.disks.iostats,/etc/zabbix/scripts/discover_disk.pl
UserParameter=custom.vfs.dev.iostats.rrqm[*],/etc/zabbix/scripts/zbx_parse_iostat_values.sh $1 "rrqm/s" # 每秒进行 merge 的读操作数目
UserParameter=custom.vfs.dev.iostats.wrqm[*],/etc/zabbix/scripts/zbx_parse_iostat_values.sh $1 "wrqm/s" # 每秒进行 merge 的写操作数目
UserParameter=custom.vfs.dev.iostats.rps[*],/etc/zabbix/scripts/zbx_parse_iostat_values.sh $1 "r/s" # 每秒完成的读 I/O 设备次数
UserParameter=custom.vfs.dev.iostats.wps[*],/etc/zabbix/scripts/zbx_parse_iostat_values.sh $1 "w/s" # 每秒完成的写 I/O 设备次数
UserParameter=custom.vfs.dev.iostats.rkb[*],/etc/zabbix/scripts/zbx_parse_iostat_values.sh $1 "rkB/s" # 每秒读K字节数
UserParameter=custom.vfs.dev.iostats.wkb[*],/etc/zabbix/scripts/zbx_parse_iostat_values.sh $1 "wkB/s" # 每秒写K字节数
UserParameter=custom.vfs.dev.iostats.avgrq[*],/etc/zabbix/scripts/zbx_parse_iostat_values.sh $1 "avgrq-sz" # 平均每次设备I/O操作的数据大小
UserParameter=custom.vfs.dev.iostats.avgqu[*],/etc/zabbix/scripts/zbx_parse_iostat_values.sh $1 "avgqu-sz" # 平均I/O队列长度
UserParameter=custom.vfs.dev.iostats.await[*],/etc/zabbix/scripts/zbx_parse_iostat_values.sh $1 "await" # 平均每次设备I/O操作的等待时间 (毫秒)
UserParameter=custom.vfs.dev.iostats.svctm[*],/etc/zabbix/scripts/zbx_parse_iostat_values.sh $1 "svctm" # 平均每次设备I/O操作的服务时间 (毫秒)
UserParameter=custom.vfs.dev.iostats.util[*],/etc/zabbix/scripts/zbx_parse_iostat_values.sh $1 "%util" # 一秒中有百分之多少的时间用于 I/O 操作
2.【重启客户端】
systemctl restart zabbix-agent.service
六.企业微信发送告警
【6-1】微信申请
1.【进入企业微信网页版本】企业微信页面
2.【申请注册并登陆】
3.点击: 【应用管理】——》【创建应用】——》【应用名称】--》【应用介绍】——》【选择部门成员】--完成
4.点击: 【通讯录】——》【创建部门】————》【添加子部门】——》【运维部】——》【点击成员】——》【设置所在部门】
5.三个信息:
【企业】:corpid = 'ww3c487ba1e6eec2ab' #CorpID是企业号的标识
【应用】:AgentId 1000002 应用的标识
【Secret】:LStqb7q8Ymh3ZecammdHdX134qyjFGRKqhKbTyGOqeo
yum install python-simplejson -y
【6-2】配置脚本
1.#在zabbix特定目录下创建脚本
vim /usr/lib/zabbix/alertscripts/wechat.py
#_*_coding:utf-8 _*_
import urllib,urllib2
import json
import sys
import simplejson
reload(sys)
sys.setdefaultencoding('utf-8')
def gettoken(corpid,corpsecret):
gettoken_url = 'https://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid=' + corpid + '&corpsecret=' + corpsecret
print gettoken_url
try:
token_file = urllib2.urlopen(gettoken_url)
except urllib2.HTTPError as e:
print e.code
print e.read().decode("utf8")
sys.exit()
token_data = token_file.read().decode('utf-8')
token_json = json.loads(token_data)
token_json.keys()
token = token_json['access_token']
return token
def senddata(access_token,user,subject,content):
send_url = 'https://qyapi.weixin.qq.com/cgi-bin/message/send?access_token=' + access_token
send_values = {
"touser":"LiuZongLiang", #企业号中的用户帐号,在zabbix用户Media中配置,如果配置不正常,将按部门发送。
"toparty":"2", #企业号中的部门id。
"msgtype":"text", #消息类型。
"agentid":"1000002", #企业号中的应用id。
"text":{
"content":subject + ' ' + content
},
"safe":"0"
}
# send_data = json.dumps(send_values, ensure_ascii=False)
send_data = simplejson.dumps(send_values, ensure_ascii=False).encode('utf-8')
send_request = urllib2.Request(send_url, send_data)
response = json.loads(urllib2.urlopen(send_request).read())
print str(response)
if __name__ == '__main__':
user = str(sys.argv[1]) #zabbix传过来的第一个参数
subject = str(sys.argv[2]) #zabbix传过来的第二个参数
content = str(sys.argv[3]) #zabbix传过来的第三个参数
corpid = 'ww3c487ba1e6eec2ab' #CorpID是企业号的标识
corpsecret = 'LStqb7q8Ymh3ZecammdHdX134qyjFGRKqhKbTyGOqeo' #corpsecretSecret是管理组凭证密钥
accesstoken = gettoken(corpid,corpsecret)
senddata(accesstoken,user,subject,content)
【6-3】授权文件
chmod 777 wechat.py
chown zabbix.zabbix wechat.py
【6-4】配置页面
配置一:报警媒介
*名称:【wechat】
类型:【脚本】 #下拉选择“脚本”
脚本名称【wechat.py】
脚本参数
参数 动作
{ALERT.SENDTO} 【移除】
{ALERT.SUBJECT} 【移除】
{ALERT.MESSAGE} 【移除】
【添加】
已启用【√】
【添加】【取消】 #点击添加
添加完后,点击右边测试(没有测试按钮的属于zabbix版本过低)
发送用户:LiuZongLiang #发送接收的企业微信成员
配置二:用户关联
1.点击:
【管理】——》【用户】--》【别名】
2进入后,点击用户右边【报警媒介】
3.添加
类型:wechat
收件人:LiuZongLiang #添加企业微信成员
当启用时间
1-7,00:00-24:00
如果存在严重性则使用如下
v【未分类】
v【信息】
v【警告】
v【一般严重】
v【严重】
v【灾难】
点击【已启用】
点击【添加】
配置三:动作配置
点击:
1.【动作】——》【名称】——》【触发器或者触发名称】——》[添加]——》【已启用】
然后点击【操作】——》【新的】——》【操作类型】——》【发送到用户群组】——》【用户】——>【仅送到所有】改为【wechat】——》点击[添加]——》【恢复操作】....——》【更新操作】——》【添加】
完成
七.QQ邮箱发送告警
【7-1】开启功能
1.点击【QQ】——》【邮箱】--》【设置】——》【账户设置】
开启服务:
POP3/SMTP服务 (如何使用 Foxmail 等软件收发邮件?) 已关闭 | 开启
IMAP/SMTP服务 (什么是 IMAP,它又是如何设置?) 已关闭 | 开启
2.点击右边开启,然后会随机生成一个一长串的密码【figpneovepwwbecd】
【7-2】配置页面
【提示:】打√号的为选择方式
1.点击zabbix-web界面版
点击【管理】——》【创建媒体类型】——》
报警媒介类型
报警媒介类型选项
【名称】:QQ邮箱 #自定义为QQ邮箱
【类型】:电子邮件 #类型选择电子邮件
【SMTP服务器】: smtp.qq.com #填写smtp.qq.com
【SMTP服务器端口】:465 #端口号:456
【SMTP HELO】:qq.com #qq.com
SMTP电邮: 5435435@qq.com #邮箱
安全链接 【无STARTTLS(纯文本通信协议扩展)】 [√]【SSL/TLS】 #安全连接选择SSl和TLS,下面两个SSL验证对端,和SSL验证主机打钩
SSL验证对端[√]
SSL验证主机[√]
认证:【无】 [√]【用户名和密码】 #选择用户名密码认证,下面数据用户名和密码
用户名称 5435435@qq.com
密码 figpneovepwwbecd
Message format
【HTML】【文本】
已启用[√]
【添加】 【取消】
【添加完成后,右边有个测试的按钮,测试发送邮件是否成功
如果没有测试按钮的,属于zabbix版本过低,升级服务即可
【7-3】用户配置
1.测试成功后——》点击【配置】——》【用户】--》【Admin】——》右边【报警媒介】
2.点击【添加】
报警媒介
类型: QQ邮箱
收件人 【5435435@qq.com】 移除
添加
当启用时 【1-7,00:00-24:00】
如果存在严重性则使用【】未分类
【】信息
【√】警告
【√】一般严重
【√】严重
【√】灾难
已启用【√】
【添加】 【取消】
【8-4】动作配置
点击:
1.【动作】——》【名称】——》【触发器或者触发名称】——》[添加]——》【已启用】
然后点击【操作】——》【新的】——》【操作类型】——》【发送到用户群组】——》【用户】——>【仅送到所有】改为【wechat】——》点击[添加]——》【恢复操作】....——》【更新操作】——》【添加】
完成