使用docker搭建zabbix环境

一、下载mysql,这里下载mysql:5.7,

docker image pull mysql:5.7

 

二、下载zabbix-server镜像,zabbix-server镜像有两种,一种是支持PostgreSQL,一种是支持mysql的。这里安装的是基于mysql的。

使用如下命令看一下zabbix-server官方的镜像。

docker search zabbix-server

我们选择第一个,zabbix-server-mysql。

使用如下命令将镜像pull下来,

docker image pull zabbix/zabbix-server-mysql

三、接下来下载 zabbix web镜像。

使用如下命令查看一下zabbix web都有哪些镜像,

docker search zabbix-web

看到有nginx的,也有基于apache的,这里选择基于nginx的。

下载镜像,

docker image pull zabbix/zabbix-web-nginx-mysql

 

四、下载 zabbix-java-gateway 镜像。zabbix本身不支持直接监控java,但可以使用 zabbix-java-gateway 监控 jvm/tomcat 的性能。

先查找一下,

docker search zabbix-java

下载第一个镜像,

docker image pull zabbix/zabbix-java-gateway

五、创建docker网络,将zabbix-server,mysql,web等容器都加入到这个网络中,方便互相通信。

使用如下命令创建,

docker network create -d bridge zabbix-test-net

六、将镜像分别放入容器运行起来,

1、使用mysql镜像创建mysql容器,并运行,

docker container run -idt -p 1111:3306 --name zabbix-mysql --network zabbix_test_net --restart always -v /etc/localtime:/etc/localtime -e MYSQL_DATABASE="zabbix" -e MYSQL_USER="zabbix" -e MYSQL_PASSWORD="zabbix" -e MYSQL_ROOT_PASSWORD="123456a" mysql:5.7

参数解释,

-p 1111:3306,将容器的3306端口映射到宿主机的1111端口,

--network zabbix_test_net ,是将容器加入到zabbix_test_net 这个网络中,

-v /etc/localtime:/etc/localtime ,是将容器中的/etc/localtime文件,挂载到宿主机的/etc/localtime上。作用是为了同步时区信息。

--restart always,设置自动启动。

-e MYSQL_DATABASE="zabbix" ,创建环境变量

 

2、使用zabbix-java-gateway 镜像,创建 zabbix-java-gateway 容器。

docker container run -v /etc/localtime:/etc/localtime -idt --restart=always --name=zabbix-java-gateway --network zabbix_test_net zabbix/zabbix-java-gateway

3、使用 zabbix-server-mysql 镜像,创建 zabbix-server-mysql 容器。

首先创建挂载数据的数据卷,

docker volume create zabbix-server-volume

然后创建并运行zabbix-server-mysql 容器,

docker run -idt -p 2222:10051 -v zabbix-server-volume:/etc/zabbix -v /etc/localtime:/etc/localtime -v /usr/lib/zabbix/alertscripts:/usr/lib/zabbix/alertscripts --name=zabbix-server-mysql --restart=always --network=zabbix_test_net -e DB_SERVER_HOST="zabbix-mysql" -e MYSQL_DATABASE="zabbix" -e MYSQL_USER="zabbix" -e MYSQL_PASSWORD="zabbix" -e MYSQL_ROOT_PASSWORD="123456a" -e ZBX_JAVAGATEWAY="zabbix-java-gateway" zabbix/zabbix-server-mysql

 

4、使用 zabbix-web-nginx 镜像,创建 zabbix-web-nginx 容器。

使用如下命令,

docker container run -idt -p 3333:80 -v /etc/localtime:/etc/localtime --name zabbix-web-nginx-mysql --restart=always --network=zabbix_test_net -e DB_SERVER_HOST="zabbix-mysql" -e MYSQL_DATABASE="zabbix" -e MYSQL_USER="zabbix" -e MYSQL_PASSWORD="zabbix" -e MYSQL_ROOT_PASSWORD="123456a" -e ZBX_SERVER_HOST="zabbix-server-mysql" zabbix/zabbix-web-nginx-mysql

 

至此,zabbix所需的容器已经全部启动,可以通过 docker ps 查看容器状态,如下,

5、浏览器输入 http://ip:port/zabbix,

默认用户名密码是 admin/zabbix,

 

  • 5
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
好的,我可以为您提供关于如何使用docker部署zabbix分离架构的指导。 首先,您需要了解Zabbix分离架构的基本概念。在此架构中,Zabbix服务器和Zabbix数据库以及Zabbix前端是分离的。Zabbix服务器负责收集和处理监控数据,而Zabbix数据库存储监控数据和配置信息,Zabbix前端用于展示监控数据和管理Zabbix系统。 接下来,您需要安装DockerDocker Compose。Docker是一种容器化技术,可以将应用程序和依赖项封装在容器中,从而实现跨平台的部署。Docker Compose是一个工具,可以使用YAML文件定义和运行多个Docker容器。 然后,您需要创建一个Docker Compose文件,定义Zabbix服务器,Zabbix数据库和Zabbix前端的容器。以下是一个示例Docker Compose文件: ``` version: '3' services: db: image: mysql:5.7 volumes: - ./data/mysql:/var/lib/mysql environment: MYSQL_ROOT_PASSWORD: your_password MYSQL_DATABASE: zabbix MYSQL_USER: zabbix MYSQL_PASSWORD: zabbix_password server: image: zabbix/zabbix-server-mysql:latest ports: - "10051:10051" environment: DB_SERVER_HOST: db MYSQL_USER: zabbix MYSQL_PASSWORD: zabbix_password MYSQL_DATABASE: zabbix web: image: zabbix/zabbix-web-nginx-mysql:latest ports: - "8080:80" environment: DB_SERVER_HOST: db MYSQL_USER: zabbix MYSQL_PASSWORD: zabbix_password MYSQL_DATABASE: zabbix ``` 在这个例子中,我们定义了三个服务:db,server和web。db服务使用mysql:5.7镜像创建一个MySQL数据库容器,并将数据卷挂载到./data/mysql目录。server服务使用zabbix/zabbix-server-mysql:latest镜像创建一个Zabbix服务器容器,并将端口10051映射到主机上。web服务使用zabbix/zabbix-web-nginx-mysql:latest镜像创建一个Zabbix前端容器,并将端口8080映射到主机上。 最后,您可以使用以下命令启动容器: ``` docker-compose up -d ``` 这将在后台启动所有容器。现在,您可以通过访问http://localhost:8080来访问Zabbix前端,并使用默认的用户名和密码(Admin/zabbix)登录。 希望这些信息能够帮助您成功部署Zabbix分离架构。如果您有任何进一步的问题,请随时询问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值