程序员

Nginx这个功能厉害了!

作者:admin 2021-04-30 我要评论

1. 需求 将生产环境的流量拷贝到预上线环境或测试环境,这样做有很多好处,比如: 可以验证功能是否正常,以及服务的性能; 用真实有效的流量请求去验证,又不用...

在说正事之前,我要推荐一个福利:你还在原价购买阿里云、腾讯云、华为云服务器吗?那太亏啦!来这里,新购、升级、续费都打折,能够为您省60%的钱呢!2核4G企业级云服务器低至69元/年,点击进去看看吧>>>)

 

1. 需求

将生产环境的流量拷贝到预上线环境或测试环境,这样做有很多好处,比如:

  •  可以验证功能是否正常,以及服务的性能;
  •  用真实有效的流量请求去验证,又不用造数据,不影响线上正常访问;
  •  这跟灰度发布还不太一样,镜像流量不会影响真实流量;
  •  可以用来排查线上问题;
  •  重构,假如服务做了重构,这也是一种测试方式;

为了实现流量拷贝,Nginx提供了ngx_http_mirror_module模块

2. 安装Nginx

首页,设置yum仓库。为此,创建一个文件/etc/yum.repos.d/nginx.repo

将以下内容写入文

  1. [nginx-stable]  
  2. name=nginx stable repo  
  3. baseurl=http://nginx.org/packages/centos/$releasever/$basearch/  
  4. gpgcheck=1  
  5. enabled=1  
  6. gpgkey=https://nginx.org/keys/nginx_signing.key  
  7. module_hotfixes=true  
  8. [nginx-mainline]  
  9. name=nginx mainline repo  
  10. baseurl=http://nginx.org/packages/mainline/centos/$releasever/$basearch/  
  11. gpgcheck=1  
  12. enabled=0  
  13. gpgkey=https://nginx.org/keys/nginx_signing.key  
  14. module_hotfixes=true 

yum安装nginx

  1. yum install nginx -y 

默认情况下,nginx配置文件是nginx.conf

一般情况下,nginx.conf文件在 /usr/local/nginx/conf  或者 /etc/nginx  或者 /usr/local/etc/nginx 目录下

为了启动nginx,直接在命令行里输入nginx回车即可

  1. # 启动nginx  
  2. nginx  
  3. # fast shutdown  
  4. nginx -s stop  
  5. # graceful shutdown  
  6. nginx -s quit  
  7. # reloading the configuration file  
  8. nginx -s reload  
  9. # reopening the log files  
  10. nginx -s reopen  
  11. # list of all running nginx processes  
  12. ps -ax | grep nginx 

一旦master进程接收到重新加载配置的信号,它将检查新配置文件的语法是否正确,并尝试应用其中提供的配置。如果成功,master进程将启动新的worker进程,并发送消息给旧的worker进程,要求他们shutdown。否则,master进程将回滚所做的更改,并继续使用旧配置。旧的worker进程在接收到关闭命令后,停止接受新的连接,直到所有之前已经接受的连接全部处理完为止。之后,旧的worker进程退出。

nginx的master进程的进程ID,默认情况下,放在nginx.pid文件中,该文件所在的目录一般是/usr/local/nginx/logs 或者 /var/run。

还可以这样停止nginx

  1. kill -s QUIT 3997 

初始配置文件长这样:

  1. user  nginx;  
  2. worker_processes  1;  
  3. error_log  /var/log/nginx/error.log warn;  
  4. pid        /var/run/nginx.pid;  
  5. events {  
  6.     worker_connections  1024;  
  7.  
  8. http {  
  9.     include       /etc/nginx/mime.types;  
  10.     default_type  application/octet-stream;  
  11.     log_format  main '$remote_addr - $remote_user [$time_local] "$request" '  
  12.                       '$status $body_bytes_sent "$http_referer" '  
  13.                       '"$http_user_agent" "$http_x_forwarded_for"';   
  14.     access_log  /var/log/nginx/access.log main;  
  15.     sendfile        on;  
  16.     #tcp_nopush on;  
  17.     keepalive_timeout  65;  
  18.     #gzip on;  
  19.     include /etc/nginx/conf.d/*.conf;  

3. ngx_http_mirror_module

The ngx_http_mirror_module module (1.13.4) implements mirroring of an original request by creating background mirror subrequests. Responses to mirror subrequests are ignored.

我是这样理解的,这里,mirror本意是镜子、镜像,这里可以理解就像一个镜像站点一样,将所有的请求都收集起来,这个镜像就代表了所有真实有效的原始请求。有了这个镜像,后续我们才可能用这个镜像去做一些事情,比如重现一下所有的请求,这就实现了把线上的流程复制到别的地方。

官网给出的示例倒是很简单,如下:

  1. location / {  
  2.     mirror /mirror;  
  3.     proxy_pass http://backend;  
  4.  
  5. location = /mirror {  
  6.     internal;  
  7.     proxy_pass http://test_backend$request_uri;  

如果请求体被镜像,那么在创建子请求之前会先读取请求体。

  1. location / {  
  2.     mirror /mirror;  
  3.     mirror_request_body off;  
  4.     proxy_pass http://backend;  
  5.  
  6. location = /mirror {  
  7.     internal;  
  8.     proxy_pass http://log_backend;  
  9.     proxy_pass_request_body off;  
  10.     proxy_set_header Content-Length "";  
  11.     proxy_set_header X-Original-URI $request_uri;  

前面我们安装了Nginx,但是里面没有包含我们所需的ngx_http_mirror_module模块,因此,真正要使用的时候最好还是采用自定义安装,即从源码构建。

首先,下载源码  http://nginx.org/en/download.html

接下来,编译安装,例如:

  1. ./configure  
  2.     --sbin-path=/usr/local/nginx/nginx  
  3.     --conf-path=/usr/local/nginx/nginx.conf  
  4.     --pid-path=/usr/local/nginx/nginx.pid  
  5.     --with-http_ssl_module  
  6.     --without-http_limit_req_module  
  7.     --without-http_mirror_module  
  8.     --with-pcre=../pcre-8.43  
  9.     --with-zlib=../zlib-1.2.11  
  10.     --add-module=/path/to/ngx_devel_kit  
  11.     --add-module=/path/to/lua-nginx-module   
  12. make & make install 

配置

  1. upstream api.abc.com {  
  2.   server 127.0.0.1:8080;  
  3.  
  4. upstream tapi.abc.com {  
  5.     server 127.0.0.1:8081;  
  6.  
  7. server {  
  8.     listen 80;  
  9.    # 源站点  
  10.     location /api {  
  11.         proxy_pass http://api.cjs.com;  
  12.         proxy_set_header Host $host;  
  13.         proxy_set_header X-Real-IP $remote_addr;  
  14.         proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;  
  15.         # 流量复制  
  16.   mirror /newapi;  
  17.   mirror /mirror2;  
  18.   mirror /mirror3;  
  19.   # 复制请求体  
  20.   mirror_request_body on;  
  21.     }  
  22.     # 镜像站点  
  23.     location /tapi {  
  24.         proxy_pass http://tapi.cjs.com$request_uri;  
  25.         proxy_pass_request_body on;  
  26.         proxy_set_header Host $host;  
  27.         proxy_set_header X-Real-IP $remote_addr;  
  28.         proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;  
  29.     }  

4. 文档

Nginx文档

http://nginx.org/en/docs/

http://nginx.org/en/docs/http/ngx_http_mirror_module.html

http://nginx.org/en/docs/beginners_guide.html

http://nginx.org/en/docs/http/ngx_http_core_module.html#location 

http://nginx.org/en/docs/configure.html

第三方模板 

http://luajit.org/

https://www.nginx.com/resources/wiki/

https://www.nginx.com/resources/wiki/modules/lua/

https://www.nginx.com/resources/wiki/modules/index.html

https://github.com/openresty/lua-nginx-module  

补充

  1. # 查看进程运行时间  
  2. ps -eo pid,user,lstart,etime,cmd | grep nginx  
  3. # 查看已经建立连接的数量  
  4. netstat -an | grep ESTABLISHED | wc -l  
  5. # 查看80端口的连接数  
  6. netstat -an | grep ":80" | wc -l  

本文转载自网络,原文链接:https://mp.weixin.qq.com/s/Q076k7Jbr28yL-SI_4poIw

版权声明:本文转载自网络,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。本站转载出于传播更多优秀技术知识之目的,如有侵权请联系QQ/微信:153890879删除

相关文章
  • 高频考点之六大进程通信机制

    高频考点之六大进程通信机制

  • 聊聊Git版本控制工具使用说明和规范

    聊聊Git版本控制工具使用说明和规范

  • 微软计划合并 Windows10 累积和服务堆

    微软计划合并 Windows10 累积和服务堆

  • Windows10这功能已如同残废!教你如何

    Windows10这功能已如同残废!教你如何

腾讯云代理商
海外云服务器