zabbix服务部署

文章目录

  • zabbix
    • 1 zabbix简介
      • 1.1 组成部件
      • 1.2 监控原理
      • 1.3 Zabbix 6.0新特性
      • 1.4 Zabbix6.0功能组件
        • 1.4.1 Zabbix Server
        • 1.4.2 数据库
        • 1.4.3 Web界面
        • 1.4.4 Zabbix Agent
        • 1.4.5 Zabbix Proxy
        • 1.4.6 Java Gateway
    • 2 部署zabbix服务端
      • 2.1 部署Nginx
      • 2.2 安装PHP
      • 2.3 修改Nginx配置
      • 2.4 修改PHP配置
      • 2.5 创建目录和测试文件
      • 2.6 部署Mariadb yum源
      • 2.7 初始化数据库
      • 2.8 编译安装zabbix server服务端
      • 2.9 修改zabbix server配置文件,修改密码
      • 2.10 部署web前端进行访问
    • 3 安装Zabbix客户端
      • 3.1 安装客户端
      • 3.2 解决中文乱码问题
    • 4 添加Zabbix客户端主机
      • 4.1 服务端和客户端配置时间同步
      • 4.2 服务端和客户端设置hosts解析
      • 4.3 设置zabbix的下载源,安装zabbix-agent2
      • 4.4 修改agent2配置文件
      • 4.5 启动zabbix-agent2
      • 4.6 服务端验证zabbix-agent2连通性
      • 4.7 Web页面添加agent主机

zabbix

1 zabbix简介

一款基于web界面分布式系统监视以及网络监视功能的企业级开源服务
在这里插入图片描述

1.1 组成部件

  • zabbix server
    • 通过zabbix agent、SNMP协议、端口监视等方法提供对远程服务器/网络状态的监视、数据收集等功能
  • zabbix agent
    • 需要安装在被监视的目标服务器上
    • 完成对硬件信息或与操作系统有关的内存、CPU等信息的收集

1.2 监控原理

  1. zabbix agent 安装在被监控的主机上,zabbix agent 负责定期收集客户端本地各项数据
  2. zabbix agent将数据发送至zabbix server端
  3. zabbix server 收到数据后, 将数据存储到数据库中
  4. 用户基于 Zabbix Web 可以看到数据在前端展现图像
  5. 被监控的某个具体的项目会设置一个触发器阈值
  6. 当被监控的指标超过该触发器设定的阈值,会进行一些必要的动作,动作包括:发送信息(邮件、微信、短信)、发送命令(shell 命令、reboot、restart、 install 等)
    在这里插入图片描述

1.3 Zabbix 6.0新特性

  1. Zabbix server高可用防止硬件故障或计划维护期的停机:

•原生选择加入HA群集配置
•定义一个或多个备用节点
•实时监控Zabbix server群集节点的状态
•不需要外部工具即可将Zabbix server配置为HA群集模式

  1. Zabbix 6.0 LTS新增Kubernetes监控功能,可以在Kubernetes系统从多个维度采集指标:

•Kubernetes节点和pods的自动发现和监控
•无代理方式采集Kubernetes pods和节点的信息
•获取Kubernetes节点主机高水平信息

1.4 Zabbix6.0功能组件

1.4.1 Zabbix Server

zabbix 服务端守护进程,是 Zabbix 软件的核心组件,Zabbix Agent 向其报告可用性、系统完整性信息和统计信息

存储所有配置信息、统计信息和操作信息

也是 Zabbix 监控系统的告警中心。在监控的系统中出现任何异常,将发出通知给管理员

1.4.2 数据库

所有配置信息以及 Zabbix 采集到的数据都被持久存储在数据库中

可以支持 MySQL、PostgreSQL、Oracle、DB2、TimescaleDB 等多种数据库

1.4.3 Web界面

用于实现展示和配置的界面

基于 Apache/Nginx + PHP 实现,早期只支持 LAMP 架构,从 Zabbix5.0 开始支持 LNMP

1.4.4 Zabbix Agent

部署在被监控目标上,用于主动监控本地资源和应用程序

将收集的数据发送给 Zabbix Server

1.4.5 Zabbix Proxy

zabbix 分布式代理守护进程,可以代替 Zabbix Server 采集性能和可用性数据

Zabbix Proxy 的部署可以很好的分担单个 Zabbix Server 的负载

通常监控大于 500 台主机时使用,需要进行分布式监控架构部署

1.4.6 Java Gateway

监控 Tomcat 服务或其它 JAVA 程序(比例 Elasticsearch、ZooKeeper)

需要使用 Java Gateway 做为代理,才能从 JAVA 程序中获取数据


2 部署zabbix服务端

2.1 部署Nginx

cat > /etc/yum.repos.d/nginx.repo << 'EOF'
[nginx]
name=nginx repo
baseurl=http://nginx.org/packages/centos/$releasever/$basearch/
gpgcheck=1
enabled=1
gpgkey=https://nginx.org/keys/nginx_signing.key
module_hotfixes=true
EOFyum install -y nginx

在这里插入图片描述
在这里插入图片描述

2.2 安装PHP

curl -o /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo
yum install -y epel-release
rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm
yum -y install php72w php72w-cli php72w-common php72w-devel php72w-embedded php72w-gd php72w-mbstring php72w-pdo php72w-xml php72w-fpm php72w-mysqlnd php72w-opcache php72w-ldap php72w-bcmath

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

2.3 修改Nginx配置

vim /etc/nginx/conf.d/default.conf
server {listen 146;server_name zbx.kgc.com;root /var/www/zbx;location / {index index.php;}location ~ \.php$ {fastcgi_pass 127.0.0.1:9000;fastcgi_index index.php;fastcgi_param SCRIPT_FILENAME /var/www/zbx$fastcgi_script_name;include fastcgi_params;}
}

在这里插入图片描述
在这里插入图片描述

2.4 修改PHP配置

vim /etc/php-fpm.d/www.conf
user = nginx
group = nginxvim /etc/php.ini
max_execution_time = 300		# 368行
max_input_time = 600			# 378行
post_max_size = 146M				# 656行
date.timezone = Asia/Shanghai	# 877行

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

2.5 创建目录和测试文件

mkdir -p /var/www/zbxvim /var/www/zbx/index.php
<?php
phpinfo();
?>

在这里插入图片描述

systemctl enable --now nginx php-fpm

在这里插入图片描述

测试访问(hosts解析)
修改 C:\Windows\System32\drivers\etc\hosts
192.168.146.20 zbx.kgc.com浏览器访问:http://zbx.kgc.com/index.php

在这里插入图片描述
在这里插入图片描述

2.6 部署Mariadb yum源

cat > /etc/yum.repos.d/mariadb.repo << EOF
[mariadb]
name = MariaDB
baseurl = http://mirrors.aliyun.com/mariadb/yum/10.5/centos7-amd64/
gpgkey = http://mirrors.aliyun.com/mariadb/yum/RPM-GPG-KEY-MariaDB
gpgcheck = 1
enabled=1
EOFyum install -y mariadb-server mariadbsystemctl enable --now mariadb

在这里插入图片描述
在这里插入图片描述

2.7 初始化数据库

mysql_secure_installation
分别输入 回车 -> n -> Y (设置root密码,如abc123) -> 后面一路 Ymysql -u root -pabc123

在这里插入图片描述

创建数据库并指定字符集
CREATE DATABASE zabbix character set utf8 collate utf8_bin;#创建 zabbix 数据库用户并授权
GRANT all ON zabbix.* TO 'zabbix'@'localhost' IDENTIFIED BY 'zabbix';
GRANT all ON zabbix.* TO 'zabbix'@'%' IDENTIFIED BY 'zabbix';
flush privileges;

在这里插入图片描述

向数据库导入 zabbix 数据
上传源码包 zabbix-6.0.13.tar.gz 到 /opt 目录
cd /opt
tar xf zabbix-6.0.13.tar.gzls /opt/zabbix-6.0.13/database/mysql
data.sql  double.sql  history_pk_prepare.sql  images.sql  Makefile.am  Makefile.in  schema.sql

在这里插入图片描述

按照顺利导入数据库
cd /opt/zabbix-6.0.13/database/mysql
mysql -uroot -pabc123 zabbix < schema.sql
mysql -uroot -pabc123 zabbix < images.sql
mysql -uroot -pabc123 zabbix < data.sql
mysql -uroot -pabc123 zabbix < double.sql
mysql -uroot -pabc123 zabbix < history_pk_prepare.sql

在这里插入图片描述

2.8 编译安装zabbix server服务端

#安装依赖包,创建 zabbix 用户
yum install -y mysql-devel pcre-devel openssl-devel zlib-devel libxml2-devel net-snmp-devel net-snmp libssh2-devel OpenIPMI-devel libevent-devel openldap-devel libcurl-devel fping gcc gcc-c++ makeuseradd -s /sbin/nologin -M zabbix#编译安装
cd /opt/zabbix-6.0.13/./configure \
--sysconfdir=/etc/zabbix/ \
--enable-server \
--with-mysql \
--with-net-snmp \
--with-libxml2 \
--with-ssh2 \
--with-openipmi \
--with-zlib \
--with-libpthread \
--with-libevent \
--with-openssl \
--with-ldap \
--with-libcurl \
--with-libpcremake install

在这里插入图片描述

2.9 修改zabbix server配置文件,修改密码

vim /etc/zabbix/zabbix_server.conf 
......
LogFile=/var/log/zabbix_server.log		# 38行,指定 zabbix 日志路径,需要去/var/log下面创建zabbix_server.log文件,并且给权限777
DBPassword=zabbix					# 123行,指定 zabbix 数据库的密码

在这里插入图片描述
在这里插入图片描述

准备 systemctl 服务管理文件
cat > /usr/lib/systemd/system/zabbix-server.service << EOF
[Unit]
Description=Zabbix Server with MySQL DB
After=syslog.target network.target mysqld.service[Service]
Type=simple
ExecStart=/usr/local/sbin/zabbix_server -f
User=zabbix[Install]
WantedBy=multi-user.target
EOFsystemctl daemon-relead
systemctl enable --now zabbix-servernetstat -lntp | grep 10051			#zabbix_server 默认监听 10051 端口

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

2.10 部署web前端进行访问

cp -r /opt/zabbix-6.0.13/ui/* /var/www/zbxchown -R nginx.nginx /var/www/zbx浏览器访问:http://zbx.kgc.com/ 
【Default language】选择 Chinese(zh_CN),点击下一步
【密码】输入 zabbix,点击下一步
【Zabbix主机名称】输入 Zabbix-监控;【默认时区】选择 Asia/Shanghai,点击下一步安装完成后,默认的登录账号和密码为:Admin/zabbix

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

3 安装Zabbix客户端

3.1 安装客户端

rpm -ivh https://repo.zabbix.com/zabbix/6.0/rhel/7/x86_64/zabbix-release-6.0-4.el7.noarch.rpm
sed -i 's#https://repo.zabbix.com#https://mirrors.aliyun.com/zabbix#' /etc/yum.repos.d/zabbix.repo#zabbix 5.0 版本开始采用 golang 语言开发的新版本客户端 agent2
yum install -y zabbix-agent2systemctl enable --now zabbix-agent2netstat -lntp | grep 10050			#客户端 zabbix_agent2 默认监听 10050 端口

在这里插入图片描述
在这里插入图片描述

3.2 解决中文乱码问题

yum install -y wqy-microhei-fonts\cp -f /usr/share/fonts/wqy-microhei/wqy-microhei.ttc /var/www/zbx/assets/fonts/DejaVuSans.ttf刷新浏览器页面

在这里插入图片描述
在这里插入图片描述


4 添加Zabbix客户端主机

4.1 服务端和客户端配置时间同步

yum install -y ntpdate
ntpdate -u ntp.aliyun.com 

在这里插入图片描述
在这里插入图片描述

4.2 服务端和客户端设置hosts解析

cat > /etc/hosts << EOF
192.168.146.20 zbx-server
192.168.146.30 zbx-agent01
EOF

在这里插入图片描述
在这里插入图片描述

4.3 设置zabbix的下载源,安装zabbix-agent2

rpm -ivh https://repo.zabbix.com/zabbix/6.0/rhel/7/x86_64/zabbix-release-6.0-4.el7.noarch.rpm
sed -i 's#https://repo.zabbix.com#https://mirrors.aliyun.com/zabbix#' /etc/yum.repos.d/zabbix.repoyum install -y zabbix-agent2

在这里插入图片描述

4.4 修改agent2配置文件

vim /etc/zabbix/zabbix_agent2.conf
......
Server=192.168.146.20			#146行,指定 zabbix 服务端的 IP 地址
ServerActive=192.168.146.20		#133行,指定 zabbix 服务端的 IP 地址
Hostname=zbx-agent01			#144行,指定当前 zabbix 客户端的主机名

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

4.5 启动zabbix-agent2

systemctl start zabbix-agent2
systemctl enable zabbix-agent2netstat -natp | grep zabbix
tcp6       0      0 :::10050                :::*                    LISTEN      43654/zabbix_agent2 

在这里插入图片描述

4.6 服务端验证zabbix-agent2连通性

yum install -y zabbix-get				#安装 zabbix 主动获取数据的命令zabbix_get -s '192.168.146.30' -p 10050 -k 'agent.ping'
1zabbix_get -s '192.168.146.30' -p 10050 -k 'system.hostname'
zbx-agent01

在这里插入图片描述

4.7 Web页面添加agent主机

点击左边菜单栏【配置】中的【主机】,点击【创建主机】
【主机名称】输入 zbx-agent01
【可见的名称】输入 zbx-agent01-192.168.146.30
【模板】搜索 Linux ,选择 Linux by Zabbix agent
【群组】选择 Linux servers
【Interfaces】点击添加 客户端,【IP地址】输入 192.168.146.30

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

找工作不用愁!送你一份Salesforce顾问面试秘籍(下)(含答案)

作为SaaS行业的先驱&#xff0c;Salesforce的发展一路高歌猛进。在Salesforce生态系统中不仅能学习到最新的技术&#xff0c;而且比其他行业的同岗位享有更高的薪水&#xff0c;这也驱使了越来越多人加入Salesforce大军。 在之前的文章中&#xff0c;自由侠部落为学习者梳理了…

奥威BI-金蝶云星空SaaS版一站式平台:对接数据、做分析

金蝶云星空和BI大数据分析平台都在企业数字化转型中扮演了重要的角色&#xff0c;为企业提供了全面的数字化解决方案和数据分析功能&#xff0c;两者强强联合不仅能提高部署效率&#xff0c;更能增强数据分析、数据可视化效果&#xff0c;帮助企业更好地适应市场变化和用户需求…

Arcgis Pro NDVI(植被指数)导出RGB

在arcgis中计算的NDVI栅格数据&#xff0c;取值范围为-1到1&#xff0c;直接导出JPG或者PNG&#xff0c;会出现导出错误的问题&#xff1a; 导出出错&#xff0c; 设置导出格式为TIFF&#xff0c;然后选中使用渲染器&#xff0c;勾选强制RGB颜色&#xff0c;即可导出你选择的色…

【C++STL】list的反向迭代器

list的反向迭代器 文章目录 list的反向迭代器reverse.h疑问1&#xff1a;为什么在迭代器当中不需要写深拷贝、析构函数疑问2&#xff1a;为什么在迭代器当中需要三个模板参数&#xff1f;疑问3&#xff1a;反向迭代器是怎么实现的&#xff1f;疑问4&#xff1a;为什么*解引用不…

创建UI组件库后上传NPM

上篇已经讲了如何创建自己的组件库&#xff0c;这篇讲怎么上传npm后&#xff0c;可以下载使用 1.首先看下组件的文件结构 在index.js中要写上每个组件可以按需引用的条件 import Button from "./src/button";Button.install function(Vue) {Vue.component(Button.…

Kubernetes 容器类型 Init - pause - sidecar - app容器

目录 Kubernetes 的容器类型 Init 初始化容器 参考文档&#xff1a;Init 容器 | Kubernetes 使用 Init 容器的情况 案例&#xff1a;定义了一个具有 2 个 Init 容器的简单 Pod 你通过运行下面的命令启动 Pod&#xff1a; 发现两个Init容器都没有运行成功 查看更多详细…

Mycat【什么是Mycat、Mycat与其他中间件区别、Mycat应用场景、核心概念详解、Mycat原理】(一)-全面详解(学习总结---从入门到深化)

目录 Mycat概述_什么是Mycat Mycat概述_Mycat与其他中间件区别 Mycat概述_Mycat应用场景 Mycat概念_核心概念详解 Mycat概述_Mycat原理 Mycat部署安装_MySQL主从复制概述 Mycat概述_什么是Mycat 什么是Mycat Mycat是数据库中间件&#xff0c;所谓中间件数据库中间件是连…

Oracle语句优化 (汇总)

大部分写sql语句都是为了实现而实现&#xff0c;如果最后在投入使用的过程中没有很难接受的性能&#xff0c;基本不怎么去考虑其性能。最近刚好有点时间&#xff0c;对优化方面进修进修&#xff0c;以备不时之需。 选择最有效率的表名顺序 Oracle的解析器按照从右到左的顺序处…

欧姆龙以太网口怎么和电脑连接

捷米特JM-ETH-CP以太网通讯处理器用于欧姆龙 CP1L/ CP1E/ CP1H 系列 PLC 的以太网数据采集&#xff0c;捷米特JM-ETH-CP以太网模块不占用 PLC 通讯口&#xff0c;即编程软件/上位机软件通过以太网对 PLC 数据监控的同时&#xff0c;触摸屏可以通过复用接口与 PLC 进行通讯。支持…

MyBatis查询数据库(1)

前言&#x1f36d; ❤️❤️❤️SSM专栏更新中&#xff0c;各位大佬觉得写得不错&#xff0c;支持一下&#xff0c;感谢了&#xff01;❤️❤️❤️ Spring Spring MVC MyBatis_冷兮雪的博客-CSDN博客 经过前⾯的学习咱们 Spring 系列的基本操作已经实现的差不多了&#xff0…

光伏5G多合一融合终端|光伏多合一融合终端|光伏多合一群调群控网关|分布式光伏群控群调|光伏AGC/AVC系统这几者之间什么技术关系,多少钱一套预算?

光伏5G多合一融合终端|光伏多合一融合终端|光伏多合一群调群控网关|分布式光伏群控群调|光伏AGC/AVC系统这几者之间什么技术关系&#xff0c;多少钱一套预算&#xff1f; 一&#xff1a;光伏5G多合一融合终端的功能 光伏5G多合一融合终端的功能&#xff1a;群调群控/AGC/AVC功…

【数据结构与算法】栈算法题

TS 实现栈 interface IStack<T> {push(e: T): void;pop(): T | undefined;peek(): T;isEmpyt(): boolean;size(): number; }// implements: 实现接口, 一个类可以实现多个接口 class ArrayStack<T> implements IStack<T> {private data: T[] []; // private…