部署LNMP+zabbix监控工具

目录

一、了解监控工具

1、为什么使用监控工具

随着时代的发展,企业的网络规模越来越大,部署的服务器等网络设备越来越多,业务越来越多样化,网络管理也越来越复杂,耗费的人力资源越来越大,于是相应的监控系统孕育而生。
使用监控工具能最大限度帮助用户实现主动监控,集中管理,快速定位故障,提高工作效率。

2、企业中使用的监控工具

监控工具发展的时间里每个时间段总有突出的几个软件。
例如:CACTI—>NAFIOS—>zabbix

CACTI(仙人掌)

  • 由PHP、MySQL、SNMP这些底层协议组成的网络流量监测图形分析工具。

NAFIOS

  • 外号:难搞死,功能依赖插件,插件非常多
  • 部署、使用比较麻烦
  • 由底层协议SNMP构成

zabbix(目前使用最多的)

  • 官网:https://www.zabbix.com/
  • 底层协议有SNMP协议
  • 基于WEB页面的分布式的监控,开源的
  • 运行的平台:linux、Windows等
  • 通常和haproxy配合使用
  • 组成组件:zabbix server(监控端)和zabbix agent(被监控端)

总结
看这三个监控工具,可以看到他们的底层协议都是SNMP
SNMP,是监控工具底层承载的协议,也是应用层协议,前身是简单的网关监控协议SGMP。

二、部署LNMP+zabbix

案例环境

主机操作系统IP地址主要软件及版本
serverCentos 7192.168.163.100LNMP+zabbix
clientCentos 7192.168.163.150zabbix

思路:
先部署LNMP
在安装zabbix监控

1、LNMP安装环境

systemctl stop firewalld.service
systemctl disable firewalld.service
setenforce 0

在这里插入图片描述

(1)安装nginx

从官网上下载nginx的rpm包

wget http://nginx.org/packages/centos/7/noarch/RPMS/nginx-release-centos-7-0.el7.ngx.noarch.rpm

在这里插入图片描述

手动创建nginx yum安装源

vim /etc/yum.repos.d/nginx.repo
[nginx]
name=nginx repo
baseurl=http://nginx.org/packages/centos/7/$basearch/
gpgcheck=0
enabled=1

#---------------------baseurl----------------------------------
格式: baseurl=http://nginx.org/packages/OS/OSRELEASE/$basearch/,
其中"OS"指的是系统(例如:centos),而"OSRELEASE"是系统版本(例如:6、7)
#--------------------------------------------------------------

yum list

在这里插入图片描述

安装nginx

yum install nginx -y

systemctl start nginx
systemctl enable nginx

//如果企业中开着软件防火墙,可以使用下面两条命令允许使用nginx通过
firewall-cmd --permanent --add-service=http —-zone=public
firewal1-cmd --reload


netstat  -natp | grep nginx

在这里插入图片描述

到这验证nginx,访问http://192.168.163.100

在这里插入图片描述

(2)安装mysql

yum install -y mariadb-server mariadb

systemctl enable mariadb.service
systemctl start mariadb.service

mysql_secure_installation

mysql -uroot -p
exit

在这里插入图片描述


在这里插入图片描述

在这里插入图片描述


在这里插入图片描述

(3)安装php

//使用rpm或yum下载epel源
rpm -Uvh https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm
或
yum install epel-release -y

//yum仓库的建立
rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm
//yum安装php相关组件等待时间取决于网络
yum install -y php72w php72w-devel php72w-fpm php72w-gd php72w-mbstring php72w-mysql
#-----------------------------------组件解释-------------------------------------------
php72w是本身服务包;
php72w-devel用于构建PHP扩展所需的文件;
php72w-fpm是PHP FastCGI进程管理器;
php72w-gd是PHP应用程序的模块,用于使用gd图形库;
php72w-mbstring模块是需要多字节字符串处理的PHP应用程序的模块;
php72w-mysql是数据库mysql驱动模块,在mysql的官网下载的
#-------------------------------------------------------------------------------------


//查看php版本
php -v

在这里插入图片描述


在这里插入图片描述


在这里插入图片描述

(4)修改配置文件

修改php-fpm配置文件,把apache改为nginx,让php可以识别nginx用户

vim /etc/php-fpm.d/www.conf
//第8行,修改属主
user = nginx
//第10行;修改属组
group = nginx

在这里插入图片描述


修改default.conf配置文件;使nginx支持php

vim /etc/nginx/conf.d/default.conf
//第10行;添加php格式的主页
index  index.html index.htm index.php;
//30~36行;配置php请求被传送到后端的php-fpm模块,默认情况下php配置块是被注释的
location ~ \.php$ {
    root           /usr/share/nginx/html;
    fastcgi_pass   127.0.0.1:9000;
    fastcgi_index  index.php;
    fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;
    include        fastcgi_params;
}

修改root根目录路径
把fastcgi_param中的/scripts改成$document_root(引用刚才设置的根目录路径)

在这里插入图片描述

配置php

vim /etc/php.ini
#修改PHP配置文件
//359行;修改;隐藏php版本
expose_php = Off
//202行;修改;支持php短标签
short_open_tag = On

//以下为zabbix配置要求,数值可以大于但不能小于,不然后面验证不通过
//368行;修改;执行时间
max_execution_time = 300
//378行;修改;接收数据等待时间
max_input_time = 300
//389;每个脚本占用内存
memory_limit = 128M
//656;修改;Post数据大小
post_max_size = 16M
//799;下载文件大小
upload_max_filesize = 2M
//800;添加;可以用$HTTP_RAW_POST_DATA 接受post raw data
always_populate_raw_post_data= -1
/877;取消注释,添加;指定时区
date.timezone = Asia/Shanghai

在这里插入图片描述


启动php-fpm和nginx服务

systemctl start php-fpm.service 
systemctl enable php-fpm.service
netstat -natp | grep 9000

systemctl restart nginx

在这里插入图片描述

(5)测试

测试首页

vim /usr/share/nginx/html/info.php
<?php
  phpinfo();
?>

在这里插入图片描述


此时可以使用真机上访问http://192.168.163.100/info.php

在这里插入图片描述

测试连接数据库
目前新版本的数据库连接测试都使用mysqli_connect

<?php
  $link=mysqli_connect('127.0.0.1', 'root','abc123');
  if ($link) echo "true!";
  else echo "false!";
?>

在这里插入图片描述


在这里插入图片描述

(6)数据库授权

mysql -u root -p
//创建zabbix库,创库时设置好字符集问题
create database zabbix character set utf8 collate utf8_bin;
//创建数据库用户及配置用户权限
grant all privileges on *.* to 'zabbix'@'%' identified by 'admin123';
//重载权限表
flush privileges;

在这里插入图片描述

测试

<?php
  $link=mysqli_connect('127.0.0.1', 'zabbix','admin123');
  if ($link) echo "true!";
  else echo "false!";
?>

在这里插入图片描述


在这里插入图片描述


解决本地无法登录问题

mysql -u root -p
select user,host from mysql.user;  //有空用户名称占用导致本地无法登录
drop user ''@localhost;
drop user ''@localhost.localdomain;

在这里插入图片描述


在这里插入图片描述

2、部署zabbix Server

(1)安装zabbix

zabbix官网 https://www.zabbix.com/download

//安装一个zabbix仓库;
rpm -i https://repo.zabbix.com/zabbix/4.0/rhel/7/x86_64/zabbix-release-4.0-2.el7.noarch.rpm
//安装Zabbix server,Web前端,agent
yum install zabbix-server-mysql zabbix-web-mysql zabbix-agent -y

在这里插入图片描述

(2)导入数据库脚本,初始架构和数据

提示您输入新创建的密码,注意密码不要输成root的

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

在这里插入图片描述

(3)修改zabbix配置文件

vim /etc/zabbix/zabbix_server.conf
//91行;去掉注释;连接本地的数据库
DBHost=localhost
//124行;修改本行;数据库密码
DBPassword=admin123

#----------------其他相关配置(比较重要的配置,看情况修改)------------------------
//38行;日志文件位置
LogFile=/var/log/zabbix/zabbix_server.log
//49行;日志文件大小;设置为0,不限制日志文件大小
LogFileSize=0
//72行;pid文件位置
PidFile=/var/run/zabbix/zabbix_server.pid
//82行;套接字文件位置;套接字是计算机之间进行通信的一种约定或一种方式
SocketDir=/var/run/zabbix
//100行;数据库名
DBName=zabbix
//116行;数据库用户名
DBUser=zabbix
//356行;采用的网络管理协议SNMP
SNMPTrapperFile=/var/log/snmptrap/snmptrap.log
//473行;超时时间
Timeout=4
//516行;脚本文件
AlertScriptsPath=/usr/lib/zabbix/alertscripts
//527行;扩展脚本文件
ExternalScripts=/usr/lib/zabbix/externalscripts
//563行;慢日志时间,超过3000秒记录
LogSlowQueries=3000

在这里插入图片描述

(5)启动zabbix及相关服务

注意:setenforce 0 系统安全机制一定要关闭
修改属主、属组、赋权

cp -r /usr/share/zabbix/ /usr/share/nginx/html/
chown -R zabbix:zabbix /etc/zabbix/
chown -R zabbix:zabbix /usr/share/nginx/
chown -R zabbix:zabbix /usr/lib/zabbix/
chmod -R 755 /etc/zabbix/web/
chmod -R 777 /var/lib/php/session/

在这里插入图片描述


重启服务

systemctl start zabbix-server.service
systemctl enable zabbix-server.service

systemctl start zabbix-agent.service
systemctl enable zabbix-agent.service

netstat -anpl | grep 10051
netstat -anpl | grep 10050

systemctl restart php-fpm.service
systemctl restart nginx

在这里插入图片描述

(6)验证

http://192.168.163.100/zabbix/

在这里插入图片描述


在这里插入图片描述


在这里插入图片描述


在这里插入图片描述


在这里插入图片描述


在这里插入图片描述

//安装后登录用户名:Admin 密码: zabbix

在这里插入图片描述

在这里插入图片描述


在这里插入图片描述


在这里插入图片描述

3、配置被监控端

安装zabbix存储库与agent代理服务

rpm -Uvh https://repo.zabbix.com/zabbix/4.0/rhel/7/x86_64/zabbix-release-4.0-2.el7.noarch.rpm

yum -y install zabbix-agent

在这里插入图片描述

修改配置文件

vim /etc/zabbix/zabbix_agentd.conf

//98行;指向监控服务器地址
Server=192.168.163.100
//139行;指向监控服务器地址
ServerActive=192.168.163.100
//150行;修改名称
Hostname=client

#------------------其他内容了解--------------
//13行;pid文件位置
PidFile=/var/run/zabbix/zabbix_agentd.pid
//32行;日志文件位置
LogFile=/var/log/zabbix/zabbix_agentd.log
//43行;日志文件大小;设置为0,不限制日志文件大小
LogFileSize=0
//268行;包含zabbix_agentd.d目录下的所有.conf结尾的配置文件
Include=/etc/zabbix/zabbix_agentd.d/*.conf

在这里插入图片描述

重启服务

service firewalld stop
setenforce 0
systemctl enable zabbix-agent.service
systemctl restart zabbix-agent.service
netstat -anpt | grep zabbix   //监听在10050端口

在这里插入图片描述


下一篇:zabbix监控的报警机制

原文地址:https://blog.csdn.net/weixin_51326240/article/details/115372654

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


本篇内容介绍了“LNMP服务器环境配置实例分析”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情...
本篇内容主要讲解“OneinStack如何一键安装LNMP”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“OneinStack如何...
小编给大家分享一下如何解决LNMP安装composer install时出现Warning: putenv()问题,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅...
1.源码安装mysql鉴于前边的文章已经详细说过mysql的源码安装可以点击基于LAMP的Discuz论坛的实现(源码安装)自行查看这里为了节省时间用一个shell脚本进行mysql的源码安装用到的mysql依然是5.6.46没有源码包的同学可以点击【mysql-5.6.46.tar.gz提取码:nli5】进行下载
Linux是非常热门的技术,也是当下非常受欢迎的操作系统,具有独特的优势所在,广受大家的喜欢和追捧,今天为大家分享一下几款常用的Linux系统面板,希望对你有所帮助。1、宝塔面板:是一款使用方便、功能强大而且终身免费的服务器管理软件,支持Linux以及Windows系统,一键配置LAMP/LNMP
██【電:131.乀.1418.乀.6667】【薇q:9788.乀.9181】██柬埔寨东方明珠开户目录LAMP1.安装Mariadb2.安装PHP3.测试php和apache的协同4.修改MariaDB数据库配置5.测试数据库连接LNMP(未完待续)LAMP1.安装Mariadb在RaspberryPi中,MySQL无法安装,会自动建议安装Maria
关闭防火墙安装依赖包上传源码包解压源码包,安装nginx启动nginx安装mysql和PHP相关服务修改nginx配置文件,nginx和PHP进行整合重新加载nginx服务启动php-fpm书写PHP测试页测试网页 
一.lnmp的搭建1.准备一台纯净版的虚拟机2.下载Lnmp一键安装包命令:wget http://soft.vpser.net/lnmp/lnmp1.5-full.tar.gz【安装完整版的-推荐1.5版本】也可以本地下载好,通过rz上传:http://soft.vpser.net/lnmp/lnmp1.5-full.tar.gz3.开始安装命令:cdlnmp1.5-full 
1.LNMP理论fastcgi的主要优点:把动态语言和http服务器分离开来,使nginx可以处理静态请求和向后转发动态请求,而php/php-fpm服务器转移解析PHP动态请求使用fastcgi的原因:Nginx不支持对外部动态程序的直接调用或者解析,所有的外部程序(包括PHP)必须通过FastCGI接口来调用。
keepalived高可用keepalived注意:任何软件都可以使用keepalived来做高可用keepalived如何实现高可用VRRP:虚拟路由冗余协议比如公司的网络是通过网关进行上网的,那么如果该路由器故障了,网关无法转发报文了,此时所有人都无法上网了,怎么办?通常做法是给路由器增加一台备节点,但是问
通过阿里云的服务器搭建lnmp架构以及部署wordpress个人博客,连接上域名所遇到的问题及解决办法注释:操作系统centos7.9第一步:购买阿里云ecs服务器,选择系统及其他硬件,下面是我自己购买的配置,可以参考(注意操作系统我购买的时候选错了,后来换成了centos7.9)然后在阿里云“云服
文章目录1.首先了解编译安装和yum安装的区别。2.yum安装准备工作---切换阿里云yum源3.编译安装lnmp**很不建议使用编译安装,麻烦且容易报错。**4.yum安装lnmp**可以先执行一下yumupdate**5.lnmp一键安装[参考网站](https://lnmp.org/)**不喜欢这种方式,所以没测试
电影院系统解压登录mysql创建电影院系统使用的数据库授权账户skyuc访问数据库讲系统部署到www.benet.com网站根目录下mv/usr/src/SKYUC.v3.4.2.SOURCE/wwwroot/*/var/www/benetcom/设置网站根目录所有者和权限客户机测试论坛系统部署解压复制文件到网站根目
下载:​ https://www.php.net/downloads​ https://www.php.net/distributions/php-8.0.6.tar.gz编译安装php:①安装依赖:yum-yinstalllibxml2-develsqlite-develbzip2-devellibcurl-devellibpng-devellibjpeg-develfreetype-devellibicu-develoniguruma-devellibxs
树莓派LNMP关键词:raspberrywebphpdnsmysq1LNMP、LAMP是指一组通常一起使用来运行动态网站或者服务器的自由软件名称首字母缩写,分别指Linux、Nginx/Apache、MySQL和PHP。这里演示如何在树莓派上搭建LNMP环境并配置多个站点。主要内容:树莓派安装nginx树莓派安装ph
官网:http://kodcloud.com/1、准备MySQL数据库 [root@cent8_yzl_20~]#yuminstall-ymysql-server[root@cent8_yzl_20~]#systemctlenable--nowmysqld[root@cent8_yzl_20~]#mysqlmysql>createdatabasekodbox;mysql>createuserkodbox@'10.0.0.
环境应用IP操作系统nginx192.168.122.131centos8mysql192.168.122.132centos8php192.168.122.133centos8准备工作//关闭防火墙#systemctldisable--nowfirewalld#setenforce0#vim/etc/selinux/configSELINUX=disabled安装nginx//安装依
1.购买vps或者外国云主机2.搭建ss服务端3.客户端配置服务端信息,即可。不废话,开始教程:ss-panel-v3简介ss-panel是一套功能齐全的shadowsocks用户管理面板,它可以实现用户注册、用户管理、流量控制、签到、添加多节点、充值购买、邀请返利等诸多功能,是目前网络上使用最广泛的一
LNMP架构数据迁移至NFS第一步:先将原有目录中数据移出数据存储到本地什么位置,获取方法1.通过网站页面右键点击,获取资源地址信息2.find命令利用-mmin53.利用inotify服务监控目录数据变化[root@web01wp-content]#cd/applicationginx/html/blog/wp-content/uploads[root@we
一 点睛业务上线之前最关键的一项任务便是环境部署,往往一个业务涉及多种应用环境,比如Web、DB、PROXY、CACHE等,本示例通过env.roledefs定义不同主机角色,再使用“@roles('webservers')”修饰符绑定到对应的任务函数,实现不同角色主机的部署差异。二 代码#coding=utf-8#!/usr