nginx中根据请求参数的不同将请求转发到不同的服务(map模块的使用)

需求:有一个文本翻译的接口,需要根据原语、目标语、以及apikey的不同转发到不同的服务;

实现:可以使用Nginx的map模块来实现基于请求参数的转发。具体实现步骤如下:

在Nginx配置文件中定义一个map块,用于根基请求参数判断对应的转发地址,$arg_apikey是获取请求参数中的apikey,from、to同理,如果请求参数中没有param参数,将会使用default的值,基本配置如下:

    map "$arg_apikey:$arg_from:$arg_to" $myServer {
    
    
        "mykey:zh:en" "172.16.1.3";
        "mykey:zh:ja" "172.16.1.3";
        "mykey:en:zh" "172.16.1.3";
        "mykey:en:ja" "172.16.1.3";
        default "172.16.1.2";
    }

注意:map块的定义应该放在http块中,而不是server块中,以确保map块能够被所有的server块共享

然后在Nginx的server块中,就可以使用变量$myServer作为proxy_pass的参数,就实现了需要根据原语、目标语、以及apikey的不同转发到不同的服务的需求,如下:

server {
    
    
    listen       80;
    location / {
    
    
        proxy_pass  $myServer;
    }
}

全量配置:

user  nginx;
worker_processes  1;

error_log  /var/log/nginx/error.log warn;
pid        /var/run/nginx.pid;


events {
    
    
    worker_connections  1024;
}


http {
    
    
    include       /etc/nginx/mime.types;
    default_type  application/octet-stream;

    log_format  main escape=json  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';

    access_log  /var/log/nginx/access.log  main;

    sendfile        on;
    #tcp_nopush     on;

    keepalive_timeout  65;

    #gzip  on;

    include /etc/nginx/conf.d/*.conf;

    charset utf-8;
 
    map "$arg_apikey:$arg_from:$arg_to" $myServer {
    
    
        "mykey:zh:en" "172.16.1.3";
        "mykey:zh:ja" "172.16.1.3";
        "mykey:en:zh" "172.16.1.3";
        "mykey:en:ja" "172.16.1.3";
        default "172.16.1.2";
    }
    server {
    
    
        listen      80 default_server;
        listen      [::]:80 default_server;
        charset     utf-8;
        add_header Access-Control-Allow-Origin *;
        add_header Access-Control-Allow-Methods *;

        location ^~/NiuTransServer/translation {
    
    
          proxy_pass  http://$myServer;
          proxy_set_header Host $host;
          proxy_set_header X-Real-IP $remote_addr;
          proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        }
    }

}

猜你喜欢

转载自blog.csdn.net/weixin_43702146/article/details/130425632