大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。
Jetbrains全家桶1年46,售后保障稳定
概述
- zabbix在docker官方的镜像源中,有维护zabbix公司官方的镜像,我们可以通过hub.docker.com进行下载,搭建docker环境下的zabbix,可以使我们的安装和部署更加快捷。
zabbix的docker镜像源
- 从这里 zabbix docker镜像源 我们可以打开看到zabbix官方在docker仓库里面维护的镜像源信息。
mysql数据库部署
- 在部署zabbix服务器前,需要提前部署mysql服务器并且创建好zabbix数据库以及用户
拉取mysql镜像
docker pull mysql
运行mysql服务器
docker run -itd --name zabbix-database -p 3306:3306 -e MYSQL_ROOT_PASSWORD=password mysql
- 上述命令将创建一个名为zabbix-database,并且把3306端口映射到docker主机的3306,设置mysql的root用户密码为password
创建zabbix用户和数据库
- 进入docker容器
docker exec -it zabbix-database /bin/bash
- 登录数据库
mysql -ppassword
- 创建zabbix数据库
create database zabbix character set utf8 collate utf8_bin;
- 创建zabbix用户
create user 'zabbix'@'localhost' identified WITH mysql_native_password by 'password'; create user 'zabbix'@'%' identified WITH mysql_native_password by 'password';
- zabbix用户授权
grant all privileges on zabbix.* to 'zabbix'@'localhost'; grant all privileges on zabbix.* to 'zabbix'@'%';
FLUSH PRIVILEGES;
- 复制mysql初始化数据库文件到容器
docker cp mysql.tar.gz zabbix-database:/tmp
- 导入zabbix初始化数据,初始化数据文件可以从zabbix的官方进行下载
tar -xvf /tmp/mysql.tar.gz
mysql -uzabbix -ppassword zabbix < /tmp/mysql/schema.sql
mysql -uzabbix -ppassword zabbix < /tmp/mysql/images.sql
mysql -uzabbix -ppassword zabbix < /tmp/mysql/data.sql
zabbix服务器部署
- 这里我们选择使用以mysql作为后端存储的zabbix-server
拉取镜像
docker pull zabbix/zabbix-server-mysql
获取mysql服务器地址
docker inspect zabbix-database|grep IPAddress
运行zabbix-server容器
docker run --name zabbix-server -e DB_SERVER_HOST="172.17.0.2" -e MYSQL_USER="zabbix" -e MYSQL_PASSWORD="password" -d zabbix/zabbix-server-mysql
zabbix-front服务器部署
- 这里我们选择以 nginx+php作为前端控制台
拉取镜像
docker pull zabbix/zabbix-web-nginx-mysql
运行zabbix-front容器
docker run --name zabbix-web -p 8080:8080 --link zabbix-database:zabbix-database --link zabbix-server:zabbix-server -e DB_SERVER_HOST="zabbix-database" -e MYSQL_USER="zabbix" -e MYSQL_PASSWORD="password" -e ZBX_SERVER_HOST="zabbix-server" -e PHP_TZ="Asia/Shanghai" -d zabbix/zabbix-web-nginx-mysql
- –link 可以连接到docker环境下的对应名称的主机,前提这个主机容器必须存在
- DB_SERVER_HOST 为数据库服务器地址,可以使用docker inspect进行查看
- MYSQL_USER 连接数据库的用户名
- MYSQL_PASSWORD 连接数据库的密码
- ZBX_SERVER_HOST zabbix服务器,主要用于确认zabbix是否存活
- PHP_TZ 时区配置
- -p 将8080端口映射到本地主机的8080
效果验证
- 打开docker服务器的8080端口,我们可以看到zabbix的服务器已经开始运行了并且可以访问。
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/219173.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...