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

相关文章

闲置电脑也能活出第二春?鲁大师AiNAS让你动动手指就能轻松部署

对于大多数人而言,在这个“数据爆炸”的时代或多或少都遇到过存储告急的情况,这使得“存储焦虑”不再是个别现象,而将会是随着软件的不断臃肿而越来越普遍的情况。从不少手机厂商都开始将存储上限提升至1TB可以见得,我们似乎正处在互联网信息飞速增长的阶段,对于存储的需求也将会不断扩大。对于苹果用户而言,这一问题愈发严峻,毕竟512GB和1TB版本的iPhone可不是人人都消费得起的,因此成熟的外置存储方案开

如何用Docker运行Django项目

本章教程,介绍如何用Docker创建一个Django,并运行能够访问。 一、拉取镜像 这里我们使用python3.11版本的docker镜像 docker pull python:3.11 二、运行容器 这里我们将容器内部的8080端口,映射到宿主机的80端口上。 docker run -itd --name python311 -p

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个

hdu2289(简单二分)

虽说是简单二分,但是我还是wa死了  题意:已知圆台的体积,求高度 首先要知道圆台体积怎么求:设上下底的半径分别为r1,r2,高为h,V = PI*(r1*r1+r1*r2+r2*r2)*h/3 然后以h进行二分 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#includ

阿里开源语音识别SenseVoiceWindows环境部署

SenseVoice介绍 SenseVoice 专注于高精度多语言语音识别、情感辨识和音频事件检测多语言识别: 采用超过 40 万小时数据训练,支持超过 50 种语言,识别效果上优于 Whisper 模型。富文本识别:具备优秀的情感识别,能够在测试数据上达到和超过目前最佳情感识别模型的效果。支持声音事件检测能力,支持音乐、掌声、笑声、哭声、咳嗽、喷嚏等多种常见人机交互事件进行检测。高效推

usaco 1.3 Prime Cryptarithm(简单哈希表暴搜剪枝)

思路: 1. 用一个 hash[ ] 数组存放输入的数字,令 hash[ tmp ]=1 。 2. 一个自定义函数 check( ) ,检查各位是否为输入的数字。 3. 暴搜。第一行数从 100到999,第二行数从 10到99。 4. 剪枝。 代码: /*ID: who jayLANG: C++TASK: crypt1*/#include<stdio.h>bool h

uva 10387 Billiard(简单几何)

题意是一个球从矩形的中点出发,告诉你小球与矩形两条边的碰撞次数与小球回到原点的时间,求小球出发时的角度和小球的速度。 简单的几何问题,小球每与竖边碰撞一次,向右扩展一个相同的矩形;每与横边碰撞一次,向上扩展一个相同的矩形。 可以发现,扩展矩形的路径和在当前矩形中的每一段路径相同,当小球回到出发点时,一条直线的路径刚好经过最后一个扩展矩形的中心点。 最后扩展的路径和横边竖边恰好组成一个直

poj 1113 凸包+简单几何计算

题意: 给N个平面上的点,现在要在离点外L米处建城墙,使得城墙把所有点都包含进去且城墙的长度最短。 解析: 韬哥出的某次训练赛上A出的第一道计算几何,算是大水题吧。 用convexhull算法把凸包求出来,然后加加减减就A了。 计算见下图: 好久没玩画图了啊好开心。 代码: #include <iostream>#include <cstdio>#inclu

uva 10130 简单背包

题意: 背包和 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#include <stack>#include <vector>#include <queue>#include <map>

K8S(Kubernetes)开源的容器编排平台安装步骤详解

K8S(Kubernetes)是一个开源的容器编排平台,用于自动化部署、扩展和管理容器化应用程序。以下是K8S容器编排平台的安装步骤、使用方式及特点的概述: 安装步骤: 安装Docker:K8S需要基于Docker来运行容器化应用程序。首先要在所有节点上安装Docker引擎。 安装Kubernetes Master:在集群中选择一台主机作为Master节点,安装K8S的控制平面组件,如AP