一、准备工作

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. Debian 16.04 配置双网卡绑定bond

    Debian 16.04 配置双网卡绑定bond Debian 16.04 bonding多网卡配置 安装负载均衡软件 fenslave root@ubuntu:~# apt-get install ...

  2. mysql如何设置一个字段,里面是自增的序号(1,2,3,..........)。

    [遇到问题] [可忽略] 想把以前写的留言板搬到我的网站上去,所以要在Mysql上创建一个一mu一样的数据库,表单,字段..................... userid这个字段忘记了如何添加, ...

  3. nohup 命令 2>&1 |tee lmbench.log & 只适用没有需要敲y或x的

    nohup make results 2>&1 |tee lmbench.log & nohup 命令 2>&1 |tee lmbench.log & 只适 ...

  4. 编写程序,计算当n=10000,20000,30000...100000时,π的值.求π的近似公式 π=4*(1-1/3+1/5-1/7+1/9-1/11+1/13-...+1/(2n-1)-1/(2n+1))

    该程序是求的 π 近似值,所以随着 i 的增大,值会无线接近于 3.1415926... 代码示例 : package judgment;/** * 编写程序,计算当n=10000,20000,300 ...

  5. unity中使用Highlighting System v4.0插件给物体添加高亮

    插件:Highlighting System v4.0 操作:在摄像机上挂上HighlightingRenderer脚本 脚本目录在\Assets\Plugins\HighlightingSystem ...

  6. 解决mysql无法远程连接的问题

    前言 最近开发中遇到一个问题,mysql在服务器本地可以登录,但是远程通过3306端口却不可以.这个问题困扰了我一周之久,终于在今天解决了.在解决的过程中试了很多的方法,遂记录下来,希望能给大家一些提 ...

  7. Lua在Windows下的安装、配置、运行

    Lua在Windows下的安装.配置.运行 本文链接:https://blog.csdn.net/ChinarCSDN/article/details/78667262 展开 # Windows下安装 ...

  8. Processing平台之PVector求角度

    问题:在processing 平台,通过给定三个PVector向量,如何求他们之间的夹角,同时确定是在左侧还是右侧? 如图所示,在processing 平台中,PVector表示点的坐标是以原点为起点 ...

  9. bind,call,apply的区别

    function cat(){}cat.prototype={ food:"fish", say: function(){ alert("I love "+th ...

  10. 服务化部署框架Paddle Serving

    服务化部署框架Paddle Serving 概述 常见的深度学习模型开发流程需要经过问题定义.数据准备.特征提取.建模.训练过程,以及最后一个环--将训练出来的模型部署应用到实际业务中.如图1所示,当 ...