【1】循序渐进学 Zabbix :初识与基础依赖环境搭建( LNMP )

  写在前面的话

运维监控是一个很大的话题,在这一块个人接触的比较突出的服务主要有 Nagio 和 Zabbix 两款。而这几年跳过的公司中,Zabbix 一直都是首选且唯一选择,Nagios 没遇到。

个人算是从 2.2 开始接触的 Zabbix ,但那时我只是 Help desk,主要工作是接受监控告警和将故障通知到指定的人,而不是配置服务。如今已经或多或少用了两三年 Zabbix 了,版本也迭代到了 3.4.10。

最近恰逢换完工作,公司的很多东西需要从零开始搭建,所以准备抽空写一些东西,一是作为笔记保留,二是给准备做运维或者刚学习运维的兄弟做个参考。

当然,网上的资料很多,但是很多都讲的太详细了,对于我这种比较菜的一是看一半就想睡觉,二是抓不住重点,于是我把自己的学习经过写下来,内容可能不深,但勉强够用。标题取名 "循序渐进学 Zabbix",算是希望能够在写的过程中慢慢完善自己。

最后,文中可能有写的有问题的地方,希望各位能够指出。当然,如果你觉得还不错,合你的口味,也希望你能够点赞支持,让我至少知道这些东西还是有人在认真看的~ 

  Zabbix 介绍

网上对于 Zabbix 的解释很多,我这里挑简单的说:

1、它是一款开源,使用 C 语言编写的分布式监控服务,包含 Server 和 Agent 两个部分

2、在系统资源,服务状态性能监控等方面具有优异的表现

3、能够自定义监控模板,具有较高的定制性

4、能够将监控结果以图形化展示出来,对于需要出具报告的运维人员来说相当实用且友好等等等特点

...

主要的几个程序:

1、zabbix_server:zabbix 服务端核心服务,事务处理都在于它 

2、zabbix_agentd: 客户端守护进程,此进程收集客户端数据,例如 CPU负载、内存、硬盘使用情况等

3、zabbix_get:主要用于测试监控项是否能够正常使用

4、zabbix_sender: 用于发送给 server 或者 proxy,通常用于耗时比较长的检查,避免超时

5、zabbix_proxy: 特殊的网络环境可以作为一个中转站,从 agent 到 proxy 再到 server 这样实现

...

原理图:上面说的太片面,于是决定画张图来简单说明一下它的主要工作方式! 

  环境说明

Zabbix 本身可以直接使用自带的脚本运行,但是其 WEB 端是 PHP 写的,所以我们就需要搭建 LNMP 环境。

以下是我本机的虚拟机环境所选择的版本:

服务
版本
操作系统
CENTOS 7.5
NGINX
nginx-1.10.2
MySQL
percona-server-5.7.11-4( MySQL 的分支 )
PHP
php-7.0.30

虚拟机环境:

服务器
IP
配置
Zabbix Server
192.168.200.101
4G 内存
Zabbix Agent
192.168.200.102
4G 内存

特殊说明:本人比较推荐源码编译安装,很多东西路径自己定制,这应该算是一个运维需要具备的基础技能,虽然 Zabbix ,LNMP 环境都可以 yum 安装,很方便,但是个人极其不推荐!

原因:我身边很多同行包括我特别反感,你倒是舒舒服服想怎么来就怎么来,结果哪天你突然离职,别人接手你的锅还得一个一个机器的去梳理,又没文档,有的涉及到迁移的,麻烦的一批,因为谁也不知道你到底干了什么骚操作,接盘侠绝对在背地里不知道骂了你多少句CNM,DSB!

个人认为,规范化对于运维来说极其重要,运维你本身的很大一部分工作就是让公司的服务器规范化管理起来!

文中所以需要的安装包我都放到了百度网盘,需要的兄弟可以去下载:

链接:https://pan.baidu.com/s/14u6r5V7sELN8NNErGp48NA 密码:g9xy

  安装 NGINX

所需安装包: 个人用到的比较多,常见的一些模块也都增加了

安装包
nginx-1.10.2.tar.gz
nginx-upload-module-2.2.zip
nginx-upstream-fair-master.zip
ngx_cache_purge-2.3.tar.gz
openssl-1.1.0c.tar.gz
pcre-8.39.tar.gz
zlib-1.2.8.tar.gz

目录说明: 

用途
目录
安装包路径
/opt/packages/nginx
安装路径
/opt/services/nginx
日志路径
/opt/logs/nginx

备注:这些目录是个人的习惯,我把所有关于用户安装的东西都尽量限制在一个目录,方便管理

【1】创建相应的用户与目录:

# 创建目录
mkdir /opt/services
mkdir -p /opt/logs/nginx
mkdir -p /opt/packages/nginx

# 创建监听用户
useradd www -s /sbin/nologin

【2】安装依赖:

yum -y install zip unzip gcc gcc-c++ automake autoconf libtool make glibc gd-devel pcre-devel libmcrypt-devel mhash-devel libxslt-devel libjpeg libjpeg-devel libpng libpng-devel freetype freetype-devel libxml2 libxml2-devel zlib zlib-devel glibc glibc-devel glib2 glib2-devel bzip2 bzip2-devel ncurses ncurses-devel curl curl-devel e2fsprogs e2fsprogs-devel krb5 krb5-devel libidn libidn-devel openssl openssl-devel libevent libevent-devel

【3】上传包到 /opt/packages/nginx 目录并解压编译安装:

# 解压安装包
cd /opt/packages/nginx

tar -zxf nginx-1.10.2.tar.gz 
unzip nginx-upload-module-2.2.zip 
unzip nginx-upstream-fair-master.zip 
tar -zxf ngx_cache_purge-2.3.tar.gz 
tar -zxf openssl-1.1.0c.tar.gz 
tar -zxf pcre-8.39.tar.gz 
tar -zxf zlib-1.2.8.tar.gz 

# 编译安装
cd nginx-1.10.2

./configure --prefix=/opt/services/nginx --user=www --group=www --with-http_realip_module --with-http_stub_status_module --with-stream  --with-http_gzip_static_module --with-http_flv_module --with-http_ssl_module --with-http_mp4_module --with-http_realip_module --with-pcre=/opt/packages/nginx/pcre-8.39 --with-openssl=/opt/packages/nginx/openssl-1.1.0c --with-zlib=/opt/packages/nginx/zlib-1.2.8 --with-http_v2_module --with-ipv6 --with-http_image_filter_module --add-module=/opt/packages/nginx/nginx-upload-module-2.2 --add-module=/opt/packages/nginx/nginx-upstream-fair-master --add-module=/opt/packages/nginx/ngx_cache_purge-2.3

make && make install

【4】初始化配置 NGINX:

# 创建额外配置文件目录,方便管理
mkdir /opt/services/nginx/conf/vhosts

# 简单的配置优化
vim /opt/services/nginx/conf/nginx.conf

配置文件内容:

user  www www;
worker_processes  4;
error_log  /opt/logs/nginx/error.log;
pid        /opt/logs/nginx/nginx.pid;
worker_rlimit_nofile 65535;

events {
    use epoll;
    worker_connections  65535;
}
 
http {
    include       mime.types;
    default_type  application/octet-stream;
 
    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';
 
    access_log  /opt/logs/nginx/access.log  main;
 
    server_names_hash_bucket_size 128;
    client_header_buffer_size 32k;
    large_client_header_buffers 4 32k;
    client_max_body_size 8m;
   
    fastcgi_connect_timeout 300;
    fastcgi_send_timeout 300;
    fastcgi_read_timeout 300;
    fastcgi_buffer_size 64k;
    fastcgi_buffers 4 64k;
    fastcgi_busy_buffers_size 128k;
    fastcgi_temp_file_write_size 128k;
    fastcgi_param HTTP_PROXY "";
   
    proxy_hide_header X-Powered-By;
    proxy_hide_header X-Forwarded-For;
    proxy_hide_header X-AspNet-Version;
    proxy_hide_header X-AspNetMvc-Version;
    proxy_hide_header Via;
    proxy_hide_header X-Varnish;
    proxy_hide_header Server;
   
    gzip on;
    gzip_min_length  1k;
    gzip_buffers     4 16k;
    gzip_http_version 1.1;
    gzip_comp_level 5;
    gzip_disable "MSIE [1-6]\.";
    gzip_types text/plain text/css text/xml application/javascript application/x-javascript;
    gzip_vary on;
   
    include vhosts/*.conf;
}

【5】添加到开机自启动:

# 授权
chmod 777 /etc/rc.local

# 加入开机启动
echo '' >> /etc/rc.local
echo '# nginx startup' >> /etc/rc.local
echo '/opt/services/nginx/sbin/nginx &' >> /etc/rc.local

【6】NGINX 安装完成,接下来安装 MySQL!

  安装 MySQL

所需安装包:

安装包
percona-server-5.7.11-4.tar.gz
cmake-3.5.2.tar.gz
boost_1_59_0.tar.gz

目录说明: 

用途
目录
安装包路径
/opt/packages/mysql
安装路径
/opt/services/mysql
日志路径
/opt/logs/mysql

【1】创建相应的用户与目录:

# 创建目录
mkdir -p /opt/logs/mysql
mkdir -p /opt/packages/mysql

# 创建监听用户
useradd mysql -s /sbin/nologin

【2】安装依赖: 

yum -y install gcc gcc-devel gcc-c++ gcc-c++-devel libaio-devel boost boost-devel autoconf* automake* zlib* libxml* ncurses-devel ncurses libgcrypt* libtool* cmake openssl openssl-devel bison bison-devel unzip numactl-devel net-snmp-devel net-snmp-utils readline*

【3】将安装包上传到 /opt/packages/mysql ,然后编译安装:安装时间较长,20 多分钟左右

# 解压
cd /opt/packages/mysql
tar -zxf cmake-3.5.2.tar.gz 
tar -xzf boost_1_59_0.tar.gz 
tar -zxf percona-server-5.7.11-4.tar.gz

# 编译安装 CMAKE
cd cmake-3.5.2
./configure 
gmake && make install

# 查看安装结果
cmake --version

# 编译安装 MySQL
cd ../percona-server-5.7.11-4

cmake . -DCMAKE_INSTALL_PREFIX=/opt/services/mysql -DWITH_BOOST=/opt/packages/mysql/boost_1_59_0/ -DMySQL_DataDIR=/opt/services/mysql/data -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DWITH_MYISAM_STORAGE_ENGINE=1 -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_ARCHIVE_STORAGE_ENGINE=1 -DWITH_BLACKHOLE_STORAGE_ENGINE=1 -DWITH_EDITLINE=bundled -DENABLED_LOCAL_INFILE=1 -DZLIB_INCLUDE_DIR:PATH=/usr/include -DENABLE_DOWNLOADS=1

make -j4 && make install

# 授权目录
chown -R mysql:mysql /opt/logs/mysql

# 配置 MySQL
vi /etc/my.cnf

内容如下:

[client]
port= 3306
socket=/opt/logs/mysql/mysql.sock

[mysqld]
port=3306
datadir=/opt/services/mysql/data
basedir=/opt/services/mysql
socket=/opt/logs/mysql/mysql.sock

character_set_server=utf8
user=mysql

# 指定日志和pid位置
log-error=/opt/logs/mysql/mysql-error.log
pid-file=/opt/logs/mysql/mysqld.pid

# 开启查询缓存,注意5.1版本如果报错的话,把下面一行注释掉
explicit_defaults_for_timestamp=true

# 关闭符号链接支持
symbolic-links=0

# 不区分大小写
lower_case_table_names=1

# 禁用DNS解析
skip-name-resolve

# INNODB重点优化参数:缓存用户表及索引数据,一般设置为系统内存的50%,但是得根据实际预留
innodb_buffer_pool_size=2000M

# MyISAM重点优化参数:指定索引缓冲区的大小,它决定索引处理的速度,尤其是索引读的速度
key_buffer_size=32M

# 分配简单索引扫描,范围索引扫描,无索引全表扫描的表连接缓存的大小
join-buffer-size=2M

# 在每个connection(session)第一次需要这个buffer的时候,一次性分配设置的内存
sort-buffer-size=4M

# 读查询操作所能使用的缓冲区大小,该参数对应的分配内存也是每连接独享
read_buffer_size=4M

# 针对按某种特定顺序(如ORDER BY子句)输出的查询结果(默认256K)加速排序操作后的读数据,提高读分类行的速度
read_rnd_buffer_size=16M

# MyISAM表发生变化时重新排序所需的缓冲
myisam_sort_buffer_size=128M

# 关闭query-cache
query-cache-size=0
query_cache_type=0

# 临时HEAP数据表的最大长度
tmp_table_size=256M

# 重新利用保存在缓存中线程的数量
thread_cache_size=64

# 开启慢日志查询
log-slow-admin-statements
slow-query-log=on
slow-launch-time=2
slow-query-log-file=/opt/logs/mysql/mysql-slow.log

# 表描述符缓存大小,可减少文件打开/关闭次数
table-open-cache=512

# 设置最大连接(用户)数
max-connections=5000

# 某一客户端尝试连接此MySQL服务器,但是失败(如密码错误等等)5000次,则MySQL会无条件强制阻止此客户端连接
max_connect_errors=5000

# 不写入硬盘而是写入系统缓存
# 日志仍然会每秒flush到硬盘,所以你一般不会丢失超过1-2秒的更新,只会在整个操作系统挂了时才可能丢数据
innodb_flush_log_at_trx_commit=2

# 限制server接受的数据包大小
max_allowed_packet=300M

# 设置编码格式
collation-server=utf8_general_ci
init-connect='SET NAMES utf8'
character-set-server=utf8

# 忽略客户端字符集
skip-character-set-client-handshake

# 跳过验证
skip-grant-tables

【4】初始化数据库:

/opt/services/mysql/bin/mysql_install_db --defaults-file=/etc/my.cnf --basedir=/opt/services/mysql --datadir=/opt/services/mysql/data --user=mysql

【5】添加服务启动脚本和环境变量:

# 创建启动方式
cp /opt/services/mysql/support-files/mysql.server /etc/init.d/mysqld
chmod 700 /etc/init.d/mysqld
sed -i 's/^basedir=$/&\/opt\/services\/mysql/g' /etc/init.d/mysqld
sed -i 's/^datadir=$/&\/opt\/services\/mysql\/data/g' /etc/init.d/mysqld

# 添加环境变量
echo "" >> /etc/profile
echo "# MySQL" >> /etc/profile
echo "export MYSQL_HOME=/opt/services/mysql" >> /etc/profile
echo 'export PATH=$PATH:${MYSQL_HOME}/bin' >> /etc/profile

# 生效环境变量
source /etc/profile

【6】启动服务初始化用户:

# 启动服务
/etc/init.d/mysqld start

# 登录 MySQL,之前配置文件有配置免认证
mysql

# 设置数据库密码,执行以下 SQL 语句
update mysql.user set authentication_string=password('123456') where user='root' and Host = 'localhost';
quit;

# 取消免密配置,重启数据库
sed -i 's%skip-grant-tables%#skip-grant-tables%g' /etc/my.cnf
/etc/init.d/mysqld restart

# 登录数据库新建用户
mysql -uroot -p123456

# 执行以下 SQL 语句
alter user 'root'@'localhost' identified by '123456';
grant all on *.* to root@'%' identified by '123456' with grant option;
flush privileges;
quit;

【7】加入开机启动:

# 加入开机启动
echo '' >> /etc/rc.local
echo '# mysql startup' >> /etc/rc.local
echo '/etc/init.d/mysqld start &' >> /etc/rc.local

【8】至此 MySQL 5.7 安装配置完成,密码 123456,接下来安装 PHP!

  安装 PHP

所需安装包:

安装包
php-7.0.30.tar.gz
libiconv-1.14.tar.gz

目录说明: 

用途
目录
安装包路径
/opt/packages/php
安装路径
/opt/services/php
日志路径
/opt/logs/php

【1】创建相应的用户与目录:

# 创建目录
mkdir -p /opt/logs/php/tmp
mkdir -p /opt/packages/php
chown -R 777 /opt/logs/php/tmp
# 创建监听用户 useradd php -s /sbin/nologin

【2】安装依赖: 

# 安装 epel
yum install -y epel-release

# 安装依赖
yum -y install libmcrypt-devel mcrypt mhash gd-devel ncurses-devel libxml2-devel bzip2-devel libcurl-devel curl-devel libjpeg-devel libpng-devel freetype-devel net-snmp-devel openssl-devel libmcrypt-devel

【3】将安装包上传到 /opt/packages/php ,然后编译安装:

# 解压安装包
cd /opt/packages/php

tar –zxf libiconv-1.14.tar.gz
tar –zxf php-7.0.30.tar.gz

# 编译安装 Libiconv
cd libiconv-1.14/srclib
sed -i -e '/gets is a security/d' ./stdio.in.h
cd ..

./configure --prefix=/usr/local/libiconv

make && make install

# 编译安装 PHP
cd ../php-7.0.30

./configure --prefix=/opt/services/php --with-config-file-path=/opt/services/php/etc --enable-mysqlnd --with-mysqli=mysqlnd --with-pdo-mysql=mysqlnd --with-iconv-dir=/usr/local/libiconv --with-pcre-regex --with-zlib --with-bz2 --enable-calendar --with-curl --enable-dba --with-libxml-dir --enable-ftp --with-gd --with-jpeg-dir --with-png-dir --with-zlib-dir --with-freetype-dir --enable-gd-native-ttf --with-mhash --enable-mbstring --with-mcrypt --enable-pcntl --enable-xml --disable-rpath --enable-shmop --enable-sockets --enable-zip --enable-bcmath --with-snmp --disable-ipv6 --with-gettext  --enable-fpm --with-fpm-user=php --with-fpm-group=php --with-openssl

make && make install

【4】配置 PHP:

# 复制配置文件
cd /opt/services/php/etc/
cp php-fpm.conf.default php-fpm.conf
cp /opt/packages/php/php-7.0.30/php.ini-production .
mv php.ini-production php.ini

# 修改 php.ini 配置
sed -i 's#;date.timezone =#date.timezone = PRC#g' php.ini 
sed -i 's#expose_php = On#expose_php = Off#g' php.ini 
sed -i 's#^;cgi.fix_pathinfo=1#cgi.fix_pathinfo=1#g' php.ini 
sed -i 's#disable_functions =#disable_functions =exec,system,eval,passthru,chroot,chgrp,chown,shell_exec,proc_open,proc_get_status,ini_alter,ini_alter,ini_restore,dl,pfsockopen,fsocket,openlog,syslog,readlink,symlink,popepassthru,stream_socket_server#g' php.ini 
sed -i 's#max_execution_time = 30#max_execution_time = 300#g' php.ini 
sed -i 's#max_input_time = 60#max_input_time = 300#g' php.ini 
sed -i 's#post_max_size = 8M#post_max_size = 24M#g' php.ini 
sed -i 's#upload_max_filesize = 2M#upload_max_filesize = 4M#g' php.ini
sed -i 's#pdo_mysql.default_socket=#pdo_mysql.default_socket= /opt/logs/mysql/mysql.sock#g' php.ini 
sed -i 's#mysqli.default_socket =#mysqli.default_socket = /opt/logs/mysql/mysql.sock#g' php.ini 
sed -i 's#;session.save_path = "/tmp"#session.save_path = "/opt/logs/php/tmp"#g' php.ini

# 修改 www.conf 配置
cd php-fpm.d/
cp www.conf.default www.conf
sed -i 's#;rlimit_files = 1024#rlimit_files = 65535#g' www.conf
sed -i 's#;listen.owner = php#listen.owner = www#g' www.conf
sed -i 's#;listen.group = php#listen.group = www#g' www.conf
sed -i 's#;listen.mode = 0660#listen.mode = 0660#g' www.conf

【5】配置启动脚本: 

cp /opt/packages/php/php-7.0.30/sapi/fpm/init.d.php-fpm /etc/init.d/php-fpm
chmod +x /etc/init.d/php-fpm

【6】启动服务和开机自启动:

# 启动服务
/etc/init.d/php-fpm start

# 加入开机启动
echo '' >> /etc/rc.local
echo '# php startup' >> /etc/rc.local
echo '/etc/init.d/php-fpm start &' >> /etc/rc.local

【7】至此,LNMP 环境都搭建完成,我们可以在 NGINX 中添加测试:

# 添加网站目录
mkdir /opt/services/website

# 添加 PHP 测试页面
echo '<?php
> phpinfo();
> ?>' > /opt/services/website/index.php

# 添加 Nginx 配置
vim /opt/services/nginx/conf/vhosts/php_test.con

内容如下: 

server {
    listen 8080;
    server_name 192.168.200.101;
    access_log /opt/logs/nginx/test.log main;
    index index.php index.html index.html;
    root /opt/services/website;
   
    location / {
        try_files $uri $uri/ /index.php?$args;
    }
   
    location ~ .*\.(php)?$ {
        expires -1s;
        try_files $uri =404;
        fastcgi_split_path_info ^(.+\.php)(/.+)$;
        include fastcgi_params;
        fastcgi_param PATH_INFO $fastcgi_path_info;
        fastcgi_index index.php;
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
        fastcgi_pass 127.0.0.1:9000;
    }
}

【8】启动 Nginx 查看效果: 

/opt/services/nginx/sbin/nginx

浏览器访问: 

 

 【9】此处,LNMP 环境检测没问题!

  小结

LNMP 网上的安装方式很多,也有一件安装包,我的方法仅供大家参考,下面附带一张安装下来的目录结构图,可以比较一下你的安装和我的安装的优缺点: 

 

猜你喜欢

转载自www.cnblogs.com/Dy1an/p/9230644.html