云计算、AI、云原生、大数据等一站式技术学习平台

网站首页 > 教程文章 正文

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

jxf315 2025-04-06 17:21:30 教程文章 40 ℃

很抱歉大家,昨天没有更新文章,是因为我在整理一些资料和在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目录,

最近发表
标签列表