设为首页 收藏本站
查看: 1381|回复: 0

[经验分享] 基于LNMP实现zabbix环境搭建

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2015-7-17 09:31:51 | 显示全部楼层 |阅读模式
系统环境
$ cat /etc/issue
CentOS release 6.6 (Final)
$ uname -rs
Linux 2.6.32-504.23.4.el6.centos.plus.x86_64
下载所需要的源码包
wget -c http://cn2.php.net/get/php-5.6.5.tar.gz/from/this/mirror
wget -c http://xcache.lighttpd.net/pub/Releases/3.2.0/xcache-3.2.0.tar.gz
wget -c http://mirrors.ustc.edu.cn/maria ... 6-linux-i686.tar.gz
http://jaist.dl.sourceforge.net/ ... zabbix-2.4.3.tar.gz

解决依赖关系
yum groupinstall "Server Platform Development" ,"Development tools"
yum -y install pcre-devel
部署LNMP
一、安装Nginx:
tar xf nginx-1.6.2.tar.gz
cd nginx-1.6.2
首先添加用户nginx,实现以之运行nginx服务进程:
# groupadd -r nginx
# useradd -r -g nginx nginx
接着开始编译和安装:
# ./configure \
  --prefix=/usr/local/nginx \  
  --sbin-path=/usr/local/nginx/sbin/nginx \  
  --conf-path=/etc/nginx/nginx.conf \  
  --error-log-path=/var/log/nginx/error.log \  
  --http-log-path=/var/log/nginx/access.log \  
  --pid-path=/var/run/nginx/nginx.pid  \  
  --lock-path=/var/lock/nginx.lock \  
  --user=nginx \  
  --group=nginx \  
  --with-http_ssl_module \  
  --with-http_flv_module \  
  --with-http_stub_status_module \  
  --with-http_gzip_static_module \  
  --http-client-body-temp-path=/var/tmp/nginx/client/ \  
  --http-proxy-temp-path=/var/tmp/nginx/proxy/ \  
  --http-fastcgi-temp-path=/var/tmp/nginx/fcgi/ \  
  --http-uwsgi-temp-path=/var/tmp/nginx/uwsgi \  
  --http-scgi-temp-path=/var/tmp/nginx/scgi \  
  --with-http_spdy_module \  
  --with-http_realip_module \  
  --with-http_auth_request_module \  
  --with-file-aio \  
  --with-pcre
# make && make install  

为nginx提供SysV init脚本:
新建文件/etc/rc.d/init.d/nginx,内容如下:
#!/bin/sh
## nginx - this script starts and stops the nginx daemon
## chkconfig:   - 85 15
# description:  Nginx is an HTTP(S) server, HTTP(S) reverse \
#               proxy and IMAP/POP3 proxy server# processname: nginx
# config:      /etc/nginx/nginx.conf
# config:      /etc/sysconfig/nginx# pidfile:     /var/run/nginx.pid
# Source function library.. /etc/rc.d/init.d/functions
# Source networking configuration.. /etc/sysconfig/network
# Check that networking is up.
[ "$NETWORKING" = "no" ] && exit 0
nginx="/usr/local/nginx/sbin/nginx"prog=$(basename $nginx)
NGINX_CONF_FILE="/etc/nginx/nginx.conf"
[ -f /etc/sysconfig/nginx ] && . /etc/sysconfig/nginx
lockfile=/var/lock/subsys/nginx

make_dirs() {   
    # make required directories   
    user=`nginx -V 2>&1 | grep "configure arguments:" | sed 's/[^*]*--user=\([^ ]*\).*/\1/g' -`   
    options=`$nginx -V 2>&1 | grep 'configure arguments:'`   
    for opt in $options; do
           if [ `echo $opt | grep '.*-temp-path'` ]; then           
           value=`echo $opt | cut -d "=" -f 2`           
               if [ ! -d "$value" ]; then               
               # echo "creating" $value               
               mkdir -p $value && chown -R $user $value           
               fi      
           fi  
       done
      }
      
      start() {
          [ -x $nginx ] || exit 5   
          [ -f $NGINX_CONF_FILE ] || exit 6   
          make_dirs   
          echo -n $"Starting $prog: "   
          daemon $nginx -c $NGINX_CONF_FILE   
          retval=$?   
          echo   
          [ $retval -eq 0 ] && touch $lockfile   
          return $retval
     }
     
     stop() {
         echo -n $"Stopping $prog: "   
         killproc $prog -QUIT   
         retval=$?   
         echo   
         [ $retval -eq 0 ] && rm -f $lockfile   
         return
         $retval
     }
     
     restart() {
         configtest || return $?   
         stop   
         sleep 1   
         start
     }
     
     reload() {
         configtest || return $?   
         echo -n $"Reloading $prog: "   
          killproc $nginx -HUP   
          RETVAL=$?   
          echo
      }
      
      force_reload() {
          restart
      }
      
      configtest() {
        $nginx -t -c $NGINX_CONF_FILE
     }
     
     rh_status() {
         status $prog
     }
     
     rh_status_q() {
         rh_status >/dev/null 2>&1      
     }
     case "$1" in   
        start)
             rh_status_q && exit 0        
             $1        
             ;;   
        stop)
             rh_status_q || exit 0      
             $1        
             ;;   
        restart|configtest)   
            $1        
            ;;   
        reload)   
            rh_status_q || exit 7        
            $1        
            ;;   
        force-reload)   
            force_reload        
            ;;   
        status)   
            rh_status        
            ;;   
        condrestart|try-restart)  
            rh_status_q || exit 0            
            ;;   
            *)        
            echo $"Usage: $0 {start|stop|status|restart|condrestart|try-restart|reload|force-reload|configtest}"        
            exit 2esac
            
而后为此脚本赋予执行权限:
# chmod +x /etc/rc.d/init.d/nginx
添加至服务管理列表,并让其开机自动启动:
# chkconfig --add nginx# chkconfig nginx on
而后就可以启动服务并测试了:
# service nginx start

二:安装MariaDB
1、准备数据存放目录mkdir /mydata/data

2、建用户以安全方式运行进程:groupadd -r mysqluseradd -g mysql -r -s /sbin/nologin -M -d /mydata/data mysqlchown -R mysql:mysql /mydata/data

3、安装并初始化mariadb-10.0.15
   tar xf mariadb-10.0.15-linux-x86_64.tar.gz  -C /usr/local/
   cd /usr/local/
   ln -sv /usr/local/mariadb-10.0.15-linux-x86_64 /usr/local/mysql
   cd /usr/local/mysql
   chown -R mysql:mysql
   .scripts/mysql_install_db --user=mysql --datadir=/mydata/data

4、为mysql提供主配置文件:cp support-files/my-large.cnf  /etc/my.cnf
并修改此文件中thread_concurrency的值为你的CPU个数乘以2,
比如这里使用如下行:thread_concurrency = 8
另外还需要添加如下行指定mysql数据文件的存放位置:datadir = /mydata/data

5、为mysql提供sysv服务脚本:
# cd /usr/local/mysql# cp support-files/mysql.server  /etc/rc.d/init.d/mysqld
添加至服务列表:# chkconfig --add mysqld# chkconfig mysqld on 而后就可以启动服务测试使用了。  
为了使用mysql的安装符合系统使用规范,并将其开发组件导出给系统使用,这里还需要进行如下步骤:

6、输出mysql的man手册至man命令的查找路径: 编辑/etc/man.config,添加如下行即可:MANPATH  /usr/local/mysql/man

7、输出mysql的头文件至系统头文件路径/usr/include: 这可以通过简单的创建链接实现:
# ln -sv /usr/local/mysql/include  /usr/include/mysql

8、输出mysql的库文件给系统库查找路径: # echo '/usr/local/mysql/lib' > /etc/ld.so.conf.d/mysql.conf 而后让系统重新载入系统库:# ldconfig 9、修改PATH环境变量,让系统可以直接使用mysql的相关命令。
# vim /etc/profile.d/mysql.sh
export PATH=$PATH:/usr/local/mysql/bin

三、安装php-5.6.5解决依赖关系
yum install libjpeg-turbo-devel  libmcrypt-devel -y  
tar xf php-5.6.5.tar.gzcd  php-5.6.5
./configure --prefix=/usr/local/php \
    --with-mysql=mysqlnd \
    --with-pdo-mysql=mysqlnd \
    --with-mysqli=mysqlnd \
    --with-openssl \
    --enable-fpm \
    --enable-sockets \
    --enable-sysvshm  \
    --with-freetype-dir \
    --with-jpeg-dir \
    --with-png-dir \
    --with-zlib-dir \
    --with-libxml-dir=/usr \
    --enable-xml  \
    --with-mhash \
    --with-mcrypt  \
    --with-config-file-path=/etc \
    --with-config-file-scan-dir=/etc/php.d \
    --with-bz2 --with-curl  \
    --enable-bcmath \
    --enable-mbstring \
    --with-gd

make && make install

为php提供配置文件:
# cp php.ini-production /etc/php.ini

为php-fpm提供Sysv init脚本,并将其添加至服务列表:
# cp sapi/fpm/init.d.php-fpm  /etc/rc.d/init.d/php-fpm
# chmod +x /etc/rc.d/init.d/php-fpm
# chkconfig --add php-fpm
# chkconfig php-fpm on

为php-fpm提供配置文件:
# cp /usr/local/php/etc/php-fpm.conf.default /usr/local/php/etc/php-fpm.conf

编辑php-fpm的配置文件:
# vim /usr/local/php/etc/php-fpm.conf
配置fpm的相关选项为你所需要的值,并启用pid文件(如下最后一行):
pm.max_children = 150
pm.start_servers = 8
pm.min_spare_servers = 5
pm.max_spare_servers = 10
pid = /usr/local/php/var/run/php-fpm.pid  
接下来就可以启动php-fpm了:
# service php-fpm start
使用如下命令来验正(如果此命令输出有中几个php-fpm进程就说明启动成功了):
# ps aux | grep php-fpm整合nginx和php51、

编辑/etc/nginx/nginx.conf,
启用如下选项:
location ~ \.php$ {
             root           html;            
             fastcgi_pass   127.0.0.1:9000;            
             fastcgi_index  index.php;            
             fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;            
             include        fastcgi_params;
   }
   
   2、编辑/etc/nginx/fastcgi_params,将其内容更改为如下内容:
    fastcgi_param  GATEWAY_INTERFACE  CGI/1.1;
    fastcgi_param  SERVER_SOFTWARE    nginx;
    fastcgi_param  QUERY_STRING       $query_string;
    fastcgi_param  REQUEST_METHOD     $request_method;
    fastcgi_param  CONTENT_TYPE       $content_type;
    fastcgi_param  CONTENT_LENGTH     $content_length;
    fastcgi_param  SCRIPT_FILENAME    $document_root$fastcgi_script_name;
    fastcgi_param  SCRIPT_NAME        $fastcgi_script_name;
    fastcgi_param  REQUEST_URI        $request_uri;
    fastcgi_param  DOCUMENT_URI       $document_uri;
    fastcgi_param  DOCUMENT_ROOT      $document_root;
    fastcgi_param  SERVER_PROTOCOL    $server_protocol;
    fastcgi_param  REMOTE_ADDR        $remote_addr;
    fastcgi_param  REMOTE_PORT        $remote_port;
    fastcgi_param  SERVER_ADDR        $server_addr;
    fastcgi_param  SERVER_PORT        $server_port;
    fastcgi_param  SERVER_NAME        $server_name;
   
并在所支持的主页面格式中添加php格式的主页,类似如下:
location / {
            root   html;
            index  index.php index.html index.htm;
     }

而后重新载入nginx的配置文件:
# service nginx reload   

3、在/usr/html新建index.php的测试页面,测试php是否能正常工作:
# cat > /usr/local/nginx/html/index.php << EOF
<?php
phpinfo();
?>

接着就可以通过浏览器访问此测试页面了。


安装xcache,为php加速:

1、安装
# tar xf xcache-2.0.0.tar.gz
# cd xcache-2.0.0
# /usr/local/php/bin/phpize
# ./configure --enable-xcache --with-php-config=/usr/local/php/bin/php-config
# make && make install

安装结束时,会出现类似如下行:
Installing shared extensions:     /usr/local/php/lib/php/extensions/no-debug-zts-20100525/

2、编辑php.ini,整合php和xcache:

首先将xcache提供的样例配置导入php.ini
# mkdir /etc/php.d
# cp xcache.ini /etc/php.d

说明:xcache.ini文件在xcache的源码目录中。

接下来编辑/etc/php.d/xcache.ini,找到zend_extension开头的行,修改为如下行:
zend_extension = /usr/local/php/lib/php/extensions/no-debug-zts-20100525/xcache.so
或者:cp /usr/local/php/lib/php/extensions/no-debug-zts-20100525/xcache.so xcache.so /usr/local/php/include/php/ext/.
注意:如果php.ini文件中有多条zend_extension指令行,要确保此新增的行排在第一位。

3、重新启动php-fpm
# service php-fpm restart


补充说明
如果要在SSL中使用php,需要在php的location中添加此选项:
fastcgi_param HTTPS on;

部署安装zabbix
# tar xf zabbix-2.4.3.tar.gz
创建用户:
# groupadd zabbix
# useradd -g zabbix zabbix
# cd zabbix-2.4.3

创建数据库:

server和proxy的运行都依赖于数据库,agent则不需要。

以MySQL数据库为例:
# mysql> CREATE DATABASE zabbix CHARACTER SET utf8 COLLATE utf8_bin;
# mysql> GRANT ALL ON zabbix.* TO zabbix@'10.15.%.%' IDENTIFIED BY 'zabbix';

# 请按需要修改用户名和密码;
#  mysql -h10.15.201.104 -uzabbix -pzabbix zabbix < database/mysql/schema.sql

# 如果仅为proxy创建数据库,只导入schema.sql即可;否则,请继续下面的步骤;
#  mysql -h10.15.201.104 -uzabbix -pzabbix zabbix < database/mysql/images.sql
#  mysql -h10.15.201.104 -uzabbix -pzabbix zabbix < database/mysql/data.sql

编译安装zabbix:
# yum install net-snmp net-snmp-devel libssh2-devel

同时安装server和agent,并支持将数据放入mysql数据中,可使用类似如下配置命令:
./configure\
  --prefix=/usr/local/zabbix  \
  --enable-server --enable-agent \
  --with-mysql --enable-ipv6 \
  --with-net-snmp --with-libcurl \
  --with-ssh2  --with-libxml2
  
./configure\
--prefix=/usr/local/zabbix \
--enable-agent  \
--sysconfdir=/etc/zabbix
  
# make  && make install

配置zabbix:
server的配置文件为zabbix_server.conf,至少应该为其配置数据库等相关的信息;
agent的配置文件为zaabix_agentd.conf,至少应该为其指定server的IP地址;
proxy的配置文件为zabbix_proxy.conf,至少应该为其指定proxy的主机名和server的IP,以及数据库等相关的配置信息;

cd /usr/local/zabbix/etc
vim zabbix_server.conf
DBHost=10.15.201.104
DBName=zabbix
DBUser=zabbix

StartDiscoverers=3
CacheSize=64M

vim zabbix_agentd.conf
Server=10.15.201.104
EnableRemoteCommands=1     #执行远程命令
UnsafeUserParameters=1     #允许在自定义参数中使用所有特殊字符
ServerActive=10.15.201.104 #指定Server端的IP
Hostname=10.15.201.104     #最好使用agent节点的IP

cp misc/init.d/fedora/core/zabbix_* /etc/init.d/
chmod +x /etc/init.d/zabbix_*
chkconfig --add zabbix_agentd
chkconfig --add zabbix_server

vim /etc/init.d/zabbix_server
BASEDIR=/usr/local/zabbix

vim /etc/init.d/zabbix_agentd
BASEDIR=/usr/local/zabbix

cd /opt/zabbix-2.4.3
cp -a  frontends/php/*   /usr/local/nginx/html/zabbix/
QQ截图20150717093105.png
QQ截图20150717093111.png
需要修改php.ini 并重启php-fpm
# vim /etc/php.ini
post_max_size = 16M
max_execution_time = 300
max_input_time = 300
date.timezone = Asia/Shanghai
always_populate_raw_post_data = 1

cd /opt/php-5.6.5/ext/gettext
/usr/local/php/bin/phpize
./configure --with-php-config=/usr/local/php/bin/php-config
mkae && make install
vim /etc/php.ini
extension = /usr/local/php/lib/php/extensions/no-debug-non-zts-20131226/gettext.so
QQ截图20150717093120.png
QQ截图20150717093125.png
QQ截图20150717093129.png
QQ截图20150717093134.png
QQ截图20150717093139.png
QQ截图20150717093145.png

注意:
zabbix优化

1. CacheSize=64M  增大缓存
2. StartDiscoverers=3 该值默认为1  如不调大该值则会一直报警Zabbix discoverer processes more than 75% busy

3. 将zabbix的 Template App Zabbix Agent  模版中的 Item "Agent ping" 的 Store value 和 Show value 两个值得类型都调整为"As is",否则会报"Zabbix agent on  is unreachable for 2 minutes"


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-87526-1-1.html 上篇帖子: zabbix之监控MySQL服务器(可用于主从架构) 下篇帖子: grafana-zabbix安装简明教程
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表