为nginx启用ngx_http_v2_module模块

生产环境的nginx当初没有编译启用ngx_http_v2_module模块

[root@nginx51 ~]# /opt/nginx/sbin/nginx -V
nginx version: nginx/1.12.0
built by gcc 4.4.7 20120313 (Red Hat 4.4.7-18) (GCC) 
built with OpenSSL 1.0.1e-fips 11 Feb 2013
TLS SNI support enabled
configure arguments: --prefix=/opt/nginx --user=nginx --group=nginx --with-http_gzip_static_module --with-http_ssl_module --with-http_stub_status_module --with-pcre=/tmp/pcre-8.40 --with-stream 

现在业务上要用到这个模块,需要把它重新编译进去但不影响业务

步骤:

进入到nginx源码目录重新编译,通过--with-http_v2_module启用ngx_http_v2_module模块,然后make (注意不要make install,否则直接覆盖了)

cd /tmp/nginx-1.12.0                # nginx源码版本必须和当前生产环境的nginx一致
./configure --prefix=/opt/nginx --user=nginx --group=nginx --with-http_gzip_static_module --with-http_ssl_module --with-http_stub_status_module --with-pcre=/tmp/pcre-8.40 --with-stream --with-http_v2_module
make

meke好了之后会在源码目录下的objs目录产生nginx的二进制,先不要make install

[root@nginx51 objs]# cd /tmp/nginx-1.12.0/objs/
[root@nginx51 objs]# ls
autoconf.err  Makefile  nginx  nginx.8  ngx_auto_config.h  ngx_auto_headers.h  ngx_modules.c  ngx_modules.o  src

然后把原先的nginx二进制命令备份,用上面编译好的nginx替换,最后reload的nignx就可以

[root@nginx51 ~]# cd /opt/nginx/sbin/
[root@nginx51 sbin]# mv nginx nginx.bak                 # 备份
[root@nginx51 sbin]# cp /tmp/nginx-1.12.0/objs/nginx .  # 把编译好的nginx拷贝过来
[root@nginx51 sbin]# service nginx reload               # 重载nginx

在通过nginx -V测试,可以看到--with-http_v2_module,说明ok了

[root@nginx51 sbin]# /opt/nginx/sbin/nginx -V
nginx version: nginx/1.12.0
built by gcc 4.4.7 20120313 (Red Hat 4.4.7-18) (GCC) 
built with OpenSSL 1.0.1e-fips 11 Feb 2013
TLS SNI support enabled
configure arguments: --prefix=/opt/nginx --user=nginx --group=nginx 
--with-http_gzip_static_module --with-http_ssl_module --with-http_stub_status_module
--with-pcre=/tmp/pcre-8.40 --with-stream --with-http_v2_module

其它模块的启用也是类似的。顺便说下make和make install, make是把源码编译成可执行的二进制,make install是把编译好的二进制或一些文件安装到指定的路径.

另外nginx1.10版本可以动态添加模块

 

posted @ 2018-03-06 07:38  opss  阅读(4686)  评论(0编辑  收藏  举报