【Linux】在docker上部署grafana+zabbix监控实录
-------------------------------------------------------------------------------------------------
| 欢迎关注个人公众号 zclinux_note 第一时间获取关于linux使用的技巧。探索Linux的奥秘 |
-------------------------------------------------------------------------------------------------
环境:CentOS7
内核:3.10.0-957.el7.x86_64
grafana+zabbix-server主机IP:192.168.25.100
zabbix_agent 主机IP:192.168.25.10
前提:需要事先停止selinux,iptables,firewalld服务
1.首先安装docker
(1)配置阿里云repo
yum install wget -y
wget -O /etc/yum.repos.d/CentOS7-Aliyun.repo http://mirrors.aliyun.com/repo/Centos-7.repo
yum clean all
yum makecache fast
(2)清除系统上原有老版本docker
sudo yum remove docker \
docker-client \
docker-client-latest \
docker-common \
docker-latest \
docker-latest-logrotate \
docker-logrotate \
docker-selinux \
docker-engine-selinux \
docker-engine
(3)安装docker
安装自己的docker,我这里安装的是18.0.6的docker
安装环境依赖
sudo yum install -y yum-utils device-mapper-persistent-data lvm2
下载阿里云的docker的repo文件
sudo yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
sudo yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
安装docker
yum install docker-ce-18.06.0.ce -y
systemctl enable docker
systemctl start docker
查看docker版本是否正确
docker version
[root@docker ~]# docker version
Client:
Version: 18.06.0-ce
API version: 1.38
Go version: go1.10.3
Git commit: 0ffa825
Built: Wed Jul 18 19:08:18 2018
OS/Arch: linux/amd64
Experimental: false
Server:
Engine:
Version: 18.06.0-ce
API version: 1.38 (minimum version 1.12)
Go version: go1.10.3
Git commit: 0ffa825
Built: Wed Jul 18 19:10:42 2018
OS/Arch: linux/amd64
Experimental: false
配置阿里docker镜像加速器
sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json <<-'EOF'
{
"registry-mirrors": ["https://bxdltesm.mirror.aliyuncs.com"]
}
EOF
sudo systemctl daemon-reload
sudo systemctl restart docker
2.安装完成后,再创建相关目录环境
mkdir -p /data/zabbix/mysql
useradd mysql
chown -R mysql.mysql /data/zabbix/mysql
3.开始安装zabbix-mysql,zabbix-nginx,zabbix-server
这里强调一点,zabbix和server,agent,还有grafana都是最新版,在容器启动的最后一行都是latest,如果需要特殊版本,需要特别指定
先启动数据库容器
docker run --name mysql-server -t \
-e MYSQL_DATABASE="zabbix" \
-e MYSQL_USER="zabbix" \
-e MYSQL_PASSWORD="zabbix_pwd" \
-e MYSQL_ROOT_PASSWORD="root_pwd" \
-v /data/zabbix/mysql:/var/lib/mysql \
-d mysql:5.7
启动zabbix-mysql服务端容器
docker run --name zabbix-server-mysql -t \
-e DB_SERVER_HOST="mysql-server" \
-e MYSQL_DATABASE="zabbix" \
-e MYSQL_USER="zabbix" \
-e MYSQL_PASSWORD="zabbix_pwd" \
-e MYSQL_ROOT_PASSWORD="root_pwd" \
--link mysql-server:mysql \
-p 10051:10051 \
-d zabbix/zabbix-server-mysql:latest
启动zabbix-server容器
docker run --name zabbix-web-nginx-mysql -t \
-e DB_SERVER_HOST="mysql-server" \
-e MYSQL_DATABASE="zabbix" \
-e MYSQL_USER="zabbix" \
-e MYSQL_PASSWORD="zabbix_pwd" \
-e MYSQL_ROOT_PASSWORD="root_pwd" \
--link mysql-server:mysql \
--link zabbix-server-mysql:zabbix-server \
-p 80:80 \
-d zabbix/zabbix-web-nginx-mysql:latest
4.安装agent,客户端需要修改ip,其实也可以手动安装
docker run --name zabbix-agent \
-e ZBX_HOSTNAME="zabbix-agent" \
-e ZBX_SERVER_HOST="192.168.25.100" \
-p 10050:10050 \
--privileged \
-d zabbix/zabbix-agent:latest
手动安装zabbix-agent步骤
登陆该网站,选择自己的zabbix-server的版本(查看版本的方法是zabbix_server -V)
https://www.zabbix.com/download
然后看到下面有rpm -Uvh的命令,将其复制并执行再agent的服务器上
# rpm -Uvh https://repo.zabbix.com/zabbix/4.4/rhel/8/x86_64/zabbix-release-4.4-1.el8.noarch.rpm
我这里是4.4的版本
完成后,执行yum install -y zabbix-agent
完成后,手动修改/etc/zabbix/zabbix-agentd.conf文件中的serverip,serveractive,
全部完成后,重启agent进程
systemctl restart zabbix-agent
查看监听端口10050是否被监听
至此,agent全部安装完成
5.安装grafana
用户名密码都是admin
docker run -d --name=grafana -p 3000:3000 grafana/grafana
所有容器启动后,查看容器是否都正常运行
[root@docker ~]# docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
96b983e4ca77 zabbix/zabbix-web-nginx-mysql:latest "docker-entrypoint.sh" Less than a second ago Up Less than a second 0.0.0.0:80->80/tcp, 443/tcp zabbix-web-nginx-mysql
1400794e747c zabbix/zabbix-agent:latest "/sbin/tini -- /usr/? Less than a second ago Up Less than a second 0.0.0.0:10050->10050/tcp zabbix-agent
2695290c1afe grafana/grafana "/run.sh" 21 hours ago Up Less than a second 0.0.0.0:3000->3000/tcp grafana
bf70f93e0a1c zabbix/zabbix-server-mysql:latest "/sbin/tini -- /usr/? 21 hours ago Up Less than a second 0.0.0.0:10051->10051/tcp zabbix-server-mysql
efd6f9b4460e mysql:5.7 "docker-entrypoint.s? 21 hours ago Up Less than a second 3306/tcp, 33060/tcp mysql-server
打开zabbix的网页管理界面
http://192.168.25.100/zabbix
这里无需setup,容器已经都自动安装配置好,登陆直接就是控制台
分别点击【配置】 --> 【主机】-->【创建主机】
配置模板
完成后点击保存(因为我已经添加过了,所以显示的是更新按钮)
显示为绿色证明agent已经被server端监控好了
下面查看grafana是否安装成功
http://192.168.25.100:3000
账号密码都是admin,第一次登陆会强制修改密码
进入之后,需要创建新用户
点击邀请
创建的用户可以分配不同权限,我这里给了编辑权限,邮件选择不发送
点击复制邀请连接,在浏览器新界面点开
复制出来的地址可能是localhost,需要将其修改为本地server的ip,我这里是192.168.25.100
密码完成后,会自动登陆
6.安装grafana的zabbix插件
登陆到grafana的容器中操作
# docker exec -it grafana /bin/bash
root@a92fe62a4475:/# grafana-cli plugins install alexanderzobnin-zabbix-app
会提示一些信息,等待完成
root@a92fe62a4475:/# exit
重启grafana容器
docker restart grafana
完成后,再次进入到grafana的控制台,使用admin用户
找到zabbix
点击enable,然后看下是否有更新update一下
完成后,进入到data sources中,配置zabbix的api
开始配置
成功后,会提示绿色的对勾
然后到上面找到这个
点击导入import
其中配置这个地方的时候,地址的url写的有问题,写成了http//192.168.25.100/zabbix/api_jsonrpc.php
结果一直提示file not found.....
查了一些关于php的,也查看了配置文件,都是正常,最后要查的地方是nginx的配置
进入到容器中
[root@docker ~]# docker exec -it 96b983e4ca77 /bin/bash
找到nginx的配置文件
vi /etc/nginx/conf.d/下的nginx.conf文件
发现,nginx的配置直接就是在zabbix下的,
原来是乌龙,重新配置后才真正生效,网上也有直接配置http://192.168.25.100/zabbix的,虽然也生效,但是api接口不正确,最后获取不到正确的数据的
7.简单创建监控项
如果配置都正确的话,前面的group和host都好后,application和item会自动弹出监控项
这样配置的api才正确
找到想监控的监控项后,修改名称
最后,点击保存,保存在标题栏上,一定要保存
这就是全部完整的流程
【Linux】在docker上部署grafana+zabbix监控实录的更多相关文章
- 【集群监控】Docker上部署Prometheus+Alertmanager+Grafana实现集群监控
Docker部署 下载 sudo yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.re ...
- 使用VS把ASP.NET 5的应用发布到Linux的Docker上
(此文章同时发表在本人微信公众号"dotNET每日精华文章",欢迎右边二维码来关注.) 题记:我相信未来应用程序的部署模式首选一定会是Docker,所以.NET社区的朋友也不应该忽 ...
- 定期从Docker上部署的MySQL备份数据
前段时间公司停电,正巧赶上周一领导要开会要过一遍项目,然而项目所依赖的MySQL数据库是直接部署在宿主机,且因为各人部署方式不同的原因,花了很久才在开会前启动起来.于是开完会后,我第一件事就是把原先依 ...
- 阿里云上部署了zabbix,突然无法收到报警邮件的解决办法
在阿里云上部署了zabbix,一直能正常接收到zbx发来的报警邮件(报警邮箱是163的),不知是什么原因,突然无法接收到报警邮件了. 但在服务器上手动执行echo "hello"| ...
- Linux实战教学笔记49:Zabbix监控平台3.2.4(一)搭建部署与概述
https://www.cnblogs.com/chensiqiqi/p/9162986.html 一,Zabbix架构 zabbix 是一个基于 WEB 界面的提供分布式系统监视以及网络监视功能的企 ...
- Linux实战教学笔记50:Zabbix监控平台3.2.4(二)深入理解zabbix
https://www.cnblogs.com/chensiqiqi/p/9162986.html 一,Zabbix Web操作深入 1.1 Zabbix Web下的主机和模版以及监控项的添加方式 ( ...
- Linux实战教学笔记51:Zabbix监控平台3.2.4(三)生产环境案例
https://www.cnblogs.com/chensiqiqi/p/9162986.html 一,Zabbix生产环境监测案例概述 1.1 项目规划 [x] :主机分组 交换机 Nginx To ...
- 本地Docker Jenkins构建dotnet core web应用到Linux服务器 Docker上
1.准备工作 环境 本地: Windows.Docker 代码仓库:Git 服务器:Linux.Docker 前提准备 创建个有dockerfile文件的dotnet core 3 web项目 新建一 ...
- 使用 Docker 部署 Grafana + Prometheus 监控 MySQL 数据库
一.背景 在平时开发过程当中需要针对 MySQL 数据库进行监控,这里我们可以使用 Grafana 和 Prometheus 来实现监控功能.Grafana 是一款功能强大的仪表盘面板,支持多种数据源 ...
随机推荐
- 一、什么是Jmeter?Jmeter安装?Jmeter的启动?
什么是Jmeter Apache JMeter 是 Apache 组织开发的基于 Java 的压力测试工具,也可以进行接口测试.它是一个开源的,100%基于Java的应用程序,带有图形界面.它旨在分析 ...
- 【Cesium 颜狗初步】fabric 材质定义与自定义着色器实践
fabric 材质定义:着色器实践 1. 示例代码 贴到沙盒里就可以运行: var viewer = new Cesium.Viewer("cesiumContainer"); v ...
- ss命令结合zabbix对socket做监控
本文为博客园作者所写: 一寸HUI,个人博客地址:https://www.cnblogs.com/zsql/ 最近天冷了,socket也出问题了,一直没有做监控,现在就把监控加起来,目前我们使用的有z ...
- 腾讯健康码16亿亮码背后的Elasticsearch系统调优实践【>>戳文章免费体验Elasticsearch服务30天】
[活动]Elasticsearch Service免费体验馆>>Elasticsearch Service新用户特惠狂欢低至4折>>Elasticsearch Service企 ...
- Graphql Tutorials(Episode 01)
1.前言 最近认识到Graphql,它是一个基于DSL的api.我曾接触过一个pos机刷卡系统,它是基于JSON-DSL语言开发的框架,很有趣.可是后来,没有机会深入研究.直到最近我认识了Graphq ...
- Loading class `com.mysql.jdbc.Driver'. This is deprecated警告处理
com.mysql.jdbc.Driver 和 com.mysql.cj.jdbc.Driver的区别 mysql客户端6以后,数据库驱动com.mysql.jdbc.Driver'已经被弃用了.应当 ...
- js上 五、运算符-1
5.1.认识运算符 什么是运算符? 运算符用于执行程序代码运算,会针对一个以上操作数项目来进行运算. 运算符的应用: 购物车:计算总价,数量: **Js ** 中有哪些运算符? 算术运算符.赋值运算符 ...
- js下 Day20、综合案例
一.购物车 效果图: 功能思路分析: 1. 面向对象框架 2. 模拟数据 1.多个店铺数组套对象 2.每个店铺多个商品,数组套对象
- PHP可变变量特性
可变变量 有时候使用可变变量名是很方便的.就是说,一个变量的变量名可以动态的设置和使用.一个普通的变量通过声明来设置,例如: <?php$a = 'hello';?> 一个可变变量获取了一 ...
- Kafka数据每5分钟同步到Hive
1.概述 最近有同学留言咨询Kafka数据落地到Hive的一些问题,今天笔者将为大家来介绍一种除Flink流批一体以外的方式(流批一体下次再单独写一篇给大家分享). 2.内容 首先,我们简单来描述一下 ...