nginx跟据url进行分流

本文介绍如何使用Nginx配置文件实现基于URL后缀的请求转发策略,将不同URL后缀的请求定向到特定的服务器。
需求让Nginx跟据请求的url不同,而转发到不同的server上
举例:
url http://127.0.0.1/json/0769/
url http://127.0.0.1/json/0734/
需求把url后缀为0769的请求转发到server1, url 后缀为0734的请求转发到server1

nginx.conf实现代码

worker_processes 2;

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

events {
    worker_connections 1024;
    use epoll;
}

http {
    charset utf-8;

    map $zone $up_stream {
    	^~0769	frontends_0769;
    	^~0734	frontends_0734;        
    	default	frontends_0769;
    }

    # Enumerate all the Tornado servers here
    upstream frontends_0769 {
        server 127.0.0.1:3333;
        #server 127.0.0.1:3334;
        #server 127.0.0.1:3335;
        #server 127.0.0.1:3336;
    }
    
    upstream frontends_0734 {
        server 127.0.0.1:3334;
        #server 127.0.0.1:3334;
        #server 127.0.0.1:3335;
        #server 127.0.0.1:3336;
    }    

    include mime.types;
    default_type application/octet-stream;

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

    keepalive_timeout 65;
    proxy_read_timeout 200;
    sendfile on;
    tcp_nopush on;
    tcp_nodelay on;
    gzip on;
    gzip_min_length 1000;
    gzip_proxied any;
    gzip_types text/plain text/css text/xml
               application/x-javascript application/xml
               application/atom+xml text/javascript;

    # Only retry if there was a communication error, not a timeout
    # on the Tornado server (to avoid propagating "queries of death"
    # to all frontends)
    proxy_next_upstream error;

    server {
        listen 8089;

        location / {
            proxy_pass_header Server;
            proxy_set_header Host $http_host;
            proxy_redirect off;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Scheme $scheme;
            #proxy_pass http://frontends;
            #if ( $request_uri ~* /json/(\d\d\d\d)\d+/ ) {
            #    set $zone $1;
            #    proxy_pass http://frontends_$zone;
            #}
            if ( $request_uri ~ ^/json/(\d+)/$ ) {
                set $zone $1;
                proxy_pass http://$up_stream;
            }            
            
        }
    }
}



<think>我们之前讨论的是快速排序,但用户现在询问的是Nginx分流程序。需要切换话题。 用户想要查找“nginx完整的分流程序”,即Nginx实现请求分流的配置方案。 通常,Nginx分流可以通过多种方式实现,例如:基于域名的分流、基于路径的分流、基于客户端IP的分流、基于权重的负载均衡等。 我将提供一个基于路径分流的示例配置,并解释关键部分。 注意:由于用户要求“完整的分流程序”,我将提供一个完整的配置示例,包括必要的上下文,但也会提醒用户根据实际环境调整。 另外,根据系统指令,需要生成相关问题,并且使用中文回答,数学公式用指定格式(虽然这里可能用不到数学公式,但如果有变量等,会使用$...$)。 配置示例将使用代码块,并添加注释说明。 </think>### Nginx请求分流配置指南 Nginx通过`upstream`模块和`location`规则实现请求分流,完整配置示例如下: ```nginx # 定义后端服务器组(负载均衡池) upstream backend_cluster { # 轮询分流策略(可替换为ip_hash/least_conn) server 192.168.1.10:8080 weight=3; # 权重分配比例3/8 server 192.168.1.11:8080 weight=5; # 权重分配比例5/8 server backup.example.com:8080 backup; # 备用节点 } server { listen 80; server_name example.com; # 路径分流:/api请求转给后端集群 location /api/ { proxy_pass http://backend_cluster; proxy_set_header Host $host; } # 文件类型分流:静态资源直返 location ~* \.(jpg|css|js)$ { root /var/www/static; expires 30d; # 缓存控制 } # 地理分流:海外用户重定向 location / { if ($geoip_country_code != CN) { proxy_pass http://overseas_backend; } # 默认处理 proxy_pass http://default_backend; } } ``` #### 核心分流策略 1. **负载均衡** - 权重分流:`weight`参数控制流量分配比例(如`3:5`) - 会话保持:`ip_hash`确保同一客户端固定后端[^1] 2. **路径分流** 通过`location`匹配URL路径: ```nginx location /mobile/ { proxy_pass http://mobile_backend; } location /admin/ { proxy_pass http://admin_backend; } ``` 3. **动态条件分流** - 基于请求头:`map $http_user_agent $backend { ... }` - 基于地理IP:`geoip_country`模块 > **重要**:分流后需添加健康检查 > ```nginx > health_check interval=10s fails=3 passes=2; > ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值