摘要:
Centos7下yum直接安装的nginx添加第三方模块支持tcp,生产有个接口是通过socket通信,为了统一Socket端口,就需要用nginx做端口转发,nginx1.9开始支持tcp层的转发,通过stream实现的,而socket也是基于tcp通信,Nginx新增TCP转发支持实现方法:Centos7.2下yum直接安装的nginx,添加新模块支持tcp转发;重新编译Nginx并添加 --with-stream 参数。
配置方法:
1、查看nginx版本模块
[root@pre ~]# nginx -V
2、下载同版本可编译的nginx
cd /opt wget http://nginx.org/download/nginx-1.12.2.tar.gz tar xf nginx-1.12..tar.gz && cd nginx-1.12.
3、备份原nginx文件
mv /usr/sbin/nginx /usr/sbin/nginx.bak cp -r /etc/nginx{,.bak}
4、重新编译nginx
根据第1步查到已有的模块,加上本次需新增的模块: --with-stream
cd /opt/nginx-1.12. ./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-file-aio--with-ipv6 --with-http_auth_request_module --with-http_ssl_module --with-http_v2_module --with-http_realip_module --with-http_addition_module--with-http_xslt_module=dynamic --with-http_image_filter_module=dynamic --with-http_geoip_module=dynamic --with-http_sub_module --with-http_dav_module--with-http_flv_module --with-http_mp4_module --with-http_gunzip_module --with-http_gzip_static_module --with-http_random_index_module--with-http_secure_link_module --with-http_degradation_module --with-http_slice_module --with-http_stub_status_module --with-http_perl_module=dynamic--with-mail=dynamic --with-mail_ssl_module --with-pcre --with-pcre-jit --with-stream=dynamic --with-stream_ssl_module --with-debug--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' --with-stream
以上编译时,如出现缺少依赖,一般需要安装以下模块,安装完再次编译:
yum -y install libxml2 libxml2-dev libxslt-devel yum -y install gd-devel yum -y install perl-devel perl-ExtUtils-Embed yum -y install GeoIP GeoIP-devel GeoIP-data yum -y install pcre-devel yum -y install openssl openssl-devel gperftools
5、编译通过后继续验证
继续输入:make make完成后不要继续输入“make install”,以免现在的nginx出现问题 以上完成后,会在objs目录下生成一个nginx文件,先验证: /opt/nginx-1.12./objs/nginx -t /opt/nginx-1.12./objs/nginx -V
6、替换Nginx文件并重启
cp /opt/nginx-1.12./objs/nginx /usr/sbin/ nginx -s reload
7、检查
[root@pre ~]# nginx -V
END!!!(
- 摘要:
- 1、查看nginx版本模块
- 2、下载同版本可编译的nginx
- 3、备份原nginx文件
- 4、重新编译nginx
- 5、编译通过后继续验证
- 6、替换Nginx文件并重启
- 7、检查
发表评论