本篇文章对于在服务器已经安装了nginx,但却希望使用Tengine 的状态检查或其他功能时使用,不需要卸载服务器上的nginx,思路是使用干净服务器(未安装过nginx)通过编译安装Tengine,通过对./configure的配置,保证安装Tengine的环境与nginx服务器相同,(同时,加入需要的Tengine模块),编译,最后将nginx代码传送至nginx服务器对应位置,覆盖原先nginx代码,完成nginx服务器上Tengine功能的更新。
1.前往Changelog - The Tengine Web Server,下载最新的tengine的tar包
2.解压tar包并进入目录中
3.编译安装前,安装依赖
yum install -y gcc make pcre pcre-devel openssl openssl-devel zlib zlib-devel geoip geoip-devel perl perl-devel gperftools gperftools-devel libxslt libxslt-devel
yum install -y gd-devel
yum -y install perl-ExtUtils-Embed
此处例举大部分依赖,若下面出现问题大概率是此处缺少其他依赖
4.在已经配置好nginx的机器上,使用nginx -V,查看nginx的configure argument
--prefix=/usr/share/nginx --sbin-path=/usr/sbin/nginx --modules-path=/usr/lib64/nginx/modules --conf-path=/etc/nginx/nginx.conf --error-log-path=/var/log/nginx/error.log --http-log-path=/var/log/nginx/access.log --http-client-body-temp-path=/var/lib/nginx/tmp/client_body --http-proxy-temp-path=/var/lib/nginx/tmp/proxy --http-fastcgi-temp-path=/var/lib/nginx/tmp/fastcgi --http-uwsgi-temp-path=/var/lib/nginx/tmp/uwsgi --http-scgi-temp-path=/var/lib/nginx/tmp/scgi --pid-path=/run/nginx.pid --lock-path=/run/lock/subsys/nginx --user=nginx --group=nginx --with-compat --with-debug --with-file-aio --with-google_perftools_module --with-http_addition_module --with-http_auth_request_module --with-http_dav_module --with-http_degradation_module --with-http_flv_module --with-http_gunzip_module --with-http_gzip_static_module --with-http_image_filter_module=dynamic --with-http_mp4_module --with-http_perl_module=dynamic --with-http_random_index_module --with-http_realip_module --with-http_secure_link_module --with-http_slice_module --with-http_ssl_module --with-http_stub_status_module --with-http_sub_module --with-http_v2_module --with-http_xslt_module=dynamic --with-mail=dynamic --with-mail_ssl_module --with-pcre --with-pcre-jit --with-stream=dynamic --with-stream_ssl_module --with-stream_ssl_preread_module --with-threads --with-cc-opt='-O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector-strong --param=ssp-buffer-size=4 -grecord-gcc-switches -specs=/usr/lib/rpm/redhat/redhat-hardened-cc1 -m64 -mtune=generic' --with-ld-opt='-Wl,-z,relro -specs=/usr/lib/rpm/redhat/redhat-hardened-ld -Wl,-E'
5.配置环境,在目录中运行如下命令(./configure 上面复制的配置信息+需要添加的模块)
注意:此处需要在tengine目录下,因为下面使用的是相对地址
因为tengine服务把ngx常用的第3方模块放在了源代码中的modules目录下面。
--add-module=modules/ngx_http_upstream_check_module 编译安装的时候增加upstream_check模块
--add-module=modules/ngx_http_upstream_session_sticky_module/ 增加会话共享模块
./configure --prefix=/usr/share/nginx --sbin-path=/usr/sbin/nginx --modules-path=/usr/lib64/nginx/modules --conf-path=/etc/nginx/nginx.conf --error-log-path=/var/log/nginx/error.log --http-log-path=/var/log/nginx/access.log --http-client-body-temp-path=/var/lib/nginx/tmp/client_body --http-proxy-temp-path=/var/lib/nginx/tmp/proxy --http-fastcgi-temp-path=/var/lib/nginx/tmp/fastcgi --http-uwsgi-temp-path=/var/lib/nginx/tmp/uwsgi --http-scgi-temp-path=/var/lib/nginx/tmp/scgi --pid-path=/run/nginx.pid --lock-path=/run/lock/subsys/nginx --user=nginx --group=nginx --with-compat --with-debug --with-file-aio --with-google_perftools_module --with-http_addition_module --with-http_auth_request_module --with-http_dav_module --with-http_degradation_module --with-http_flv_module --with-http_gunzip_module --with-http_gzip_static_module --with-http_image_filter_module=dynamic --with-http_mp4_module --with-http_perl_module=dynamic --with-http_random_index_module --with-http_realip_module --with-http_secure_link_module --with-http_slice_module --with-http_ssl_module --with-http_stub_status_module --with-http_sub_module --with-http_v2_module --with-http_xslt_module=dynamic --with-mail=dynamic --with-mail_ssl_module --with-pcre --with-pcre-jit --with-stream=dynamic --with-stream_ssl_module --with-stream_ssl_preread_module --with-threads --with-cc-opt='-O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector-strong --param=ssp-buffer-size=4 -grecord-gcc-switches -specs=/usr/lib/rpm/redhat/redhat-hardened-cc1 -m64 -mtune=generic' --with-ld-opt='-Wl,-z,relro -specs=/usr/lib/rpm/redhat/redhat-hardened-ld -Wl,-E' --add-module=modules/ngx_http_upstream_check_module/ --add-module=modules/ngx_http_upstream_session_sticky_module/
6.进行编译
make -j 1 这里1为cpu核心,或者直接make也可以
正常这一步如果要安装Tengine,make install 即可,这里不需要安装。
7.将当前目录下的objs下的nginx代码传到负载均衡服务器
scp ./objs/nginx lb01:~
8.负载均衡服务器检查./nginx -V,检查scp过来的nginx信息
注意图片最后两行已经加了对应的模块
9.将nginx代码替换掉原来的,scp是传至家目录,所以下面两条命令执行也是在家目录下。
mv /sbin/nginx /sbin/nginx1
mv nginx /sbin/nginx
10.nginx -V,检查nginx信息,此时已经可以看到信息如第8步一致
注意:第八步看的是家目录下的nginx代码信息,此处看的是服务器nginx代码信息
nginx -t,检查语法
kill -USR2 pid (通过老的命令向当前运行的ngx发送信号,准备被新的ngx进程替代)
kill pid(之前的ngx服务)
systemctl restart nginx 重新启动nginx。
11.对需要状态检查的页面进行配置,可以参考Tengine官网(ngx_http_upstream_check_module - The Tengine Web Server)
配置完成即可查看各个web服务器信息
12.各个参数
check interval=3000 rise=2 fall=5 timeout=1000 type=http;
检查间隔3000ms,成功两次即为活跃状态,失败五次即为挂掉状态,检查类型为http请求
check_http_send 代理向web服务器通过http方式发出请求报文,请求报文起始行,请求方法, 请求的URI,请求协议(默认使用的是ip方式 访问
check_http_expect_alive 收到指定的状态码,就认为是存活的