Docker部署zabbix监控系统

zabbix监控端 监控四件套

mysql-server

zabbix-java-gateway

zabbix-server-mysql

zabbix-web-nginx-mysql

zabbix-agent

我这里采用6.0.21版本

server端操作拉取镜像

docker pull mysql:8.0
docker pull zabbix/zabbix-java-gateway:alpine-6.0-latest
docker pull zabbix/zabbix-server-mysql:alpine-6.0-latest
docker pull zabbix/zabbix-web-nginx-mysql:alpine-6.0-latest
docker pull zabbix/zabbix-agent:alpine-6.0-latest

创建容器挂载卷

docker volume create -d local  mysql_data
docker volume create -d local  mysql_logs 
docker volume create -d local  mysql_conf 
docker volume create -d local  zabbix_server
docker volume create -d local  zabbix_agent

创建zabbix容器专属网络 

docker network create --subnet 172.20.0.0/16 --ip-range 172.20.240.0/20 zabbix-net

创建MySQL容器存储数据

docker run --name mysql-server -t \
      -v mysql_data:/var/lib/mysql \
      -v mysql_logs:/var/log/mysql \
      -v mysql_conf:/etc/mysql \
      -e MYSQL_DATABASE="zabbix" \
      -e MYSQL_USER="zabbix" \
      -e MYSQL_PASSWORD="password" \
      -e MYSQL_ROOT_PASSWORD="password" \
	  --network=zabbix-net \
      --restart=unless-stopped \
      -d mysql:8.0 \
      --character-set-server=utf8 --collation-server=utf8_bin \
      --default-authentication-plugin=caching_sha2_password

注释#

-v 均为挂载卷 映射出容器的数据到本地

-e MYSQL_DATABASE="zabbix"         ##数据库名
-e MYSQL_USER="zabbix"                  ##zabbix用户名
-e MYSQL_PASSWORD="password"        #zabbix用户密码 
-e MYSQL_ROOT_PASSWORD="password"         #root用户密码 
--network=zabbix-net                                 #使用创建的zabbix专用网络
--restart=unless-stopped                         #当容器在关闭时重启docker不会重新启动容器

--character-set-server=utf8 --collation-server=utf8_bin  ###数据库字符集
--default-authentication-plugin=caching_sha2_password         ##加密方式推荐使用这种话,官方文档的加密过时了,会一直警告

查看容器状态 出现up即为成功

docker ps | grep mysql-server

创建 zabbix-java-gateway 容器

docker run --name zabbix-java-gateway -t \
	--network=zabbix-net \
	--restart=unless-stopped \
	-d zabbix/zabbix-java-gateway:alpine-6.0-latest

一样查看已经状态up状态即可

docker ps  |grep zabbix-java-gateway

创建zabbix-server-mysql

docker run --name zabbix-server-mysql -t \
      -v zabbix_server:/etc/zabbix \
      -e DB_SERVER_HOST="mysql-server" \
      -e MYSQL_DATABASE="zabbix" \
      -e MYSQL_USER="zabbix" \
      -e MYSQL_PASSWORD="password" \
      -e MYSQL_ROOT_PASSWORD="password" \
      -e ZBX_JAVAGATEWAY="zabbix-java-gateway" \
	  -p 10051:10051 \
	  --network=zabbix-net \
      --restart=unless-stopped \
      -d zabbix/zabbix-server-mysql:alpine-6.0-latest

查看一下日志  出现Updating就是在导入数据了 

docker logs -f zabbix-server-mysql

创建zabbix-web-nginx-mysql

docker run --name zabbix-web-nginx-mysql -t \
   -e PHP_TZ="Asia/Shanghai" \
   -e ZBX_SERVER_HOST="zabbix-server-mysql" \
      -e DB_SERVER_HOST="mysql-server" \
      -e MYSQL_DATABASE="zabbix" \
      -e MYSQL_USER="zabbix" \
      -e MYSQL_PASSWORD="password" \
      -e MYSQL_ROOT_PASSWORD="password" \
      -p 7777:8080 \
	  --network=zabbix-net \
      --restart unless-stopped \
      -d zabbix/zabbix-web-nginx-mysql:alpine-6.0-latest

注释

这里的-p 7777:8080 是映射端口 我这里用宿主机IP:7777 访问  你们也可以 -p 80:8080  直接使用IP访问

浏览器打开ip:7777

默认账号密码为 Admin   zabbix

到此zabbix-server监控端就部署完毕

汉化面板

 

汉化就完事了 

在server监控端部署node

docker run --name zabbix-agent -t \
-v zabbix_agent:/etc/zabbix \
-e ZBX_HOSTNAME="master" \
-e ZBX_SERVER_HOST="172.20.240.3" \
-e ZBX_SERVER_PORT=10051 -p 10050:10050 \
--network host \
--restart=unless-stopped  \
--privileged \
-d zabbix/zabbix-agent:alpine-6.0-latest

注意在server端部署的node 需要把 -e ZBX_SERVER_HOST="172.20.240.3"  里面的ip写zabbix-server-mysql容器ip

docker inspect  zabbix-server-mysql  | grep "IPAddress"

然后添加主机即可

被监控端部署node节点

node被监控端服务器

首先创建挂载卷

docker volume create -d local  zabbix_agent

 拉取镜像

docker pull zabbix/zabbix-agent:alpine-6.0-latest
docker run --name zabbix-agent -t \
-v zabbix_agent:/etc/zabbix \
-e ZBX_HOSTNAME="master" \
-e ZBX_SERVER_HOST="zabbix-server主机IP" \
-e ZBX_SERVER_PORT=10051 \
-p 10050:10050 \
--network host \
--restart=unless-stopped  \
--privileged \
-d zabbix/zabbix-agent:alpine-6.0-latest

添加主机 填写node节点的IP即可

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Docker是一种容器化技术,可以方便地部署和管理应用程序。Zabbix是一种流行的开源监控系统,可以监控服务器、网络设备和应用程序等。在Docker部署Zabbix监控集群可以提高系统的可靠性和可扩展性。 要部署Zabbix监控集群,需要先创建一个Docker镜像,其中包含Zabbix Server和Zabbix Agent。可以使用Dockerfile文件来定义镜像的构建过程。然后,可以使用Docker Compose来定义和管理多个容器部署和运行。 在Docker Compose文件中,需要定义Zabbix Server和Zabbix Agent的容器,并指定它们的网络配置和环境变量。可以使用Docker Swarm来管理多个Docker节点,以实现高可用性和负载均衡。 最后,可以使用Zabbix Web界面来配置和管理监控项、触发器和报警等。通过Docker部署Zabbix监控集群,可以简化部署和管理过程,提高系统的可靠性和可扩展性。 ### 回答2: DockerZabbix都是开源软件,可在各种操作系统上部署和使用。Docker可以帮助我们简化部署和管理多个容器的过程,而Zabbix则是一种开源监控解决方案,能够对各种设备和应用程序进行监控、报警和分析。在Docker中,我们可以利用容器部署Zabbix监控集群,达到扩展和分布式监控的目的。 1. 首先,我们需要安装DockerDocker Compose。安装完成后,我们可以创建一个新的Zabbix监控服务的Docker镜像。为此,我们可以使用类似以下命令的Dockerfile: FROM zabbix/zabbix-server-pgsql:alpine-3.2-latest # Install additional packages RUN apk add --update \ supervisor \ nginx \ php7-fpm \ php7-json \ php7-mysqli \ php7-session \ php7-simplexml \ php7-xml \ php7-xmlrpc \ && rm -rf /var/cache/apk/* # Configure services COPY nginx.conf /etc/nginx/nginx.conf COPY supervisord.conf /etc/supervisor/conf.d/supervisord.conf COPY php-fpm.ini /etc/php7/php-fpm.d/www.conf RUN ln -sf /dev/stdout /var/log/nginx/access.log \ && ln -sf /dev/stderr /var/log/nginx/error.log COPY entrypoint.sh / EXPOSE 80 EXPOSE 10051/TCP ENTRYPOINT ["/entrypoint.sh"] CMD ["nginx", "-g", "daemon off;"] 其中entrypoint.sh是一个脚本,用于检查是否已经创建数据库和zabbix配置文件,并自动执行启动脚本。该脚本如下: #!/bin/sh set -e if [ ! -d "/var/lib/zabbix/alertscripts" ]; then mkdir -p /var/lib/zabbix/alertscripts cp /usr/share/zabbix/alertscripts/* /var/lib/zabbix/alertscripts/ -r chown -R zabbix.zabbix /var/lib/zabbix/alertscripts fi if [ ! -d "/var/lib/zabbix/modules" ]; then mkdir -p /var/lib/zabbix/modules chown -R zabbix.zabbix /var/lib/zabbix/modules fi if [ ! -d "/etc/zabbix/web" ]; then mkdir -p /etc/zabbix/web cp /usr/share/zabbix/conf/* /etc/zabbix/web/ chown -R zabbix.zabbix /etc/zabbix/web fi if [ ! -f "/etc/zabbix/zabbix_server.conf" ]; then cp /usr/share/zabbix/conf/zabbix_server.conf /etc/zabbix/ chown -R zabbix.zabbix /etc/zabbix fi if [ ! -f "/var/lib/postgresql/data/zabbix.sql" ]; then chown postgres.postgres /var/lib/postgresql/data su -c "/usr/bin/pg_ctl -D /var/lib/postgresql/data start" postgres su -c "psql -c \"CREATE USER zabbix WITH PASSWORD 'zbxpass';\"" postgres su -c "createdb -O zabbix zabbix" postgres su -c "/usr/bin/pg_ctl -D /var/lib/postgresql/data stop" postgres fi exec "$@" 2. 然后,我们可以使用Docker Compose创建一个Zabbix监控集群。我们将使用Zabbix Server、Zabbix Agent以及PostgreSQL数据库容器。可以使用以下配置文件: version: '3' services: db: image: postgres:9.6 volumes: - db_data:/var/lib/postgresql/data environment: - POSTGRES_USER=zabbix - POSTGRES_PASSWORD=zbxpass - POSTGRES_DB=zabbix ports: - "5432:5432" networks: - zbx_net zabbix_server: build: . volumes: - ./nginx.conf:/etc/nginx/nginx.conf - ./supervisord.conf:/etc/supervisor/conf.d/supervisord.conf - ./php-fpm.ini:/etc/php7/php-fpm.d/www.conf - zabbix_data:/var/lib/zabbix environment: - DB_SERVER_HOST=db - DB_SERVER_PORT=5432 - POSTGRES_USER=zabbix - POSTGRES_PASSWORD=zbxpass - POSTGRES_DB=zabbix ports: - "80:80" - "10051:10051" depends_on: - db networks: - zbx_net zabbix_agent: image: zabbix/zabbix-agent2:alpine-3.13-latest environment: - ZBX_HOSTNAME=zabbix-agent networks: - zbx_net volumes: db_data: driver: local zabbix_data: driver: local networks: zbx_net: 3. 在保存Docker Compose配置文件后,您可以通过以下命令创建并启动Zabbix监控集群: docker-compose up -d 4. 容器启动后,可以访问Zabbix Web界面并使用默认凭据登录。默认用户名和密码分别为Admin和zabbix。接下来,您可以开始监控您的设备和应用程序。 综上所述,我们可以使用DockerDocker Compose来部署Zabbix监控集群。这种方法方便、可扩展和易于管理,能够让我们快速构建和部署一个强大的监控系统。 ### 回答3: Docker是一个开源的容器化应用平台,它可以帮助我们将应用程序和服务打包成一个容器,这样就可以更快速、更有效地部署和运行它们。而Zabbix是一款功能强大的监控软件,它可以帮助我们监测网络通信、服务器性能等。通过将Zabbix部署Docker容器中,可以实现快速部署和升级。 在部署Zabbix集群之前,我们需要准备好Docker环境。首先,我们需要在主机上安装Docker Engine和Docker Compose。然后,我们需要创建一个Docker镜像,包含Zabbix Server和Zabbix Agent。可以使用Dockerfile文件来定义该镜像的构建过程。例如,我们可以通过以下方式构建Zabbix镜像: ```dockerfile FROM ubuntu:20.04 RUN apt-get update && apt-get -y install wget \ && wget https://repo.zabbix.com/zabbix/5.2/ubuntu/pool/main/z/zabbix-release/zabbix-release_5.2-1+ubuntu20.04_all.deb \ && dpkg -i zabbix-release_5.2-1+ubuntu20.04_all.deb \ && rm -f zabbix-release_5.2-1+ubuntu20.04_all.deb \ && apt-get update \ && apt-get -y install zabbix-server-mysql zabbix-frontend-php zabbix-agent mysql-client \ && apt-get clean \ && rm -rf /var/lib/apt/lists/* EXPOSE 80 10050 CMD ["/bin/bash"] ``` 在这个Dockerfile中,我们首先从Ubuntu官方镜像开始构建。然后,我们下载最新的Zabbix Release,并安装Zabbix Server、Zabbix Agent、Zabbix Web等软件包。最后,我们暴露了80和10050两个端口,并在容器启动时启动Bash shell。 接下来,我们需要使用Docker Compose来编排这个镜像的部署。以下是一个简单的docker-compose.yml文件的示例: ```yml version: '3.2' services: zabbix-db: image: mysql:5.7 volumes: - ./data:/var/lib/mysql environment: MYSQL_ROOT_PASSWORD: zabbix MYSQL_DATABASE: zabbix MYSQL_USER: zabbix MYSQL_PASSWORD: zabbix zabbix-server: build: . volumes: - ./zabbix-server.conf:/etc/zabbix/zabbix_server.conf environment: DB_SERVER_HOST: zabbix-db MYSQL_USER: zabbix MYSQL_PASSWORD: zabbix MYSQL_DATABASE: zabbix ports: - 80:80 zabbix-agent: image: zabbix/zabbix-agent:latest environment: ZBX_SERVER_HOST: zabbix-server ZBX_SERVER_PORT: 10051 ZBX_HOSTNAME: zabbix-agent ports: - 10050:10050 ``` 在这个docker-compose.yml文件中,我们定义了3个容器服务,分别是: 1. zabbix-db:MySQL数据库容器服务,用于存储Zabbix Server的监控数据。 2. zabbix-server:Zabbix Server容器服务,包含Zabbix Server和Zabbix Web等组件。 3. zabbix-agent:Zabbix Agent容器服务,用于监控其他容器的性能指标。 在这个文件中,我们还定义了一些环境变量和卷,以保证容器之间的数据共享。最后,我们将Zabbix Web的端口暴露给主机,以方便用户访问Zabbix监控界面。 在完成docker-compose.yml文件的编写后,我们可以使用以下命令来启动Zabbix集群: ```bash docker-compose up -d ``` 总之,使用Docker可以轻松地部署Zabbix监控集群,以帮助我们更好地监控和管理我们的应用程序和服务。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值