大家好,又见面了,我是你们的朋友全栈君。
概述
- zabbix在docker官方的镜像源中,有维护zabbix公司官方的镜像,我们可以通过hub.docker.com进行下载,搭建docker环境下的zabbix,可以使我们的安装和部署更加快捷。
zabbix的docker镜像源
- 从这里 zabbix docker镜像源 我们可以打开看到zabbix官方在docker仓库里面维护的镜像源信息。
mysql数据库部署
- 在部署zabbix服务器前,需要提前部署mysql服务器并且创建好zabbix数据库以及用户
拉取mysql镜像
代码语言:javascript复制docker pull mysql
运行mysql服务器
代码语言:javascript复制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
拉取镜像
代码语言:javascript复制docker pull zabbix/zabbix-server-mysql
获取mysql服务器地址
代码语言:javascript复制docker inspect zabbix-database|grep IPAddress
运行zabbix-server容器
代码语言:javascript复制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作为前端控制台
拉取镜像
代码语言:javascript复制docker pull zabbix/zabbix-web-nginx-mysql
运行zabbix-front容器
代码语言:javascript复制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