一 部署docker环境
关闭防火墙、selinux、开启docker,并设置开机自启动
注意点:docker部署的时候,bip要指定,不然会导致虚拟机ip和容器ip冲突,ssh连不上虚拟机
部署请参考 docker (二)-yum&二进制部署-CSDN博客
二 docker-compose的安装----github下载
curl -SL https://github.com/docker/compose/releases/download/v2.20.2/docker-compose-linux-x86_64 -o /usr/local/bin/docker-compose
chmod +x /usr/local/bin/docker-compose##测试
docker-compose version
三 编写docker-compose.yml文件
##yml文件,缩进表示层级关系##指定版本号
version: '3'##配置服务
services:
##容器1zabbix-web-nginx-mysql:
##镜像:从中拉取镜像image: zabbix/zabbix-web-nginx-mysql:centos-5.2-latestrestart: alwaysenvironment:- DB_SERVER_HOST=zabbix-mysql- MYSQL_DATABASE=zabbix- MYSQL_USER=zabbix- MYSQL_PASSWORD=zabbix- MYSQL_ROOT_PASSWORD=123qwe- ZBX_SERVER_HOST=zabbix-server-mysqlports:
##端口映射 主机:容器- 8080:8080volumes:- /etc/localtime:/etc/localtime- /data2/zabbix/fonts/DejaVuSans.ttf:/usr/share/zabbix/assets/fonts/DejaVuSans.ttfnetworks:- zbx_netdepends_on:- zabbix-server-mysql- zabbix-mysql
##容器2zabbix-mysql:image: mysql:8.0.23restart: alwaysports:- 3306:3306environment:- MYSQL_DATABASE=zabbix- MYSQL_USER=zabbix- MYSQL_PASSWORD=zabbix- MYSQL_ROOT_PASSWORD=123qwe
##容器启动的默认命令command:- mysqld- --default-authentication-plugin=mysql_native_password- --character-set-server=utf8- --collation-server=utf8_binvolumes:
##将容器中的数据或文件挂载到主机上,实现数据的持久化- /etc/localtime:/etc/localtime- /data2/zabbix/db:/var/lib/mysqlnetworks:- zbx_net
##容器3zabbix-java-gateway:image: zabbix/zabbix-java-gateway:centos-5.2-latestrestart: alwaysvolumes:- /etc/localtime:/etc/localtimenetworks:- zbx_net
##容器4zabbix-server-mysql:image: zabbix/zabbix-server-mysql:centos-5.2-latestrestart: alwaysvolumes:- /data/zabbix/zabbix-server:/etc/zabbix- /data2/zabbix/alertscripts:/usr/lib/zabbix/alertscripts- /etc/localtime:/etc/localtimeports:- 10052:10051environment:- DB_SERVER_HOST=zabbix-mysql- MYSQL_DATABASE=zabbix- MYSQL_USER=zabbix- MYSQL_PASSWORD=zabbix- MYSQL_ROOT_PASSWORD=123qwe- ZBX_JAVAGATEWAY=zabbix-java-gateway- ZBX_JAVAGATEWAY_ENABLE=true- ZBX_JAVAGATEWAYPORT=10052depends_on:- zabbix-mysqlnetworks:- zbx_net
##容器5zabbix-agent:image: zabbix/zabbix-agent:centos-5.2-latestrestart: alwaysports:- 10050:10050environment:- ZBX_HOSTNAME=Zabbix server- ZBX_SERVER_HOST=zabbix-server-mysql- ZBX_SERVER_PORT=10051networks:- zbx_net##网络
networks:
##网络名zbx_net:
##指定驱动用于这个网络driver: bridge
创建相应映射目录
/data2/zabbix/zabbix-server 用于存储 Zabbix 服务器容器的配置文件等相关数据
/data2/zabbix/alertscripts 用于存储 Zabbix 服务器容器中的告警脚本
/data2/zabbix/fonts 用于存储 Zabbix Web 容器中的字体文件
/data2/zabbix/db 用于存储 MySQL 数据库容器的数据文件
中文简体文件添加
从主机(C:\Windows\Fonts)上传一个.ttf的字体文件到/data2/zabbix/fonts目录
可使用rz命令,或者ftp,或远程传输工具(如:xftp)
并将文件名称改成DejaVuSans.ttf(yml文件中有指明)
四 一键启动(注:在docker-compose.yml文件目录下启动)
docker-compose up -d # -d 后台运行
检验 在浏览器输入ip地址和映射的端口号(192.168.10.131:8080)即可到web界面,则安装完成 (Admin--zabbix)
五 出现报错
docker ps 看到 docker-zabbix-server-mysql-1 起来后就挂了,docker logs 查看日志发现
**** Configuration file '/etc/zabbix/zabbix_server.conf' does not exist
zabbix_server [7]: cannot open config file "/etc/zabbix/zabbix_server.conf": [2] No such file or directory
解决思路
-
确保主机上的
/data/zabbix/zabbix-server
目录中包含正确的 Zabbix Server 配置文件。 -
确保 Zabbix Server 容器具有正确的权限访问挂载的卷。你可以通过检查挂载点的权限来确保容器有权限访问挂载的卷。
-
如果配置文件位于主机上的其他位置,请确保在
docker-compose.yml
文件中正确指定了挂载的卷路径。 -
如果 Zabbix Server 镜像默认配置文件的路径不是
/etc/zabbix/zabbix_server.conf
,你需要确保在容器内正确的路径上存在该配置文件,或者在容器启动时指定正确的配置文件路径
解决步骤
1.将容器4中这行删掉,后直接docker-compose up -d
这样启动容器就没有报错,但是配置文件未持久化(若要持久化按以下步骤做)
2.拷贝配置文件
mkdir -p /data/zabbix/zabbix-server
docker cp docker-zabbix-server-mysql-1:/etc/zabbix/zabbix_server.conf /data/zabbix/zabbix-server
3.再按照 三中的 docker-compose.yml 启动容器
启动后,没有报错
总结:使用volumes进行配置文件持久化,要保证宿主机的目录中包含对应的配置文件
六 docker-compose常用命令
以下是一些常用的 Docker Compose 相关命令:
1. docker-compose up:
- 启动 Docker Compose 定义的所有服务。
- 如果需要构建镜像,它将会构建镜像。
- 如果服务已经运行,则会尝试重新启动服务。
2. docker-compose down:
- 停止并删除所有 Docker Compose 定义的服务。
- 如果指定
--volumes
参数,则还会删除相关的数据卷。
3. docker-compose build:
- 构建 Docker Compose 定义的所有服务的镜像。
- 如果只需要构建特定服务的镜像,可以使用
docker-compose build <service_name>
。
4. docker-compose start:
- 启动 Docker Compose 定义的所有服务。
- 如果服务已经启动,则不会执行任何操作。
5. docker-compose stop:
- 停止 Docker Compose 定义的所有服务。
- 如果服务已经停止,则不会执行任何操作。
6. docker-compose restart:
- 重启 Docker Compose 定义的所有服务。
- 如果服务未启动,则会启动服务。
7. docker-compose ps:
- 显示 Docker Compose 定义的所有服务的状态。
- 包括服务名称、状态、端口映射等信息。
8. docker-compose logs:
- 显示 Docker Compose 定义的所有服务的日志输出。
- 可以通过
-f
参数实时查看日志。