很抱歉大家,昨天没有更新文章,是由于我在整理一些资料和在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 |
其他数据库(db2sqliteoracle)数据库初始化方法参考:
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目录,




跟着大佬学习学习
收藏了,感谢分享