一 部署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:
##容器1
zabbix-web-nginx-mysql:
##镜像:从中拉取镜像
image: zabbix/zabbix-web-nginx-mysql:centos-5.2-latest
restart: always
environment:
- DB_SERVER_HOST=zabbix-mysql
- MYSQL_DATABASE=zabbix
- MYSQL_USER=zabbix
- MYSQL_PASSWORD=zabbix
- MYSQL_ROOT_PASSWORD=123qwe
- ZBX_SERVER_HOST=zabbix-server-mysql
ports:
##端口映射 主机:容器
- 8080:8080
volumes:
- /etc/localtime:/etc/localtime
- /data2/zabbix/fonts/DejaVuSans.ttf:/usr/share/zabbix/assets/fonts/DejaVuSans.ttf
networks:
- zbx_net
depends_on:
- zabbix-server-mysql
- zabbix-mysql
##容器2
zabbix-mysql:
image: mysql:8.0.23
restart: always
ports:
- 3306:3306
environment:
- 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_bin
volumes:
##将容器中的数据或文件挂载到主机上,实现数据的持久化
- /etc/localtime:/etc/localtime
- /data2/zabbix/db:/var/lib/mysql
networks:
- zbx_net
##容器3
zabbix-java-gateway:
image: zabbix/zabbix-java-gateway:centos-5.2-latest
restart: always
volumes:
- /etc/localtime:/etc/localtime
networks:
- zbx_net
##容器4
zabbix-server-mysql:
image: zabbix/zabbix-server-mysql:centos-5.2-latest
restart: always
volumes:
- /data/zabbix/zabbix-server:/etc/zabbix
- /data2/zabbix/alertscripts:/usr/lib/zabbix/alertscripts
- /etc/localtime:/etc/localtime
ports:
- 10052:10051
environment:
- 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=10052
depends_on:
- zabbix-mysql
networks:
- zbx_net
##容器5
zabbix-agent:
image: zabbix/zabbix-agent:centos-5.2-latest
restart: always
ports:
- 10050:10050
environment:
- ZBX_HOSTNAME=Zabbix server
- ZBX_SERVER_HOST=zabbix-server-mysql
- ZBX_SERVER_PORT=10051
networks:
- 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
参数实时查看日志。