Zabbix技术分享——使用docker-compose快速部署zabbix监控系统
前面文章有提到过使用docker来快速拉起一个zabbix监控系统(详见:如何使用docker快速部署一个zabbix监控系统),但是要一个个执行docker启动命令去将对应的容器启动。如果要配置参数多,那敲启动命令就是一件让人心累的事情。而且敲完后若没有保存启动命令,后面的管理也是比较麻烦,并且如果容器数量较多,还要一个个手敲启动命令,这就非常的不方便。
所以为了解决这个问题,并且更加高效的启动一个zabbix监控系统。现在使用docker-compose这个容器编排工具来高效的启动zabbix监控系统。
1. Docker-compose介绍
- Docker-Compose项目是Docker官方的开源项目,负责实现对Docker容器集群的快速编排, 并且提供了 scale (服务扩容) 的功能。
- Docker-Compose将所管理的容器分为三层,分别是工程(project),服务(service)以及容器(container)。Docker-Compose运行目录下的所有文件(docker-compose.yml,extends文件或环境变量文件等)组成一个工程,若无特殊指定工程名即为当前目录名。一个工程当中可包含多个服务,每个服务中定义了容器运行的镜像,参数,依赖。一个服务当中可包括多个容器实例,Docker-Compose并没有解决负载均衡的问题,因此需要借助其它工具实现服务发现及负载均衡。
- Docker-Compose的工程配置文件默认为docker-compose.yml,可通过环境变量COMPOSE_FILE或-f参数自定义配置文件,其定义了多个有依赖关系的服务及每个服务运行的容器。
- 使用一个Dockerfile模板文件,可以让用户很方便的定义一个单独的应用容器。在工作中,经常会碰到需要多个容器相互配合来完成某项任务的情况。例如要实现一个Web项目,除了Web服务容器本身,往往还需要再加上后端的数据库服务容器,甚至还包括负载均衡容器等。
- Compose允许用户通过一个单独的docker-compose.yml模板文件(YAML 格式)来定义一组相关联的应用容器为一个项目(project)。
- Docker-Compose项目由Python编写,调用Docker服务提供的API来对容器进行管理。因此,只要所操作的平台支持Docker API,就可以在其上利用Compose来进行编排管理。
2. 基础语法
Docker-compose就是通过docker-compose.yaml文件所定义的容器作为一个项目,从而进行docker容器的管理。下面就对docker-compose.yaml模板文件的常用基础语法进行一个简单的解释
2.1 container_name
Compose 的容器默认名称格式是:<项目名称><服务名称><序号>
虽然可以自定义项目名称、服务名称,但是如果你想完全控制容器的命名,可以使用这个标签指定:
比如我要制定一个mysql容器的名为“mysql-test”,那么
version: '3'
services:
mysql:
container_name: mysql-test
2.2 image
指定服务的镜像名称或镜像 ID。如果镜像在本地不存在,Compose 将会尝试拉取这个镜像。
比如我要制定一个mysql容器,使用的镜像名为“mysql:8.0”,那么
version: '3'
services:
mysql:
image: mysql:8.0
2.3 depends_on
在使用 Compose 时,最大的好处就是少打启动命令,但是一般项目容器启动的顺序是有要求的,如果直接从上到下启动容器,必然会因为容器依赖问题而启动失败。
例如在没启动数据库容器的时候启动了应用容器,这时候应用容器会因为找不到数据库而退出,为了避免这种情况我们需要加入一个标签,就是 depends_on,这个标签解决了容器的依赖、启动先后的问题。
比如我要先启动一个MySQL,后启动nginx,那么
version: '3'
services:
nginx:
image: nginx:1.16.1
depends_on:
- mysql
mysql:
image: mysql:8.0
2.4 environment
这是设置镜像的环境变量,直接将变量定义到镜像里面,这样启动容器时会自动读取该环境变量
如启动一个MySQL容器,要设置它的root初始化密码为“123456”,那
version: '3'
services:
mysql:
image: mysql:8.0
environment:
MYSQL_ROOT_PASSWORD: 123456
2.5 ports
该参数是将宿主机的端口映射到容器端口,从而在宿主机访问对应的端口能访问到容器内。
如要讲MySQL容器的3306端口映射到宿主机的33060端口,那
version: '3'
services:
mysql:
image: mysql:8.0
ports:
- “33060:3306”
2.6 volumes
挂载一个目录或者一个已存在的数据卷容器,可以直接使用 [HOST:CONTAINER] 这样的格式,或者使用 [HOST:CONTAINER:ro] 这样的格式,后者对于容器来说,数据卷是只读的,这样可以有效保护宿主机的文件系统。
Compose的数据卷指定路径可以是相对路径,使用 . 或者
.. 来指定相对目录。
version: '3'
services:
mysql:
image: mysql:8.0
volumes:
-
./data:/var/lib/mysql
-
/var/log/mysql:/var/log/mysql
3. 安装docker-compose
选择对应版本下载安装包
https://github.com/docker/compose/releases?after=1.28.0
上传到服务器修改名称并授权
mv docker-compose-x86 docker-compose
chmod +x docker-compose
测试
./docker-compose –v
安装
mv docker-compose /usr/bin
4. 编写zabbix监控系统的docker-compose.yaml文件
version: '3.7'
services:
mysql:
container_name: mysql
image: mysql:latest
restart: always
environment:
MYSQL_DATABASE: zabbix
MYSQL_ROOT_PASSWORD: zabbix@2022
ports:
- "3306:3306"
volumes:
- /data/mysql:/var/lib/mysql
zabbix-server:
container_name: zabbix_server
image: zabbix/zabbix-server-mysql:latest
restart: always
depends_on:
- mysql
environment:
MYSQL_DATABASE: zabbix
MYSQL_PASSWORD: zabbix@2022
MYSQL_USER: root
DB_SERVER_HOST: 192.168.75.31
DB_SERVER_PORT: 3306
ports:
- "10051:10051"
volumes:
- /data/zabbix/alertscripts:/usr/lib/zabbix/alertscripts
- /data/zabbix/externalscripts:/usr/lib/zabbix/externalscripts
zabbix-web:
container_name: zabbix_web
image: zabbix/zabbix-web-nginx-mysql:latest
restart: always
depends_on:
- mysql
- zabbix_server
environment:
MYSQL_DATABASE: zabbix
MYSQL_PASSWORD: zabbix@2022
MYSQL_USER: root
DB_SERVER_HOST: 192.168.75.31
DB_SERVER_PORT: 3306
ZBX_SERVER_HOST: 192.168.75.31
ZBX_SERVER_PORT: 10051
ports:
- "8080:8080"
zabbix-agent:
container_name: zabbix_agent
image: zabbix/zabbix-agent:latest
restart: always
depends_on:
- mysql
- zabbix_server
environment:
ZBX_HOSTNAME: 192.168.75.31
ZBX_SERVER_HOST: 172.18.0.1
ports:
- "10050:10050"
5. 启动zabbix监控系统
别忘了安装docker!
编写好zabbix监控系统的docker-compose.yaml文件后,就可以启动系统了
Docker-compose up –d
如图所示,已成功启动
6. 验证监控系统
我这边web端口映射为宿主机的18080,所以访问zabbix界面,那就是IP+18080
默认的账号密码:
Admin
zabbix
如图,成功访问。
这一期的Zabbix技术内容到这就结束了。我是乐维IT君,专注运维技术分享,更多Zabbix技术及其他运维内容,还可以查看我的往期内容,zabbix服务,zabbix配置,zabbix部署等zabbix服务解决方案。
Zabbix技术分享——使用docker-compose快速部署zabbix监控系统的更多相关文章
- 使用 Docker Compose 快速构建 TiDB 集群
本文档介绍如何在单机上通过 Docker Compose 快速一键部署一套 TiDB 测试集群.Docker Compose 可以通过一个 YAML 文件定义多个容器的应用服务,然后一键启动或停止. ...
- Docker Compose 一键部署LNMP
Docker Compose 一键部署LNMP 目录结构 [root@localhost ~]# tree compose_lnmp/ compose_lnmp/ ├── docker-compose ...
- Docker Compose 一键部署Nginx代理Tomcat集群
Docker Compose 一键部署Nginx代理Tomcat集群 目录结构 [root@localhost ~]# tree compose_nginx_tomcat/ compose_nginx ...
- Docker Compose 一键部署多节点爬虫程序
Docker Compose 一键部署多节点爬虫程序 目录结构 [root@localhost ~]# tree compose_crawler/ compose_crawler/ ├── cento ...
- 用Docker swarm快速部署Nebula Graph集群
用Docker swarm快速部署Nebula Graph集群 一.前言 本文介绍如何使用 Docker Swarm 来部署 Nebula Graph 集群. 二.nebula集群搭建 2.1 环境准 ...
- 微信团队原创分享:iOS版微信的内存监控系统技术实践
本文来自微信开发团队yangyang的技术分享. 一.前言 FOOM(Foreground Out Of Memory),是指App在前台因消耗内存过多引起系统强杀.对用户而言,表现跟crash一样. ...
- CentOS 7.4 下安装部署Nagios监控系统详细攻略(三)
Nagios是一个流行的电脑系统和网络监控程序,它检测主机和服务,当异常发生和解除时能提醒用户.它是基于GPLv2开发的开源软件,可免费获得及使用. nagios工作原理 nagios的功能是监控服务 ...
- Telegraf+InfluxDB+Grafana快速搭建实时监控系统 监控postgresql
Telegraf+InfluxDB+Grafana快速搭建实时监控系统 监控postgresql
- Docker Compose安装部署Jenkins
流水线可以让项目发布流程更加清晰,docker可以大大减少Jenkins配置. 1.前言 数据卷挂载到 /var 磁盘目录下,因为该磁盘空间较大,后面需要挂载容器数据卷,以防内存吃紧. 为了可以留存启 ...
- docker swarm快速部署redis分布式集群
环境准备 四台虚拟机 192.168.2.38(管理节点) 192.168.2.81(工作节点) 192.168.2.100(工作节点) 192.168.2.102(工作节点) 时间同步 每台机器都执 ...
随机推荐
- PHP函数小工具
PHP检测IP是否内网地址.保留地址 /** * @param string $ip 被检测的IP * @return bool 是否内网或者保留IP */ public function isInt ...
- Elasticsearch:ICU分词器介绍
ICU Analysis插件是一组将Lucene ICU模块集成到Elasticsearch中的库. 本质上,ICU的目的是增加对Unicode和全球化的支持,以提供对亚洲语言更好的文本分割分析. 从 ...
- CentOS7.x安装VNC
VNC需要系统安装的有桌面,如果是生产环境服务器,安装时使用的最小化安装,那么进行下面操作安装GNOME 桌面. # 列出的组列表里有GNOME Desktop. yum grouplist #安装 ...
- C++自学笔记 Composition:对象组合
继承是实现软件重用的一种方式. 在C++中拥有另一种实现软件重用的方式----- Composition:对象组合 用已经有的对象制造新的对象 (设计一个类的时候它的成员变量可以是另一个类的对象) 对 ...
- 如何0到1构建DevOps?
从0到1构建DevOps,首先得弄清楚这个DevOps的受众群体,它的用途到底是什么,解决什么问题,比如Android Studio是为了解决Android应用的开发,3UCS xPlus是为了解决应 ...
- [题解] BZOJ 3456 洛谷 P4841 [集训队作业2013]城市规划 多项式,分治FFT
题目 令\(f_i\)表示n个点的答案.考虑容斥,用所有连边方案减去有多个连通块的方案.枚举1号点所在的连通块大小: \(f_i=2^{i(i-1)/2}-\sum_{j>0}^{i-1}f_j ...
- @input含义和用法
@input :一般用于监听事件只要输入的值变化了就会触发input 示例: <div id="div1"> <input type="text&quo ...
- github使用Webhooks实现自动化部署
参考: https://blog.csdn.net/u013764814/article/details/85240752 -------------------------------------- ...
- 知识图谱-生物信息学-医学顶刊论文(Bioinformatics-2021)-SumGNN:通过有效的KG聚集进行多类型DDI预测
3.(2021.3.26)Bioinformatics-SumGNN:通过有效的KG聚集进行多类型DDI预测 论文标题: SumGNN: multi-typed drug interaction pr ...
- 十一、Pod的健康检查-探针
Pod 的健康检查-探针 一.Pod 的健康检查-探针 1.1.探针基本概念 探针是由 kubelet 对容器执行的定期诊断.要执行诊断,kubelet 调用由容器实现的 Handler 有三种类型 ...