docker环境下部署web_docker环境部署

2022-11-17 15:22:24 浏览数 (1)

大家好,又见面了,我是你们的朋友全栈君。

概述

  • 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容器
代码语言:javascript复制
docker exec -it  zabbix-database /bin/bash
  • 登录数据库
代码语言:javascript复制
mysql -ppassword
  • 创建zabbix数据库
代码语言:javascript复制
create database zabbix character set utf8 collate utf8_bin;
  • 创建zabbix用户
代码语言:javascript复制
create user 'zabbix'@'localhost' identified WITH mysql_native_password by 'password'; create user 'zabbix'@'%' identified WITH mysql_native_password by 'password';
  • zabbix用户授权
代码语言:javascript复制
 grant all privileges on zabbix.* to 'zabbix'@'localhost'; grant all privileges on zabbix.* to 'zabbix'@'%';
 FLUSH PRIVILEGES;
  • 复制mysql初始化数据库文件到容器
代码语言:javascript复制
docker cp mysql.tar.gz zabbix-database:/tmp
  • 导入zabbix初始化数据,初始化数据文件可以从zabbix的官方进行下载
代码语言:javascript复制
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

0 人点赞