zabbix企业监控实战-1-zabbix部署

news2024/12/24 8:17:06

官网:https://www.zabbix.com

参考官网:https://www.zabbix.com/download?zabbix=6.0&os_distribution=rocky_linux&os_version=8&components=server_frontend_agent&db=mysql&ws=apache

1、环境准备

1> 修改主机名

[root@zabbix ~]# hostnamectl set-hostname  zabbix
[root@zabbix ~]# su -

2> 关闭防火墙和selinux

# 临时关闭
[root@zabbix ~]# setenforce 0
[root@zabbix ~]# systemctl stop firewalld.service

# 永久关闭
[root@zabbix ~]# systemctl disable firewalld.service
[root@zabbix ~]# cat /etc/selinux/config

# This file controls the state of SELinux on the system.
# SELINUX= can take one of these three values:
#     enforcing - SELinux security policy is enforced.
#     permissive - SELinux prints warnings instead of enforcing.
#     disabled - No SELinux policy is loaded.
SELINUX=disabled

3> 配置源

[root@zabbix ~]# sed -e 's|^mirrorlist=|#mirrorlist=|g'     -e 's|^#baseurl=http://dl.rockylinux.org/$contentdir|baseurl=https://mirrors.aliyun.com/rockylinux|g'     -i.bak     /etc/yum.repos.d/Rocky-*.repo

[root@zabbix ~]# wget -O /etc/yum.repos.d/epel.repo https://mirrors.aliyun.com/repo/epel-7.repo

4> 安装常用软件

[root@zabbix ~]# yum install -y bash-completion tree lrzsz  vim  net-tools.x86_64  unzip net-tools  lsof  wget

5> 修改IP为静态IP地址

[root@zabbix ~]# nmcli connection modify ens160 ipv4.method manual ipv4.addresses 192.168.11.91/24 ipv4.gateway 192.168.11.2 ipv4.dns 114.114.114.114 connection.autoconnect yes 
[root@zabbix ~]# nmcli connection up ens160

6> 创建快照

2、时间同步需求

Zabbix-Server对时间的精准要求比较高,时间对数据的计算等都有影响,因此必须设置NTP自动同步时间

[root@zabbix ~]# yum install chrony.x86_64 -y


...
    #  iburst为固定格式,配置向上游时间服务器同步。
    server cn.pool.ntp.org iburst
    ...
    # 允许指定网络的主机同步时间,不指定就是允许所有,默认不开启。
    allow 192.168.11.0/24
    ...
    # 还有一个默认不开启的选项,意思是,即使服务端没有同步到精确的网络时间,也允许向客户端同步不精确的时间。可以视情况而定。
    # Serve time even if not synchronized to any NTP server.
    #local stratum 10
[root@zabbix ~]# systemctl enable --now chronyd

3、RPM包安装

下面以64位Rocky Linux release 8.7操作系统为例,介绍如何安装Zabbix-Server
服务器端。Zabbix-Server的最新版本为6.x

1> Install Zabbix repository

源里面没有包

[root@zabbix ~]# wget -O /etc/yum.repos.d/epel.repo https://mirrors.aliyun.com/repo/epel-7.repo

官方:
[root@zabbix ~]# rpm -Uvh https://repo.zabbix.com/zabbix/6.0/rhel/8/x86_64/zabbix-release-6.0-4.el8.noarch.rpm
[root@zabbix ~]# yum clean all

2> Install Zabbix server, frontend, agent

[root@zabbix ~]# dnf install zabbix-server-mysql zabbix-web-mysql zabbix-apache-conf zabbix-sql-scripts zabbix-selinux-policy zabbix-agent

3> Create initial database

[root@zabbix ~]# yum install mariadb-server -y

4> 配置数据库

[root@zabbix ~]# systemctl enable --now mariadb
[root@zabbix ~]# mysql -e "create database zabbix character set utf8 collate utf8_bin;"
[root@zabbix ~]# mysql -e "create user 'zabbix'@'localhost' identified by 'zabbix';"
[root@zabbix ~]# mysql -e "grant all privileges on zabbix.* to 'zabbix'@'localhost';"
[root@zabbix ~]# mysql -e "set global log_bin_trust_function_creators = 1"

5> 导入数据

PS:版本路径不一致,最好参考官方文档做,这个路径是在官方提供的

[root@zabbix ~]# zcat /usr/share/zabbix-sql-scripts/mysql/server.sql.gz | mysql --default-character-set=utf8mb4 -uzabbix -p zabbix
Enter password:

6> Disable log_bin_trust_function_creators option after importing database schema.

[root@zabbix ~]# mysql -e "set global log_bin_trust_function_creators = 0"

7> Configure the database for Zabbix server

为zabbix server配置数据库

[root@zabbix ~]# grep ^DB  /etc/zabbix/zabbix_server.conf
DBName=zabbix
DBUser=zabbix
DBPassword=zabbix

8> Start Zabbix server and agent processes

配置php时区

[root@zabbix ~]# vim /etc/php-fpm.d/zabbix.conf
[root@zabbix ~]# tail -1 /etc/php-fpm.d/zabbix.conf
php_value[date.timezone] = Asia/Shanghai
[root@zabbix ~]# systemctl enable --now httpd.service php-fpm.service zabbix-server.service
[root@zabbix ~]# systemctl restart zabbix-agent.service

(1) 欢迎界面

(2) 检查环境
(3) 配置数据库
(4) 安装汇总

(5) 安装完成
(6) 登录系统http://ip/zabbix
用户/密码:Admin/zabbix

4、源码安装

1> 部署LAMP环境

[root@node1 ~]# dnf install -y httpd mariadb-server php php-fpm php-gd php-mysqlnd php-xml php-common php-mbstring php-bcmath php-ldap php-json

2> 获取zabbix

[root@node1 ~]# wget -c https://cdn.zabbix.com/zabbix/sources/stable/5.0/zabbix-5.0.0.tar.gz

3> 安装zabbix

#1. 创建用户
[root@node1 ~]# groupadd -r zabbix
[root@node1 ~]# useradd -r zabbix -g zabbix -d /usr/lib/zabbix -s /sbin/nologin -c "Zabbix Monitoring System"
创建zabbix账号的home目录
[root@node1 ~]# mkdir -m u=rwx,g=rwx,o= -p /usr/lib/zabbix
[root@node1 ~]# chown zabbix:zabbix /usr/lib/zabbix
#2. 创建 Zabbix 数据库
[root@node1 ~]# systemctl enable --now mariadb
Created symlink /etc/systemd/system/mysql.service → /usr/lib/systemd/system/mariadb.service.
Created symlink /etc/systemd/system/mysqld.service → /usr/lib/systemd/system/mariadb.service.
Created symlink /etc/systemd/system/multi-user.target.wants/mariadb.service → /usr/lib/systemd/system/mariadb.service.
[root@node1 ~]# mysql -e "create database zabbix character set utf8 collate utf8_bin;"
[root@node1 ~]# mysql -e "create user 'zabbix'@'localhost' identified by 'zabbix';"
[root@node1 ~]# mysql -e "grant all privileges on zabbix.* to 'zabbix'@'localhost';"
#3. 导入数据
[root@node1 ~]# tar xf zabbix-5.0.0.tar.gz -C /usr/local/src/
[root@node1 ~]# cd /usr/local/src/zabbix-5.0.19/database/mysql/
[root@node1 mysql]# mysql -uzabbix -pzabbix zabbix < schema.sql
[root@node1 mysql]# mysql -uzabbix -pzabbix zabbix < images.sql
[root@node1 mysql]# mysql -uzabbix -pzabbix zabbix < data.sql 
#4. 安装编译环境和依赖
[root@node1 mysql]# dnf install -y gcc gcc-c++ make mariadb-devel libxml2-devel net-snmp net-snmp-devel libevent-devel curl-devel pcre-devel
#5. 配置源代码
[root@node1 mysql]# cd ../..
[root@node1 zabbix-5.0.0]# ./configure --prefix=/usr/local/zabbix --enable-server --enable-agent --with-mysql --enable-ipv6 --with-net-snmp --with-libcurl --with-libxml2
#6. 安装
[root@node1 zabbix-5.0.0]# make && make install
#7. 安装 Zabbix web 界面
[root@node1 zabbix-5.0.0]# mkdir /var/www/html/zabbix
[root@node1 zabbix-5.0.0]# cp -R ui/* /var/www/html/zabbix/
[root@node1 zabbix-5.0.0]# chown apache:apache /var/www/html/zabbix/ -R
#8. 配置server 使用数据库
[root@node1 ~]# grep ^DB /usr/local/zabbix/etc/zabbix_server.conf
DBName=zabbix
DBUser=zabbix
DBPassword=zabbix
#9. 配置zabbix server和agent脚本
[root@node1 ~]# cat /usr/lib/systemd/system/zabbix-server.service
[Unit]
Description=Zabbix Server
After=syslog.target
After=network.target
After=mysql.service
After=mysqld.service
After=mariadb.service
After=postgresql.service
After=pgbouncer.service
After=postgresql-9.4.service
After=postgresql-9.5.service
After=postgresql-9.6.service
After=postgresql-10.service
After=postgresql-11.service
After=postgresql-12.service
After=postgresql-13.service

[Service]
Environment="CONFFILE=/usr/local/zabbix/etc/zabbix_server.conf"
EnvironmentFile=-/etc/sysconfig/zabbix-server
Type=forking
Restart=on-failure
PIDFile=/tmp/zabbix_server.pid
KillMode=control-group
ExecStart=/usr/local/zabbix/sbin/zabbix_server -c $CONFFILE
ExecStop=/bin/kill -SIGTERM $MAINPID
RestartSec=10s
TimeoutSec=0

[Install]
WantedBy=multi-user.target

[root@node1 ~]# systemctl daemon-reload
[root@node1 ~]# systemctl enable zabbix-server.service --now
Created symlink /etc/systemd/system/multi-user.target.wants/zabbix-server.service → /usr/lib/systemd/system/zabbix-server.service.

[root@node1 ~]# cat /usr/lib/systemd/system/zabbix-agent.service
[Unit]
Description=Zabbix Agent
After=syslog.target
After=network.target

[Service]
Environment="CONFFILE=/usr/local/zabbix/etc/zabbix_agentd.conf"
EnvironmentFile=-/etc/sysconfig/zabbix-agent
Type=forking
Restart=on-failure
PIDFile=/tmp/zabbix_agentd.pid
KillMode=control-group
ExecStart=/usr/local/zabbix/sbin/zabbix_agentd -c $CONFFILE
ExecStop=/bin/kill -SIGTERM $MAINPID
RestartSec=10s
User=zabbix
Group=zabbix

[Install]
WantedBy=multi-user.target
[root@node1 ~]# systemctl daemon-reload
[root@node1 ~]# systemctl enable --now zabbix-agent.service
#10. 修改php配置文件
[root@node1 ~]# vim /etc/php.ini
post_max_size = 16M
max_execution_time = 300
max_input_time = 300
date.timezone = Asia/Shanghai
#11. 启动服务
[root@node1 ~]# systemctl enable --now httpd.service php-fpm.service 
Created symlink /etc/systemd/system/multi-user.target.wants/httpd.service → /usr/lib/systemd/system/httpd.service.
Created symlink /etc/systemd/system/multi-user.target.wants/php-fpm.service → /usr/lib/systemd/system/php-fpm.service.
#12. web界面安装,过程略。

5、容器部署

1> 安装podman

[root@node1 ~]# dnf install -y podman

更换为阿里云镜像源

[root@node1 ~]# cp /etc/containers/registries.conf{,.bak}
[root@node1 ~]# vim /etc/containers/registries.conf
...
#unqualified-search-registries = ["registry.fedoraproject.org", "registry.access.redhat.com", "registry.centos.org", "docker.io"]
unqualified-search-registries = ["docker.io"]
[[registry]]
prefix = "docker.io"
location = "rvq9mjyt.mirror.aliyuncs.com"
[root@node1 ~]# systemctl restart podman

2> 使用名称zabbix和公开的端口
(Web界面,Zabbix server trapper)创建新的Pod:

[root@node1 ~]# podman pod create --name zabbix -p 80:8080 -p 10051:10051

3> (可选)启动Zabbix agent容器

[root@node1 ~]# podman run --name zabbix-agent \
    -e ZBX_SERVER_HOST="127.0.0.1,localhost" \
    --restart=always \
    --pod=zabbix \
    -d zabbix/zabbix-agent:centos-5.0.0

4> 启动 MySQL server 8.0
在主机上创建./mysql/目录,然后启动

[root@node1 ~]# mkdir mysql
[root@node1 ~]# podman run --name mysql-server -t \
      -e MYSQL_DATABASE="zabbix" \
      -e MYSQL_USER="zabbix" \
      -e MYSQL_PASSWORD="zabbix_pwd" \
      -e MYSQL_ROOT_PASSWORD="root_pwd" \
      -v ./mysql/:/var/lib/mysql/:Z \
      --restart=always \
      --pod=zabbix \
      -d mysql:8.0 \
      --character-set-server=utf8 --collation-server=utf8_bin \
      --default-authentication-plugin=mysql_native_password

5> 启动Zabbix server容器

[root@node1 ~]# podman run --name zabbix-server-mysql -t \
                  -e DB_SERVER_HOST="127.0.0.1" \
                  -e MYSQL_DATABASE="zabbix" \
                  -e MYSQL_USER="zabbix" \
                  -e MYSQL_PASSWORD="zabbix_pwd" \
                  -e MYSQL_ROOT_PASSWORD="root_pwd" \
                  -e ZBX_JAVAGATEWAY="127.0.0.1" \
                  --restart=always \
                  --pod=zabbix \
                  -d zabbix/zabbix-server-mysql:centos-5.0.0

6> 启动Zabbix web容器

[root@node1 ~]# podman run --name zabbix-web-nginx-mysql -t \
      -e ZBX_SERVER_HOST="zabbix-server-mysql" \
      -e DB_SERVER_HOST="mysql-server" \
      -e MYSQL_DATABASE="zabbix" \
      -e MYSQL_USER="zabbix" \
      -e MYSQL_PASSWORD="zabbix_pwd" \
      -e MYSQL_ROOT_PASSWORD="root_pwd" \
      --pod=zabbix \
      --restart=always \
      -d zabbix/zabbix-web-nginx-mysql:centos-5.0.0

7> 启动Zabbix Java Gateway容器

[root@node1 ~]# podman run --name zabbix-java-gateway -t \
      --restart=always \
      --pod=zabbix \
      -d zabbix/zabbix-java-gateway:centos-5.0.0

8> 查看容器

[root@node1 ~]# podman ps
CONTAINER ID  IMAGE                                                 COMMAND               CREATED         STATUS             PORTS                                           NAMES
0f5c6ecb0abe  registry.access.redhat.com/ubi8/pause:latest                                27 minutes ago  Up 27 minutes ago  0.0.0.0:80->8080/tcp, 0.0.0.0:10051->10051/tcp  bc3c3547971b-infra
83635fcb4ed2  docker.io/library/mysql:8.0                           --character-set-s...  26 minutes ago  Up 27 minutes ago  0.0.0.0:80->8080/tcp, 0.0.0.0:10051->10051/tcp  mysql-server
2654c06dc28e  docker.io/zabbix/zabbix-server-mysql:centos-5.0.0     /usr/sbin/zabbix_...  25 minutes ago  Up 25 minutes ago  0.0.0.0:80->8080/tcp, 0.0.0.0:10051->10051/tcp  zabbix-server-mysql
9ce2910d9cc8  docker.io/zabbix/zabbix-java-gateway:centos-5.0.0     /usr/sbin/zabbix_...  21 minutes ago  Up 21 minutes ago  0.0.0.0:80->8080/tcp, 0.0.0.0:10051->10051/tcp  zabbix-java-gateway
198e0c257f94  docker.io/zabbix/zabbix-web-nginx-mysql:centos-5.0.0                        19 minutes ago  Up 19 minutes ago  0.0.0.0:80->8080/tcp, 0.0.0.0:10051->10051/tcp  zabbix-web-nginx-mysql
7f7eb782650f  docker.io/zabbix/zabbix-agent:centos-5.0.0            /usr/sbin/zabbix_...

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/546995.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Java --- redis7实现分布式锁

目录 一、锁的种类 二、分布式锁具备的条件与刚需 三、springbootredisngnix单机实现案例 四、Nginx配置负载均衡 4.1、修改nginx配置文件 4.2、执行启动命令 4.3、启动微服务程序测试 五、使用redis分布式锁 5.1、方法递归重试 5.2、自旋方式 5.3、添加key过期时间&#xff0…

业务实战记录4:多维表插入数据任务丢失处理与思考

本文目录 一、线程 bug二、解决方案2.1 加停顿2.2 单线程2.3 多 Token 三、一点花絮 很久没有写业务实战记录了&#xff0c;实际工作过程中其实遇到了挺多问题的&#xff0c;但是要通过 CSDN 记录下来&#xff0c;还是比较难的&#xff0c;因为场景和目标比较难说清楚&#xff…

【网络】HTTPHTTPS协议

文章目录 HTTP协议认识URLurlencode和urldecodeHTTP协议格式HTTP请求协议格式简单的小实验 HTTP响应协议格式关于封装解包分用 HTTP的方法关于GET和POST方法概念GET&POST对比(代码测试)测试POST和GET方法的区别 HTTP的状态码关于重定向的状态码临时重定向的代码演示: HTTP的…

【文献研究】轴辐式航线网络设计—Liner hub-and-spoke shipping network design

学习文献&#xff1a;轴辐式航线网络设计—Liner hub-and-spoke shipping network design 3. 模型建立 轴辐式航线网络设计 三级轴辐式网络&#xff1a;喂给港-二级枢纽港-一级枢纽港 主要考虑的限制条件&#xff1a;多种类型的集装箱船舶、转运时间、多种类型的集装箱 转运操…

Kangas:计算机视觉中的Pandas

介绍 在计算机视觉领域&#xff0c;Kangas是一种越来越受欢迎的工具&#xff0c;用于图像数据处理和分析。类似于Pandas如何改变数据分析人员处理表格数据的方式&#xff0c;Kangas对计算机视觉任务也起到了同样的作用。 Kangas是Comet ML开源的工具&#xff0c;用于探索、分析…

【Http协议①】认识http协议,学会使用fiddler抓包工具进行抓包.

前言: 大家好,我是良辰丫,今天我们一起来学习http协议,http协议是应用层的协议,应用层是最接近程序员的,那么,http协议到底是什么呢?我们往下看.&#x1f49e;&#x1f49e; &#x1f9d1;个人主页&#xff1a;良辰针不戳 &#x1f4d6;所属专栏&#xff1a;javaEE初阶 &#…

springboot+java养老院儿童福利院管理系统

安家儿童福利院管理系统包括儿童管理、申请领养管理、捐赠管理、楼栋管理、宿舍管理、分配信息管理、宿舍物品管理、报修管理、维修工管理、报修状态管理、留言管理、系统管理。通过对系统的实现得出安家儿童福利院管理系统具有安全稳定、操作简单、功能强大等特点&#xff0c;…

MySQL8.0卸载、安装和使用(二)

MySQL数据库的安装 注意&#xff1a; 必须用系统管理员身份运行mysql安装程序。安装目录切记不要用中文。 步骤一&#xff1a;双击mysql8的安装向导 步骤二&#xff1a;分为首次安装和再安装 1、首次安装 &#xff08;1&#xff09;如果是首次安装mysql系列的产品&#xff…

第06章_多表查询

第06章_多表查询 多表查询&#xff0c;也称为关联查询&#xff0c;指两个或更多个表一起完成查询操作。 前提条件&#xff1a;这些一起查询的表之间是有关系的&#xff08;一对一、一对多&#xff09;&#xff0c;它们之间一定是有关联字段&#xff0c;这个关联字段可能建立了…

脑科学研究者的案头书(含下载资源)

脑科学研究者的案头书 <<< 回复关键词获取下载链接 >>> 《EEG Signal Processing and Machine Learning》&#xff08;Second Edition&#xff09; 简介&#xff1a; 《脑电信号处理与机器学习》书籍旨在描述脑电图(EEG)研究中的新技术和成果&#xff0c;主…

chatgpt赋能Python-python3捕获异常

Python3异常处理技术详解 在Python3中&#xff0c;异常处理技术是一项非常重要的工具。它能够帮助程序员避免不可预见的错误&#xff0c;减少不必要的程序崩溃&#xff0c;保证程序的稳定性。 什么是异常&#xff1f; 异常就是程序在执行过程中发生的错误或异常情况。不同的…

Redis+LUA脚本实现限流

文章目录 1、demo结构2、自定义接口3、编写写LUA脚本4、通过AOP切面识别需要限流的接口编写切面AOP通知类型 5、Redis限流自定义异常构建Redis限流自定义异常声明这个类为全局异常处理器专属日志 6、流量限制器RateLimiterRateLimitAlgApiLimitRateLimitRuleRuleConfig 7、Guav…

Win11系统不兼容怎么回退到Win10系统使用?

Win11系统不兼容怎么回退到Win10系统使用&#xff1f;有用户将自己的电脑系统升级到了Win11之后&#xff0c;发现使用起来非常的卡顿&#xff0c;自己的电脑配置不足。那么这个情况怎么去进行问题的解决呢&#xff1f;来看看以下详细的解决方法分享吧。 准备工作&#xff1a; 1…

Golang每日一练(leetDay0071) 同构字符串、反转链表

目录 205. 同构字符串 Isomorphic Strings &#x1f31f; 206. 反转链表 Reverse Linked-list &#x1f31f; &#x1f31f; 每日一练刷题专栏 &#x1f31f; Rust每日一练 专栏 Golang每日一练 专栏 Python每日一练 专栏 C/C每日一练 专栏 Java每日一练 专栏 205. 同…

Debezium系列之:Debezium镜像仓库Quay.io,使用Debezium镜像仓库的方法和案例

Debezium系列之:Debezium镜像仓库Quay.io,使用Debezium镜像仓库的方法和案例 一、Debezium镜像仓库变动二、镜像仓库[Quay.io](https://quay.io/organization/debezium)三、使用镜像仓库Quay.io方法四、使用镜像仓库下载Debezium UI一、Debezium镜像仓库变动 Debezium2.2版本…

Linux RTC 驱动实验

RTC 也就是实时时钟&#xff0c;用于记录当前系统时间&#xff0c;对于 Linux 系统而言时间是非常重要的&#xff0c; 就和我们使用 Windows 电脑或手机查看时间一样&#xff0c;我们在使用 Linux 设备的时候也需要查看时 间。 一、Linux 内核 RTC 驱动简介 RTC 设备驱动是标准…

verdaccio + docker搭建私有npm仓库(有手就行)

一、环境准备 docker 二、步骤 运行verdaccio docker run -d --name verdaccio -p 4873:4873 --restartalways该命令执行完&#xff0c;一个本地的npm仓库就基本搭建好了&#xff0c;可以浏览器访问http://localhost:4873/ 查看&#xff0c;效果如下&#xff1a; 效果出是…

教你接入Midjourney,不用梯子也能玩

1、效果 话不多说&#xff0c;先上最终出图效果&#xff0c; 我给的关键词是一只白色的猫 2、接入流程 API文档可以来这里查&#xff08;可以白嫖100次midjourney出图和10次gpt4体验&#xff09;&#xff0c;我这里精简一下接入流程&#xff0c;方便大家快速接入 2.1、文字生…

JDK源码怎么学?看这篇文章就够了!

最近后台收到很多粉丝私信&#xff0c;说的是程序员究竟要不要去读源码&#xff1f;当下行情&#xff0c;面试什么样的薪资/岗位才会被问到源码&#xff1f; 对此&#xff0c;我的回答是&#xff1a;一定要去读&#xff0c;并且要提到日程上来&#xff01; 据不完全统计&…

远程访问群晖Drive并挂载为电脑磁盘同步备份文件「无需公网IP」

文章目录 前言视频教程1.群晖Synology Drive套件的安装1.1 安装Synology Drive套件1.2 设置Synology Drive套件1.3 局域网内电脑测试和使用 2.使用cpolar远程访问内网Synology Drive2.1 Cpolar云端设置2.2 Cpolar本地设置2.3 测试和使用 3. 结语 转发自CSDN远程穿透的文章&…