百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术教程 > 正文

超级详细的zabbix环境搭建和测试(看我的教程,大神你也可以)

mhr18 2025-01-13 15:37 16 浏览 0 评论

很抱歉大家,昨天没有更新文章,是因为我在整理一些资料和在centos7中搭建zabbix环境。

相信很多人都不愿意花较多的时间浪费在环境部署中,所以我愿意帮大家先整理好这个zabbix教程,希望大家节省更多的时间,(其中自己踩了很坑,也学习了,很棒!)也很愿意分享。其中的步骤非常的详细,当然也许你也会遇到一点的小问题,请留言,必回!!!

好了,重点来了,以下全部是详细的步骤!

1:第一步我们创建两个虚拟机,我们的zabbix-server和zabbix-agent(当然名字随意)


2:ssh 连接服务器

ssh root@your ip -p 22(默认端口)如图连接成功并ping www.baidu.com成功


3:安装nginx编译所需的lib库

yum -y install make zlib zlib-devel gcc-c++ libtool openssl openssl-devel
yum -y install pcre pcre-devel



4:查看pcre(正则库)版本

pcre-config --version

5:进入编译目录

cd /usr/local/src

6:从官网下载最新的nginx(stable version稳定版) 这里我安装的是1.16 .1 大家可以换成自己想要的版本

wget http://nginx.org/download/nginx-1.16.1.tar.gz

7:解压nginx压缩包

tar -zxvf nginx-1.16.1.tar.gz

8:进入解压目录

cd  nginx-1.16.1


9:运行配置脚本(--prefix参数指定nginx安装的目录,默认安装在/usr/local/nginx )

./configure --prefix=/usr/local/nginx --with-http_ssl_module

10:编译安装nginx

make && make install

11:nginx执行命令软链接到/usr/bin

ln -s /usr/local/nginx/sbin/nginx /usr/bin

12:启动nginx

nginx

13:设置开机自启动

echo "/usr/local/nginx/sbin/nginx" >> /etc/rc.d/rc.local
chmod +x /etc/rc.d/rc.local

14:查看版本 (切换到nginx 安装的目录下执行 nginx -v)

以上是nginx 安装的全部过程!!!!

打开服务器ip:如图显示就是成功了

注意安装后请把防火墙关闭,或者开通80,443端口


二:这里我们开始MySQL的安装:

2.1 安装 mysql 源

# 下载
 wget https://dev.mysql.com/get/mysql57-community-release-el7-11.noarch.rpm
# 安装 mysql 源
yum localinstall mysql57-community-release-el7-11.noarch.rpm

2.2 用下面的命令检查 mysql 源是否安装成功

 yum repolist enabled | grep "mysql.*-community.*"

2.3 安装 MySQL

使用 yum install 命令安装

 yum install -y mysql-community-server

2.4 启动 MySQL 服务

在 CentOS 7 下,新的启动/关闭服务的命令是 systemctl start|stop

systemctl start mysqld

systemctl status 查看 MySQL 状态

 systemctl status mysqld

2.5 设置开机启动

systemctl enable mysqld

2.6 修改 root 本地账户密码

mysql 安装完成之后,生成的默认密码在 /var/log/mysqld.log 文件中。使用 grep 命令找到日志中的密码。

 grep 'temporary password' /var/log/mysqld.log


首次通过初始密码登录后,使用以下命令修改密码

 mysql -uroot -p
mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY 'MyNewPass4!'; 

或者

mysql> set password for 'root'@'localhost'=password('MyNewPass4!'); 

以后通过 update set 语句修改密码

mysql> use mysql;
mysql> update user set password=PASSWORD('MyNewPass5!') where user='root';
mysql> flush privileges;


注意:mysql 5.7 默认安装了密码安全检查插件(validate_password),默认密码检查策略要求密码必须包含:大小写字母、数字和特殊符号,并且长度不能少于8位。否则会提示 ERROR 1819 (HY000): Your password does not satisfy the current policy requirements 错误。查看 MySQL官网密码详细策略

2.7 添加远程登录用户

默认只允许root帐户在本地登录,如果要在其它机器上连接mysql,必须添加一个允许远程连接的帐户。或者修改 root 为允许远程连接(不推荐)

添加一个允许远程连接的帐户

mysql> GRANT ALL PRIVILEGES ON *.* TO 'zhangsan'@'%' IDENTIFIED BY 'Zhangsan2018!' WITH GRANT OPTION;

修改 root 为允许远程连接(不推荐)

mysql> use mysql;
mysql> UPDATE user SET Host='%' WHERE User='root';
mysql> flush privileges;


三:这里我们开始PHP的安装:

3.1 检查当前安装的PHP包

yum list installed | grep php


3.2如果有安装的PHP包,先删除他们

yum remove php*

3.3更换rpm源

 rpm -Uvh https://mirror.webtatic.com/yum/el7/epel-release.rpm
 rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm

3.4 如果想删除上面安装的包,重新安装

rpm -qa | grep php
rpm -e  上面搜索到的包即可

3.5运行yum install

yum install php70w.x86_64 php70w-cli.x86_64 php70w-common.x86_64 php70w-gd.x86_64 php70w-ldap.x86_64 php70w-mbstring.x86_64 php70w-mcrypt.x86_64 php70w-mysql.x86_64 php70w-pdo.x86_64

3.6.安装PHP FPM

yum install php70w-fpm
systemctl enable php-fpm.service【开机自启动】

4 zabbix服务端安装

4.1 下载安装zabbix
所有版本下载地址:http://www.zabbix.com/download.php

1

2

3

4

5

6

7

8

9

# yum install net-snmp-devel libxml2-devel libcurl-devel // 一定先安装依赖

# cd /usr/local/src

# wget "http://downloads.sourceforge.net/project/zabbix/ZABBIX%20Latest%20Stable/2.2.2/zabbix-2.2.2.tar.gz?r=http%3A%2F%2Fwww.zabbix.com%2Fdownload.php&ts=1395066528&use_mirror=jaist"

# tar -xzvf zabbix-2.2.2.tar.gz

# cd zabbix-2.2.2

# ./configure --prefix=/usr/local/zabbix-2.2.2/ --enable-server \

--enable-agent --with-mysql --with-net-snmp --with-libcurl --with-libxml2

# make

# make install

在zabbix server一般充当两个角色:server、angent,所以上面的配置参数也同时加上了--enable-agent。
备注:请安装好MySQL,snmp,curl开发库。

4.2 创建用户
为了安全考虑zabbix只使用普通用户运行,假如你当前用户叫ttlsa,那么你运行他,他便使用ttlsa身份运行。但是如果你在root环境下运行zabbix,那么zabbix将会主动使用zabbix用户来运行。但是如果你的系统没有名叫zabbix的用户,你需要创建一个用户,如下:
# groupadd zabbix
# useradd -g zabbix zabbix

4.3 初始化数据库
zabbix server与proxy需要数据库,angent不需要。尤其要注意的是proxy只需要导入一个sql文件,而server一共要导入3个sql文件。我当时在搭建proxy的时候导入了3个sql,导致出现报错。后来才发现proxy只需要导入一个表结构即可。

我假想你安装好了MySQL,用户名为root,密码为ttlsapwd

1

2

3

4

# mysql -uroot -pttlsapwd

mysql> create database zabbix default charset utf8;

mysql> quit;

# mysql -uroot -pttlsapwd zabbix < database/mysql/schema.sql

备注:创建数据库请别忘记加default charset utf8,有可能会导致你出现中文乱码问题,具体问题请查看《zabbix中文乱码解决方法》

如果你仅仅是初始化proxy的数据库,那么够了。如果初始化server,那么接着导入下面两个sql

1

2

# mysql -uroot -pttlsapwd zabbix < database/mysql/images.sql

# mysql -uroot -ppttlsapwd zabbix < database/mysql/data.sql

其他数据库(db2\sqlite\oracle)数据库初始化方法参考:https://www.zabbix.com/documentation/2.2/manual/appendix/install/db_scripts

4.4 配置zabbix
配置zabbix_server配置文件,zabbix源码目录下

1

2

3

4

5

6

7

# mkdir /etc/zabbix

# cp config/zabbix_server.conf /etc/zabbix/

# vim /etc/zabbix/zabbix_server.conf

DBName=zabbix

DBUser=root

DBPassword=ttlsapwd

DBPort=3306

4.5 启动zabbix server

1

# /usr/local/zabbix-2.2.2/sbin/zabbix_server

默认端口10051


好了以上全部是zabbix 服务器端的环境安装,然后我们输入IP:/zabbix,会看见如图所示,这里我已经验证了,所以我们可以直接登录,大家在研制的时间根据提示需要下载一个zabbix.conf.php文件到nginx目录,

相关推荐

Spring Boot 分布式事务实现简单得超乎想象

环境:SpringBoot2.7.18+Atomikos4.x+MySQL5.71.简介关于什么是分布式事务,本文不做介绍。有需要了解的自行查找相关的资料。本篇文章将基于SpringBoot...

Qt编写可视化大屏电子看板系统15-曲线面积图

##一、前言曲线面积图其实就是在曲线图上增加了颜色填充,单纯的曲线可能就只有线条以及数据点,面积图则需要从坐标轴的左下角和右下角联合曲线形成完整的封闭区域路径,然后对这个路径进行颜色填充,为了更美观...

Doris大数据AI可视化管理工具SelectDB Studio重磅发布!

一、初识SelectDBStudioSelectDBStudio是专为ApacheDoris湖仓一体典型场景实战及其兼容数据库量身打造的GUI工具,简化数据开发与管理。二、Select...

RAD Studio 、Delphi或C++Builder设计代码编译上线缩短开发时间

#春日生活打卡季#本月,Embarcadero宣布RADStudio12.3Athens以及Delphi12.3和C++Builder12.3,提供下载。RADStudio12.3A...

Mybatis Plus框架学习指南-第三节内容

自动填充字段基本概念MyBatis-Plus提供了一个便捷的自动填充功能,用于在插入或更新数据时自动填充某些字段,如创建时间、更新时间等。原理自动填充功能通过实现com.baomidou.myba...

「数据库」Sysbench 数据库压力测试工具

sysbench是一个开源的、模块化的、跨平台的多线程性能测试工具,可以用来进行CPU、内存、磁盘I/O、线程、数据库的性能测试。目前支持的数据库有MySQL、Oracle和PostgreSQL。以...

如何选择适合公司的ERP(选erp系统的经验之谈)

很多中小公司想搞ERP,但不得要领。上ERP的目的都是歪的,如提高效率,减少人员,堵住财务漏洞等等。真正用ERP的目的是借机提升企业管理能力,找出管理上的问题并解决,使企业管理更规范以及标准化。上ER...

Manus放开注册,但Flowith才是Agent领域真正的yyds

大家好,我是运营黑客。前天,AIAgent领域的当红炸子鸡—Manus宣布全面放开注册,终于,不需要邀请码就能体验了。于是,赶紧找了个小号去确认一下。然后,额……就被墙在了外面。官方解释:中文版...

歌浓酒庄总酿酒师:我们有最好的葡萄园和最棒的酿酒师

中新网1月23日电1月18日,张裕董事长周洪江及总经理孙健一行在澳大利亚阿德莱德,完成了歌浓酒庄股权交割签约仪式,这也意味着张裕全球布局基本成型。歌浓:澳大利亚年度最佳酒庄据悉,此次张裕收购的...

软件测试进阶之自动化测试——python+appium实例

扼要:1、了解python+appium进行APP的自动化测试实例;2、能根据实例进行实训操作;本课程主要讲述用python+appium对APP进行UI自动化测试的例子。appium支持Androi...

为什么说Python是最伟大的语言?看图就知道了

来源:麦叔编程作者:麦叔测试一下你的分析能力,直接上图,自己判断一下为什么Python是最好的语言?1.有图有真相Java之父-JamesGoshlingC++之父-BjarneStrou...

如何在Eclipse中配置Python开发环境?

Eclipse是著名的跨平台集成开发环境(IDE),最初主要用来Java语言开发。但是我们通过安装不同的插件Eclipse可以支持不同的计算机语言。比如说,我们可以通过安装PyDev插件,使Eclip...

联合国岗位上新啦(联合国的岗位)

联合国人权事务高级专员办事处PostingTitleIntern-HumanRightsDutyStationBANGKOKDeadlineOct7,2025CategoryandL...

一周安全漫谈丨工信部:拟定超1亿条一般数据泄露属后果严重情节

工信部:拟定超1亿条一般数据泄露属后果严重情节11月23日,工信部官网公布《工业和信息化领域数据安全行政处罚裁量指引(试行)(征求意见稿)》。《裁量指引》征求意见稿明确了行政处罚由违法行为发生地管辖、...

oracle列转行以及C#执行语句时报错问题

oracle列转行的关键字:UNPIVOT,经常查到的怎么样转一列,多列怎么转呢,直接上代码(sshwomeyourcode):SELECTsee_no,diag_no,diag_code,...

取消回复欢迎 发表评论: