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