微信公众号:运维开发故事,作者:wanger


安装zabbix-server

添加zabbix存储库

rpm -ivh https://repo.zabbix.com/zabbix/4.0/rhel/7/x86_64/zabbix-release-4.0-1.el7.noarch.rpm
yum -y install yum-utils
yum-config-manager --enable rhel-7-server-optional-rpm

安装zabbix-server zabbix-web

yum install zabbix-server-mysql
yum install zabbix-web-mysql

安装MySQL5.7数据库

卸载mariadb包

rpm -qa |grep mariadb    #查看当前安装的mariadb的包
rpm -e --nodeps mariadb-libs-5.5.52-1.el7.x86_64     #卸载mariadb的包

下载并解压MySQL源码包

wget https://dev.mysql.com/get/archives/mysql-5.7/mysql-5.7.21-linux-glibc2.12-x86_64.tar.gz
#从官网下载源码包
tar -xzvf  mysql-5.7.21-linux-glibc2.12-x86_64.tar.gz     #解压源码包
mv  mysql-5.7.21-linux-glibc2.12-x86_64  /usr/local/mysql

创建MySQL用户并对MySQL文件进行授权

groupadd mysql   --创建mysql用户组
useradd -r -g mysql mysql     --创建mysql用户并添加到mysql用户组中
chown -R mysql.mysql mysql/  --将mysql目录访问权限赋为myql用户

创建MySQL配置文件

cat >>/etc/my.cnf  <<EOF
#写入配置文件
[client]
port = 3306
socket = /tmp/mysql.sock
[mysqld]
character_set_server=utf8
init_connect='SET NAMES utf8'
basedir=/usr/local/mysql
datadir=/usr/local/mysql/data
socket=/tmp/mysql.sock
log-error=/var/log/mysqld.log
pid-file=/var/run/mysqld/mysqld.pid
#不区分大小写
lower_case_table_names = 1
sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION
max_connections=5000default-time_zone = '+8:00‘
EOF

初始化数据库

touch /var/log/mysqld.log    #创建日志文件并授权
chmod 777 /var/log/mysqld.log
chown mysql.mysql mysqld.log
/usr/local/mysql/bin/mysqld   --initialize --user=mysql   --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data

查看初始化密码

cat /var/log/mysqld.log|grep root@localhost

执行如下操作开启MySQL服务,并设置相应权限

mkdir /var/run/mysqld
touch /var/run/mysqld/mysqld.pid
chmod -R 777 /var/run/mysqld
chown -R mysql.mysql /var/run/mysqld
/usr/local/mysql/support-files/mysql.server start  #启动MySQL

修改MySQL密码

vim /etc/my.cnf #修改配置文件

skip-grant-tables    #跳过密码认证
default_password_lifetime=360    #修改密码超时时间

不然修改密码之后密码会过期,会提示让你重新设置密码
You must reset your password using ALTER USER statement before executing this statement/usr/local/mysql/bin/mysql -uroot -p #登录MySQL``use mysql #切换MySql数据库

update mysql.user set authentication_string =password('root'), host = '%' where user = 'root'; #修改MySQL密码

flush privileges;

将MySQL加入环境变量

echo 'PATH=/usr/local/mysql/bin:$PATH' >>/etc/profile
#将MySQL二进制文件加入环境变量
ln -s usr/local/mysql/support-files/mysql.server /usr/local/mysql/bin/
#将MySQL的启动文件软连接到MySQL的环境变量中

进入数据库并创建zabbix数据库以及创建授权用户

mysql>  create database zabbix character set utf8 collate utf8_bin;
mysql> grant all privileges on zabbix.* to zabbix@localhost identified by 'zabbix';
mysql> flush privileges;

编辑zabbix-server配置文件

修改以下参数为创建数据库时的信息,并重启zabbix-server
vim /etc/zabbix/zabbix_server.conf

DBName=zabbix
DBHost=192.168.179.132
DBUser=zabbix
DBPassword=zabbix
systemctl enable zabbix-server
systemctl start zabbix-server

启动的时候启动失败,查看系统日志,查找关键词

usr/sbin/zabbix_server: error while loading shared libraries: libmysqcl
ient.so.18: cannot open shared object file: No such file or directory

原来是缺少一个文件,yum安装解决
yum -y install mysql-libs

将初始数据导入MySQL中

zcat /usr/share/doc/zabbix-server-mysql*/create.sql.gz | mysql -uzabbix -p zabbix

安装Nginx

关掉防火墙和selinux

systemctl stop firewalld
systemctl disable firewalld
sed -i 's/SELINUX=enforcing/SELINUX=disable/g' /etc/selinux/config

安装依赖

yum -y install wget vim lsof lrzsz pcre-devel zlib-devel make gd-devel libjpeg-devel libpng-devel libxml2-devel bzip2-devel libcurl-devel libmcrypt libmcrypt-devel mcrypt mhash net-snmp-devel
yum -y install gcc bison bison-devel openssl-devel readline-devel libedit-devel sqlite-devel freetype freetype-devel libevent-devel mysql-devel

配置Nginx的yum仓库

cat >>/etc/yum.repos.d/nginx.repo <<EOF
[nginx]
name=nginx.repo
baseurl=http://nginx.org/packages/centos/7/$basearch/
gpgcheck=0
enabled=1
skip_if_unavailable = 1
keepcache = 0
EOF

启动Nginx

nginx -t  测试配置是否有错
systemctl start nginx
systemctl enable nginx

安装PHP

添加PHP用户

useradd -s /sbin/nologin php-fpm

安装PHP依赖库

yum install -y gcc gcc-c++ make zlib zlib-devel pcre pcre-devel libjpeg libjpeg-devel libpng libpng-devel freetype freetype-devel libxml2 libxml2-devel glibc glibc-devel glib2 glib2-devel bzip2 bzip2-devel ncurses ncurses-devel curl curl-devel e2fsprogs e2fsprogs-devel krb5 krb5-devel openssl openssl-devel openldap openldap-devel nss_ldap openldap-clients openldap-servers#### 编译安装phpwget http://mirrors.sohu.com/php/php-7.2.6.tar.gz
tar zxvf php-7.2.6.tar.gz
cd php-7.2.6
./configure --prefix=/usr/local/php --with-config-file-path=/usr/local/php/etc --enable-fpm --with-fpm-user=php-fpm --with-fpm-group=php-fpm --with-mysql=mysqlnd  --with-pdo-mysql=mysqlnd --with-mysqli=mysqlnd --with-libxml-dir --with-gd --with-jpeg-dir --with-png-dir --with-freetype-dir --with-iconv-dir --with-zlib-dir --with-mcrypt --enable-soap --enable-gd-native-ttf --enable-ftp --enable-mbstring --enable-exif --disable-ipv6 --with-pear --with-curl --enable-bcmath --enable-mbstring --enable-sockets --with-gd --with-libxml-dir=/usr/local --with-gettext
make && make install
echo $? #每执行完上条命令就运行一下,如果返回0,则执行成功
cp php.ini-production /usr/local/php/etc/php.ini

更改PHP配置文件

sed -i 's/post_max_size = 8M/post_max_size = 32M/g' /usr/local/php/etc/php.ini
sed -i 's/upload_max_filesize = 2M/upload_max_filesize = 50M/g' /usr/local/php/etc/php.ini
sed -i 's/;date.timezone =/date.timezone =PRC/' /usr/local/php/etc/php.ini
sed -i 's/max_execution_time = 30/max_execution_time = 600/g' /usr/local/php/etc/php.ini
sed -i 's/max_input_time = 60/max_input_time = 600/g' /usr/local/php/etc/php.ini
sed -i 's/memory_limit = 128M/memory_limit = 256M/g' /usr/local/php/etc/php.ini

启动php-fpm

cp /usr/local/php/etc/php-fpm.conf.default /usr/local/php/etc/php-fpm.conf
cp /usr/local/php/etc/php-fpm.d/www.conf.default  /usr/local/php/etc/php-fpm.d/www.conf
/usr/local/php/sbin/php-fpm -c /usr/local/php/etc/php.ini -y /usr/local/php/etc/php-fpm.conf

vim phpinfo.php

<?php
phpinfo();
?>

测试是否能连接nginx,这里出现一个错误,访问动态页面一直显示文件没有发现,修改nginx配置文件的PHP脚本路径变量和修改文件权限后一直没有用,后来我将路径的变量去掉,添加网站真实路径后解决

安装zabbix-agent

yum install zabbix-agent
vim /etc/zabbix/zabbix-agentd.conf
#Server和ServerActive分别代表zabbix的被动模式和主动模式,这里都填server端的IP
最后一行是开启脚本采集数据

安装zabbix-web

将zabbix的php源文件拷贝到网站目录上

cp -r /usr/share/zabbix/.* /usr/share/nginx/html/

修改nginx配置

egrep -v ‘(.*#|$)’ /etc/nginx/conf.d/default.conf

server {listen       80;server_name  192.168.179.132;access_log  /var/log/nginx/host.access.log  main;location / {root   /usr/share/nginx/html;index  index.html index.htm index.php;}error_page  404              /404.html;location ~ \.php$ {root           html;fastcgi_pass   127.0.0.1:9000;fastcgi_index  index.php;fastcgi_param  SCRIPT_FILENAME  /usr/share/nginx/html$fastcgi_script_name;include        fastcgi_params;}
}

重启nginx访问会报这个错

百度之后得知是权限不足引起的,运行一下命令可以解决,这里一定要777,不然到时候安装完成不能创建配置文件

chmod -R 777 /etc/zabbix/web

在访问浏览器的时候不出图,请教我学长之后得出是因为nginx上配置了图片缓存,去掉缓存解决

访问192.168.179.132/index.php安装zabbix-web

安装完成可能会遇到连接不上zabbix-server的错误,查看zabbix-server日志如下,这个解决方法有两种,第一种就是创建一个mysql.sock然后重启mysql服务器

mkdir /var/lib/mysql
ln -s /tmp/mysql.sock /var/lib/mysql/mysql.sock

第二种就是编辑zabbix_server.conf文件,将DBSocket修改为自己数据库的mysql.sock,然后重启 zabbix_server

监控zabbix 本机的CPU idle

监控CPU idle
基本就是图形界面,创建监控项之前先测试一下key值是否可用,当然需要安装zabbix_get工具,使用yum install zabbix-get来安装

zabbix_get -s 192.168.179.132 -k system.cpu.util[all,idle,avg1]

自建模板监控磁盘IO

监控磁盘IO利用的工具是iostat
yum install -y sysstat

首先zabbix-agent端要开启允许脚本收集监控数据

编辑zabbix-agent的配置文件
vim /etc/zabbix/zabbix_agentd.d/userparameter.conf

UserParameter=disk.status[*],/usr/local/zabbix/scripts/disk-status.sh $1

编写收集脚本

vim /usr/local/zabbix/scripts/disk-status.sh

#!/bin/bash if [ $# -ne 1 ];thenecho "Follow the script name with an argument"
ficase $1 inrrqm)iostat -dxk 1 1|grep -w sda |awk '{print $2}';;wrqm)iostat -dxk 1 1|grep -w sda |awk '{print $3}';;rps)iostat -dxk 1 1|grep -w sda|awk '{print $4}';;wps)iostat -dxk 1 1|grep -w sda |awk '{print $5}';;rKBps)iostat -dxk 1 1|grep -w sda |awk '{print $6}';;wKBps)iostat -dxk 1 1|grep -w sda |awk '{print $7}';;avgrq-sz)iostat -dxk 1 1|grep -w sda |awk '{print $8}';;avgqu-sz)iostat -dxk 1 1|grep -w sda |awk '{print $9}';;await)iostat -dxk 1 1|grep -w sda|awk '{print $10}';;svctm)iostat -dxk 1 1|grep -w sda |awk '{print $13}';;util)iostat -dxk 1 1|grep -w sda |awk '{print $14}';;*) echo -e "\e[033mUsage: sh $0 [rrqm|wrqm|rps|wps|rKBps|wKBps|avgqu-sz|avgrq-sz|await|svctm|util]\e[0m"
esac

touch +x /usr/local/zabbix/scripts/disk-status.sh #给脚本添加执行权限

打开zabbix-web,创建模板

浏览器打开192.168.179.132/index.php
依次点击配置—>模板—>创建模板
添加模板名称以及群组,最后点击添加

创建应用集

在创建的模板上点击创建应用集,名字最好与磁盘io相关

创建监控项

这里所有的数据类型都是浮点数

创建图形

这需要为每一个监控项都创建图形

为需要监控的主机链接模板

点击需要监控的主机,然后单击模板,为主机添加模板链接

解决图形名字乱码问题

可以看到我收集到的图形是乱码的
首先查看zabbix字体目录,它定义的路径是“fonts”,它是一个相对路径,绝对路径为/usr/share/zabbix/fonts,
vim /usr/share/zabbix/include/defines.inc.php //搜索ZBX_FONTPATH

而字体文件为“ZBX_GRAPH_FONT_NAME”所定义的“graphfont”,它是一个文件,绝对路径为/usr/share/zabbix/fonts/graphfont.ttf
我们可以从Windows系统中选择一个中文字体然后放到zabbix的字体目录下
Windows字体目录位于C:\Windows\Fonts下,找到仿宋常规字体将他拷入zabbix字体目录下
然后修改PHP文件,将字体文件修改为simsong

安装elastic6.1

下载源码包并解压,修改es配置

yum install java    #elastic需要安装Java依赖
curl -L -O https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-6.1.4.tar.gz
tar -xvf elasticsearch-6.1.4.tar.gz

vim /root/elasticsearch-6.1.4/config/elasticsearch.yml #主要修改es的一些配置信息

启动过程出现的报错

[WARN ][o.e.b.BootstrapChecks    ] [PWm-Blt] max file descriptors [4096]for elasticsearch process is too low, increase to at least [65536]

解决办法:
vim /etc/security/limits.conf

* soft nofile 65536
* hard nofile 131072
* soft nproc 2048
* hard nproc 4096

[WARN ][o.e.b.BootstrapChecks ] [PWm-Blt] max virtual memory areas
vm.max_map_count [65530] is too low, increase to at least [262144]


解决办法:
vim /etc/sysctl.conf
`vm.max_map_count=655360`
修改完成执行命令:
sysctl -p
cd elasticsearch-6.1.4/bin
这里不能使用root用户运行elastic,可以自己新建一个普通用户,还要把目录授予普通用户权限
./elasticsearch
然后我们可以打开浏览器输入192.168.179.133:9200可以查看es的状态,或者可以装一个head插件### 安装head插件#### 安装node.js这里我采用的源码安装,其实二进制安装是比较简单的,但我执行到最后node的二进制文件无法执行,因此只能源码安装,时间有点长,打了两局王者荣耀才装完

yum groupinstall “Development Tools” #安装编译必要的工具
wget https://nodejs.org/dist/v8.11.4/node-v8.11.4.tar.gz
#下载node的源码包
tar -zxvf node-v8.11.4.tar.gz #解压源码包
cd node-v8.11.4
./configure && make && make install #执行编译安装
echo $? #查看执行结果,输出0表示安装成功


node.js默认安装路径在/usr/local/bin/目录下#### 安装gruntgrunt是基于Node.js的项目构建工具,可以进行打包压缩、测试、执行等等的工作,head插件就是通过grunt启动
`npm install -g grunt-cli`#### 下载并安装head插件

git clone git://github.com/mobz/elasticsearch-head.git
#克隆head插件仓库
cd elasticsearch-head/
npm install #执行完会报一些错误,不要管执行下一条命令就会解决

npm install phantomjs-prebuilt@2.1.14 --ignore-scripts


#### 修改elasticsearch的配置vim /elasticsearch/elasticsearch-6.4.0/config/elasticsearch.yml

http.cors.enabled: true # elasticsearch中启用CORS
http.cors.allow-origin: "" # 允许访问的IP地址段, 为所有IP都可以访问


#### 启用head插件并在浏览器上打开npm run start    #启动head插件
在浏览器输入http://192.168.179.133:9100/ 即可使用head插件### 使用es存储zabbix的历史数据#### 修改/etc/zabbix/zabbix\_server.conf添加如下内容

HistoryStorageURL=192.168.179.133:9200
HistoryStorageTypes=str,text,log,uint,dbl
HistoryStorageDateIndex=1


#### 修改/etc/zabbix/web/zabbix.conf.php添加如下内容

global $DB, $HISTORY;
$HISTORY[‘url’] = ‘http://192.168.179.133:9200’;
// Value types stored in Elasticsearch.
$HISTORY[‘types’] = [‘str’, ‘text’, ‘log’,‘uint’,‘dbl’];


![图片](https://img-blog.csdnimg.cn/img_convert/c32c75f132de4343667b157aa9fff085.png)#### 修改完成后重启zabbix,并查看zabbix是否有数据  `systemctl restart zabbix-server`  ![图片](https://img-blog.csdnimg.cn/img_convert/a67270f3599f4eb0f480968456911b1b.png)至此,es收集zabbix历史数据完成* * *欢迎各位对文章和我提出宝贵意见,觉得不错可以动手转发支持一下公众号

使用LNMP搭建Zabbix并对接Elasticsearch相关推荐

  1. 实操:基于LNMP搭建zabbix监控

    文章目录 一:环境准备: 二:zabbix概述 2.1 查看官网 2.2 zabbix与nagios 2.3 zzbbix介绍 2.4 zabbix软件包 三:基于LNMP搭建zabbix 3.1 创 ...

  2. Lnmp搭建zabbix运维监控系统

    使用目的? 在公司项目中需要做一个日志监控,最开始选择的是efk,但是efk的资料相对较少并且之前对这几个产品都没接触过,使用起来难度.于是选择了zabbix作为项目的运维监控系统. zabbix能做 ...

  3. Linux监控平台搭建Zabbix(资源)

    2019独角兽企业重金招聘Python工程师标准>>> 自动化监控: 1.cobbler实现自动装机 2.saltstack实现工程自动化配置 3.kubernetes实现容器自动化 ...

  4. zabbix3.0 监控php,CentOS 6.8 搭建Zabbix 3.0.3监控系统

    系统环境:CentOS 6.8,LNMP,zabbix 3.0.3 一.前言 Zabbix是一个企业级的,开源的.分布式的监控套件,可监控Linux,Windows,交换路由设备等,其已成为时下最主流 ...

  5. CentOS 6.6 搭建Zabbix 3.0.3 过程

    分享CentOS 6.6下搭建Zabbix 3.0.3 的过程,希望都大家有所帮助. 环境安装 系统环境: # cat /etc/RedHat-release  CentOS release 6.6 ...

  6. 搭建zabbix监控系统

    要想实时的了解服务器的运行状况并且能在出现问题时及时解决,利用监控软件是一个很好的选择,而zabbix监控系统则在众多监控软件中脱颖而出. zabbix是一个基于web界面的企业级开源监控软件,Zab ...

  7. 基于 LNMP 部署 Zabbix 集中监控系统(图文详解,篇幅较长!)

    文章目录 一.Zabbix 概述 二.安装配置 Zabbix 服务 1.环境概述 2.关闭防火墙/安全机制/网络管理工具 3.搭建 LNMP 架构 ①Nginx ②MySQL(MariaDB) ③PH ...

  8. 搭建zabbix监控及邮件报警(超详细教学)

    zhbbix 一.zabbix 1.1 简介 1.2 zabbix主要功能 1.3 zabbix的主要特点 1.4 zabbix组件 1.5 zabbix原理 二.基于LNMP环境搭建zabbix监控 ...

  9. centos 桥接配置 设置网络代理 lnmp搭建

    一.桥接配置 centos设置  编辑->虚拟网络编辑器->桥接模式->还原默认设置 虚拟机->设置->网络适配器->桥接 cd /etc/sysconfig/ne ...

最新文章

  1. 计算机本科学位有用吗_我应该回到学校获得计算机科学学位吗?
  2. 如何用javascript控制上传文件的大小
  3. mysql数据库会同时执行sql吗_mysql 一次执行多条sql语句
  4. 有关调试CRM系统的一些感想
  5. JavaScrip调用腾讯地图
  6. fopen,fopen_s,fclose, _fcloseall函数用法
  7. ckedit 3.0 配置(一)
  8. 统计单词数(信息学奥赛一本通-T1400)
  9. 安卓学习笔记:使用PopupWindow创建简单菜单
  10. opencv-api arcLength
  11. 在window7 64位下Oracle 10g 数据库中PLSQL Developer配置和使用
  12. 蓝桥杯2021国赛太原理工大学获得14枚奖牌
  13. 《软件工程导论》第一章
  14. VAR模型Stata实例操作
  15. 基于内容的图像特征提取系统
  16. 解决BIEE中地图FOI数据过多
  17. oracle 设置 锁模式,oracle表锁的几种模式v$locked_object-locked_mode
  18. AutoCAD2015激活码和密钥
  19. 802.11-2020协议学习__$12-Security__$12.3.2-WEP__1
  20. python 实现获取与下载网页中图片的四种方案

热门文章

  1. oracle 解锁对象,Oracle解锁的方式
  2. 《延禧攻略》那些你不知道的红与黑
  3. 计算机网络管理员 职业技能鉴定,国家职业技能鉴定·操作技能强化训练:计算机网络管理员(国家职业资格四级)(学生取证专用)...
  4. 一员工密码设为「123456」,导致被盗 450Gb 数据?
  5. excel手机版_换手机了备忘录怎么恢复到新手机?便签备忘录同步可用敬业签
  6. 深入理解spring中的AOP原理——实现MethodInterceptor接口,自已动手写一个AOP
  7. MATLAB实现矩阵的布尔运算(逻辑运算)
  8. python3 reshape
  9. 微信开发者工具——快捷键汇总
  10. 程序员之间的搞笑对话!测试妹子弄得大家好尴尬!