Docker容器化部署Zabbix6.0(史上最简单,全程粘贴复制即可完成!!)

本文主要是介绍Docker容器化部署Zabbix6.0(史上最简单,全程粘贴复制即可完成!!),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

    • 一、部署docker环境
    • 二、部署docker-compose环境
    • 三、部署Zabbix6.0(docker-compose方式)
    • 四、部署Zabbix-agent

一、部署docker环境

1、前提环境准备

systemctl stop firewalld
systemctl disable firewalld
setenforce 0
sed -i 's/SELINUX=enforcing/SELINUX=disabled/' /etc/selinux/config

2、配置阿里云Yum源

yum -y install yum-utils
yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo

3、安装docker

yum install docker-ce docker-ce-cli containerd.io -y

4、配置国内镜像加速地址

mkdir -p /etc/dockertee /etc/docker/daemon.json <<-'EOF'
{"registry-mirrors": ["https://aoewjvel.mirror.aliyuncs.com"]
}
EOF

5、启动并加入自启动

systemctl start docker
systemctl enable docker

6、查看docker版本

docker --version

二、部署docker-compose环境

1、官方下载docker-compose

curl -L "https://github.com/docker/compose/releases/download/v2.10.2/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose

2、赋予执行权限

chmod +x /usr/local/bin/docker-compose

3、查看版本

docker-compose --version

三、部署Zabbix6.0(docker-compose方式)

1、创建部署目录

mkdir /etc/zabbix
cd /etc/zabbix

2、添加.env文件(如果没有需求,保持默认即可)

vi .envDEPLOY_PATH="/etc/zabbix/zabbix6.0"
MYSQL_ROOT_PASSWORD="1qaz!QAZZabbix.com"
MYSQL_USER=zabbix
MYSQL_PASSWORD="1qaz!QAZZabbix.com"
ZABBIX_NETWORK_SUBNET="10.10.10.0/24"
ZABBIX_WEB_PORT="3999"
ZABBIX_HISTORYCACHESIZE=2048M

3、添加docker-compose.yaml文件

vi docker-compose.yamlversion: '3'
services:
# DBmysql:image: mysql:8.0container_name: mysqlvolumes:- ${DEPLOY_PATH}/data:/var/lib/mysql- ${DEPLOY_PATH}/mysql/conf:/etc/mysql/conf.d- ${DEPLOY_PATH}/mysql/logs:/var/log/mysql- /etc/localtime:/etc/localtime:rorestart: alwaysprivileged: trueenvironment:- MYSQL_ROOT_PASSWORD=${MYSQL_ROOT_PASSWORD}- MYSQL_DATABASE=zabbix- MYSQL_USER=${MYSQL_USER}- MYSQL_PASSWORD=${MYSQL_PASSWORD}- TZ=Asia/Shanghai- LANG=en_US.UTF-8expose:- "3306"networks:zabbix-net:command: --character-set-server=utf8 --collation-server=utf8_bin# Gatewayzabbix-gateway:image: zabbix/zabbix-java-gateway:6.0-centos-latestcontainer_name: zabbix-gatewayvolumes:- /etc/localtime:/etc/localtime:rorestart: alwaysprivileged: trueports:- "10052:10052"networks:zabbix-net:# Agent 
#  zabbix6-agent:
#    image: zabbix/zabbix-agent:centos-6.0-latest
#    container_name: zabbix6-agent
#    volumes:
#      - /etc/localtime:/etc/localtime:ro
#      - /etc/timezone:/etc/timezone:ro
#      - ${DEPLOY_PATH}/zbx_env/etc/zabbix/zabbix_agentd.d:/etc/zabbix/zabbix_agentd.d:ro
#      - ${DEPLOY_PATH}/zbx_env/var/lib/zabbix/modules:/var/lib/zabbix/modules:ro
#      - ${DEPLOY_PATH}/zbx_env/var/lib/zabbix/enc:/var/lib/zabbix/enc:ro
#      - ${DEPLOY_PATH}/zbx_env/var/lib/zabbix/ssh_keys:/var/lib/zabbix/ssh_keys:ro
#    restart: always
#    privileged: true
#    environment:
#      - ZBX_HOSTNAME=Zabbix server
#      - ZBX_SERVER_HOST=zabbix-server
#      - ZBX_SERVER_PORT=10051
#    ports:
#      - "10050:10050"
#    networks:
#      zabbix-net:
#
# SNMP(可选)
#  zabbix-snmptraps:
#    image: zabbix/zabbix-snmptraps:6.0-centos-latest
#    container_name: zabbix-snmptraps
#    volumes:
#      - /etc/localtime:/etc/localtime:ro
#      - ${DEPLOY_PATH}/snmptraps:/var/lib/zabbix/snmptraps
#      - ${DEPLOY_PATH}/mibs:/var/lib/zabbix/mibs
#    restart: always
#    privileged: true
#    ports:
#      - "1162:1162/udp"
#    networks:
#      zabbix-net:# Serverzabbix-server:image: zabbix/zabbix-server-mysql:6.0-centos-latestcontainer_name: zabbix-servervolumes:- /etc/localtime:/etc/localtime:ro- ${DEPLOY_PATH}/snmptraps:/var/lib/zabbix/snmptraps- ${DEPLOY_PATH}/mibs:/var/lib/zabbix/mibs- ${DEPLOY_PATH}/alertscripts:/usr/lib/zabbix/alertscripts- ${DEPLOY_PATH}/externalscripts:/usr/lib/zabbix/externalscriptsrestart: alwaysprivileged: trueenvironment:- ZBX_LISTENPORT=10051- DB_SERVER_HOST=mysql- DB_SERVER_PORT=3306- MYSQL_DATABASE=zabbix- MYSQL_USERx-server=${MYSQL_USER}- MYSQL_PASSWORD=${MYSQL_PASSWORD}- MYSQL_ROOT_PASSWORD=${MYSQL_ROOT_PASSWORD}- ZBX_CACHESIZE=1G- ZBX_HISTORYCACHESIZE=${ZABBIX_HISTORYCACHESIZE}- ZBX_HISTORYINDEXCACHESIZE=16M- ZBX_TRENDCACHESIZE=256M- ZBX_VALUECACHESIZE=256M- ZBX_STARTPINGERS=64- ZBX_IPMIPOLLERS=1- ZBX_ENABLE_SNMP_TRAPS=true- ZBX_STARTTRAPPERS=1- ZBX_JAVAGATEWAY_ENABLE=true- ZBX_JAVAGATEWAY=zabbix-gateway- ZBX_STARTJAVAPOLLERS=1ports:- "10051:10051"networks:zabbix-net:links:- mysql- zabbix-gateway# WEBzabbix-web:image: zabbix/zabbix-web-nginx-mysql:6.0-centos-latestcontainer_name: zabbix-webvolumes:- ${DEPLOY_PATH}/font/simfang.ttf:/usr/share/zabbix/assets/fonts/DejaVuSans.ttf- /etc/localtime:/etc/localtimerestart: alwaysprivileged: trueenvironment:- ZBX_SERVER_NAME=Zabbix 6.0- ZBX_SERVER_HOST=zabbix-server- ZBX_SERVER_PORT=10051- DB_SERVER_HOST=mysql- DB_SERVER_PORT=3306- MYSQL_DATABASE=zabbix- MYSQL_USER=${MYSQL_USER}- MYSQL_PASSWORD=${MYSQL_PASSWORD}- MYSQL_ROOT_PASSWORD=${MYSQL_ROOT_PASSWORD}- PHP_TZ=Asia/Shanghaiports:- "${ZABBIX_WEB_PORT}:8080"networks:zabbix-net:links:- mysql- zabbix-servernetworks:zabbix-net:driver: bridgeipam:config:- subnet: ${ZABBIX_NETWORK_SUBNET} 

4、解决图形乱码问题

yum -y install wqy-microhei-fonts.noarch 
mkdir /etc/zabbix/font
cp /usr/share/fonts/wqy-microhei/wqy-microhei.ttc /etc/zabbix/font/simfang.ttf

5、启动(第一次需要下载镜像,请耐心等待…)

docker-compose up -d

6、访问验证

浏览器访问:http://IP:3999

注意:如果访问到提示"Database error",如下图所示,不要担心,这是Zabbix还没初始化完成,耐心等待后即可正常访问到了!

在这里插入图片描述

默认账号密码:Admin/zabbix

在这里插入图片描述

四、部署Zabbix-agent

注意:由于不是每台服务器都有docker环境,所以zabbix-agent不走容器部署比较方便

1、下载Zabbix-agent

wget https://cdn.zabbix.com/zabbix/binaries/stable/6.0/6.0.30/zabbix_agent-6.0.30-linux-3.0-i386-static.tar.gz --no-check-certificatetar zxf zabbix_agent-6.0.30-linux-3.0-i386-static.tar.gz -C /usr/local/

2、修改配置文件,10.10.10.0/24 是容器的网段

vi /usr/local/conf/zabbix_agentd.conf
# 修改Server
Server=10.10.10.0/24

3、启动Zabbix-agent

useradd -M zabbix
cd /usr/local/sbin/
su - zabbix -c "./zabbix_agentd -c ../conf/zabbix_agentd.conf"

添加完成之后,正常在WEB页面添加主机即可,这里不在赘述

OK,至此结束

这篇关于Docker容器化部署Zabbix6.0(史上最简单,全程粘贴复制即可完成!!)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1027563

相关文章

使用IDEA部署Docker应用指南分享

《使用IDEA部署Docker应用指南分享》本文介绍了使用IDEA部署Docker应用的四步流程:创建Dockerfile、配置IDEADocker连接、设置运行调试环境、构建运行镜像,并强调需准备本... 目录一、创建 dockerfile 配置文件二、配置 IDEA 的 Docker 连接三、配置 Do

Java中使用 @Builder 注解的简单示例

《Java中使用@Builder注解的简单示例》@Builder简化构建但存在复杂性,需配合其他注解,导致可变性、抽象类型处理难题,链式编程非最佳实践,适合长期对象,避免与@Data混用,改用@G... 目录一、案例二、不足之处大多数同学使用 @Builder 无非就是为了链式编程,然而 @Builder

使用Go实现文件复制的完整流程

《使用Go实现文件复制的完整流程》本案例将实现一个实用的文件操作工具:将一个文件的内容完整复制到另一个文件中,这是文件处理中的常见任务,比如配置文件备份、日志迁移、用户上传文件转存等,文中通过代码示例... 目录案例说明涉及China编程知识点示例代码代码解析示例运行练习扩展小结案例说明我们将通过标准库 os

MySQL 主从复制部署及验证(示例详解)

《MySQL主从复制部署及验证(示例详解)》本文介绍MySQL主从复制部署步骤及学校管理数据库创建脚本,包含表结构设计、示例数据插入和查询语句,用于验证主从同步功能,感兴趣的朋友一起看看吧... 目录mysql 主从复制部署指南部署步骤1.环境准备2. 主服务器配置3. 创建复制用户4. 获取主服务器状态5

SpringBoot结合Docker进行容器化处理指南

《SpringBoot结合Docker进行容器化处理指南》在当今快速发展的软件工程领域,SpringBoot和Docker已经成为现代Java开发者的必备工具,本文将深入讲解如何将一个SpringBo... 目录前言一、为什么选择 Spring Bootjavascript + docker1. 快速部署与

golang程序打包成脚本部署到Linux系统方式

《golang程序打包成脚本部署到Linux系统方式》Golang程序通过本地编译(设置GOOS为linux生成无后缀二进制文件),上传至Linux服务器后赋权执行,使用nohup命令实现后台运行,完... 目录本地编译golang程序上传Golang二进制文件到linux服务器总结本地编译Golang程序

如何在Ubuntu 24.04上部署Zabbix 7.0对服务器进行监控

《如何在Ubuntu24.04上部署Zabbix7.0对服务器进行监控》在Ubuntu24.04上部署Zabbix7.0监控阿里云ECS服务器,需配置MariaDB数据库、开放10050/1005... 目录软硬件信息部署步骤步骤 1:安装并配置mariadb步骤 2:安装Zabbix 7.0 Server

使用Docker构建Python Flask程序的详细教程

《使用Docker构建PythonFlask程序的详细教程》在当今的软件开发领域,容器化技术正变得越来越流行,而Docker无疑是其中的佼佼者,本文我们就来聊聊如何使用Docker构建一个简单的Py... 目录引言一、准备工作二、创建 Flask 应用程序三、创建 dockerfile四、构建 Docker

SpringBoot+Docker+Graylog 如何让错误自动报警

《SpringBoot+Docker+Graylog如何让错误自动报警》SpringBoot默认使用SLF4J与Logback,支持多日志级别和配置方式,可输出到控制台、文件及远程服务器,集成ELK... 目录01 Spring Boot 默认日志框架解析02 Spring Boot 日志级别详解03 Sp

Spring IoC 容器的使用详解(最新整理)

《SpringIoC容器的使用详解(最新整理)》文章介绍了Spring框架中的应用分层思想与IoC容器原理,通过分层解耦业务逻辑、数据访问等模块,IoC容器利用@Component注解管理Bean... 目录1. 应用分层2. IoC 的介绍3. IoC 容器的使用3.1. bean 的存储3.2. 方法注