一、准备工作

1、mysql数据库:192.168.1.5
2、nginx服务:192.168.1.10
3、docker服务器:192.168.1.20
4、zabbix客户端若干

二、docker搭建zabbix

1、部署zabbix-server

先部署测试zabbix-server:

mkdir -p /home/docker/server/zabbix
docker pull zabbix/zabbix-server-mysql
docker run --name zabbix-server -p 10051:10051 \
-e DB_SERVER_HOST="192.168.1.5" \
-e MYSQL_USER="zabbix" -e MYSQL_PASSWORD="123456" \
-itd zabbix/zabbix-server-mysql
docker cp zabbix-server:/etc/zabbix /home/docker/server/zabbix/zabbix-server  #将zabbix配置文件放到服务器,为的是修改方便
docker rm -f zabbix-server

启动正式docker-server:

docker run --name zabbix-server -p 10051:10051 \
-e DB_SERVER_HOST="192.168.1.5" \
-e MYSQL_USER="zabbix" -e MYSQL_PASSWORD="1234565" \
-v /home/docker/server/zabbix/server/zabbix_server.conf:/etc/zabbix/ zabbix_server.conf \
-v /home/docker/server/zabbix/server/alertscripts:/usr/lib/zabbix/alertscripts \
-v /home/docker/server/zabbix/server/externalscripts:/usr/lib/zabbix/externalscripts \
-v /home/docker/server/zabbix/server/modules:/var/lib/zabbix/modules \
-v /home/docker/server/zabbix/server/enc:/var/lib/zabbix/enc \
-v /home/docker/server/zabbix/server/ssh_keys:/var/lib/zabbix/ssh_keys \
-v /home/docker/server/zabbix/server/ssl/certs:/var/lib/zabbix/ssl/certs \
-v /home/docker/server/zabbix/server/ssl/keys:/var/lib/zabbix/ssl/keys \
-v /home/docker/server/zabbix/server/ssl/ssl_ca:/var/lib/zabbix/ssl/ssl_ca \
-v /home/docker/server/zabbix/server/snmptraps:/var/lib/zabbix/snmptraps \
-v /home/docker/server/zabbix/server/mibs:/var/lib/zabbix/mibs \
-itd zabbix/zabbix-server-mysql
注:-v 参数将容器文件映射到服务器,也是方便修改

2、部署zabbix-web

先部署测试zabbix-web:

docker pull zabbix/zabbix-web-nginx-mysql
docker run --name zabbix-web  -p 8080:8080 -p 8443:8443 \
--link zabbix-server:zabbix-server \
-e DB_SERVER_HOST="192.168.1.5" \
-e MYSQL_USER="zabbix" -e MYSQL_PASSWORD="123456" \
-e ZBX_SERVER_HOST="zabbix-server" \
-e PHP_TZ="Asia/Shanghai" \
-itd zabbix/zabbix-web-nginx-mysql
docker cp zabbix-web:/usr/share/zabbix /home/docker/server/zabbix/zabbix-web 
注:--link 链接容器,可以互相通信,接收容器可以获取源容器的环境变量。   -e 设置环境变量。

启动正式zabbix-web:

docker run --name zabbix-web  -p 8080:8080 -p 8443:8443 \
--link zabbix-server:zabbix-server \
-v /home/docker/server/zabbix/zabbix-web:/usr/share/zabbix \
-e DB_SERVER_HOST="192.168.1.5" \
-e MYSQL_USER="zabbix" -e MYSQL_PASSWORD="123456" \
-e ZBX_SERVER_HOST="zabbix-server" \
-e PHP_TZ="Asia/Shanghai" \
-itd zabbix/zabbix-web-nginx-mysql

3、部署zabbix-agent

先部署测试zabbix-agent:

docker pull zabbix/zabbix-agent
docker run --name zabbix-agent -p 10050:10050 \
--link zabbix-server:zabbix-server \
-itd zabbix/zabbix-agent
docker cp zabbix-agent:/etc/zabbix /home/docker/server/zabbix/zabbix-agent 
docker rm -f zabbix-agent

修改zabbix_agentd.conf配置文件:(有2种情况)

  (1)zabbix-server和zabbix-agent在同一台服务器部署

Server=172.17.0.1      #docker容器的网关地址 

  (2)zabbix-server和zabbix-agent不在一台服务器

Server=192.168.1.20
ServerActive=192.168.1.20:10051
Hostname=主机名

启动正式zabbix-agent:

docker run --name zabbix-agent -p 10050:10050 \
--link zabbix-server:zabbix-server \
-v /home/docker/server/zabbix/zabbix-agent/zabbix_agentd.conf:/etc/zabbix/zabbix_agentd.conf \
-itd zabbix/zabbix-agent

在nginx配置域名访问:

server {
server_name zabbix.aa.com;
listen 80;
location /zabbix/ {
proxy_pass http://192.168.1.20:8080/;
proxy_redirect off;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_next_upstream error timeout invalid_header;
}
}

访问url:http://zabbix.aa.com/zabbix           默认用户名密码:admin/zabbix

注:如果想在没有装docker环境的服务器安装zabbix客户端,直接下载zabbix-agent安装包就可以了。(总结来说docker部署的zabbix-agent不太好用,可以用zabbix+grafana实现所有监控功能:zabbix监控Linux服务,grafana监控容器服务)

三、zabbix页面配置

要配合Grafana做监控系统,所以下面选项中有创建触发器的操作就可以免除了。

1、提前准备

创建模板:

创建应用集:

添加主机:

2、监控端口

添加监控项:

创建触发器:

点完添加会出现下面这个条件选项:

3、url监控(不需要安装zabbix-agent)

创建web场景:

四、zabbix结合Grafana页面展示并邮件警报

因为之前写过docker部署Prometheus+Grafana,这里搭建grafana就可以了,还需要为grafana安装一个zabbix插件:

docker exec -it grafana grafana-cli plugins install alexanderzobnin-zabbix-app    #进入容器执行命令
docker restart grafana #重启grafana

1、提前准备

访问Grafana:http://grafana.aa.com  用户名密码:admin/grafana123  在页面配置zabbix插件并添加数据源:   

保存并测试,如果成功说明和zabbix已经连接成功。

创建报警信息:(grafana自带的警报)

2、导入json仪表盘模板

根据自己需求下载:https://grafana.com/grafana/dashboards,下载完导入到grafana:

3、手动创建仪表板:

(1)监控端口并报警:

   监控端口并报警配置完成。

(2)监控url并报警:

  监控URL并报警配置完成。

报警邮件展示:

功能以及操作方面可能有所不足,还在研究,持续更新中!!!

人生确实没有意义,但人生有美。

Docker搭建zabbix+grafana监控系统的更多相关文章

  1. Docker搭建Prometheus+grafana监控系统

    一.Prometheus简介 1.简介 Prometheus是由SoundCloud开发的开源监控报警系统和时序列数据库(TSDB). Prometheus使用Go语言开发,是Google BorgM ...

  2. Docker部署Zabbix+Grafana监控

    Docker部署Zabbix+Grafana监控 环境 centos 7 ; Docker 17.12.0-ce ; docker-compose version 1.20.1 2018-4-1 当前 ...

  3. docker-compose 搭建 Prometheus+Grafana监控系统

    有关监控选型之前有写过一篇文章: 监控系统选型,一文轻松搞定! 监控对象 Linux服务器 Docker Redis MySQL 数据采集 1).prometheus: 采集数据 2).node-ex ...

  4. docker-compose快速搭建 Prometheus+Grafana监控系统

    一.说明Prometheus负责收集数据,Grafana负责展示数据.其中采用Prometheus 中的 Exporter含:1)Node Exporter,负责收集 host 硬件和操作系统数据.它 ...

  5. 搭建zabbix+grafana监控

    编写一件安装脚本 #!/bin/sh echo "\033[32;1m脚本作者:fage\033[0m" #sleep 10 zabbix_version=4.0.2 zabbix ...

  6. [转帖]基于docker 搭建Prometheus+Grafana

    基于docker 搭建Prometheus+Grafana https://www.cnblogs.com/xiao987334176/p/9930517.html need good study 一 ...

  7. Zabbix分布式监控系统实践

    https://www.zabbix.com/wiki/howto/install/Ubuntu/ubuntuinstall 环境介绍OS: Ubuntu 10.10 Server 64-bitSer ...

  8. docker搭建zabbix

    本次使用docker搭建zabbix的组合是mysql+docker+zabix-server 1 先安装数据库mysql docker run --name zabbix-mysql-server ...

  9. 使用Ubuntu系统编译安装Zabbix企业级监控系统

    使用Ubuntu系统编译安装Zabbix企业级监控系统   作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. Ubuntu系统部署笔记:https://www.cnblogs.com/ ...

随机推荐

  1. 攻防世界(一)baby_web

    攻防世界系列:baby_web 方法一: 按照提示,初始界面自然想到index.php,访问后界面(注意到URL)仍是1.php 打开hackbar查看响应,发现确实有index.php点开看到了Fl ...

  2. S8 Linux磁盘与文件系统管理命令

    8.1 fdisk:磁盘分区工具 8.2-3 partprobe.tune2fs 8.4 parted:磁盘分区工具 8.5-7 mkfs.dumpe2fs.resize2fs 8.8-9 fsck. ...

  3. dd命令详解-(转自dkcndk)

    Linux-dd命令详解 dd 是 Linux/UNIX 下的一个非常有用的命令,作用是用指定大小的块拷贝一个文件,并在拷贝的同时进行指定的转换.名称: dd 使用权限: 所有使用者dd 这个指令在 ...

  4. 转载 | python inferface使用

    Python中最特别的关键字之一便是pass,它放在类或函数里,表示类和函数暂不定义. class PassClass: pass def PassFun(): pass 如上实现最精简的类和函数定义 ...

  5. NNVM Compiler,AI框架的开放式编译器

    NNVM Compiler,AI框架的开放式编译器 深度学习已变得无处不在且不可或缺.在多种平台(例如手机,GPU,IoT设备和专用加速器)上部署深度学习工作负载的需求不断增长.宣布了TVM堆栈,以弥 ...

  6. 人脸真伪验证与识别:ICCV2019论文解析

    人脸真伪验证与识别:ICCV2019论文解析 Face Forensics++: Learning to Detect Manipulated Facial Images 论文链接: http://o ...

  7. 使用Relay部署编译ONNX模型

    使用Relay部署编译ONNX模型 本文介绍如何使用Relay部署ONNX模型的入门. 首先,必须安装ONNX软件包. 一个快速的解决方案是安装protobuf编译器,然后 pip install o ...

  8. 深入理解java虚拟机笔记Chapter11

    运行期优化 即时编译 什么是即时编译? 当虚拟机发现某个方法或某段代码运行的特别频繁时,会把这段代码认为成热点代码: 在运行时,虚拟机会将这段代码编译成平台相关的机器码,并进行各种层次的优化. Hot ...

  9. Spring——Bean的作用域

    Spring中Bean的作用域有五种,分别是singleton.prototype.request.session.globalSession.其中request.session.globalSess ...

  10. Spring:DI依赖注入的几种方式

    据我所学,spring实现依赖注入(DI)的方式分为三大类:基于构造器(构造方法)的依赖注入.基于setter的依赖注入.其他方式(c命名空间.p命名空间等).其中推荐使用setter方法注入,这种注 ...