Nginx之负载均衡

HTTP

http {
    upstream backend {
        # 负载均衡算法 Round Robin、Least Connections、IP Hash、Generic Hash
        # Least Time、Random仅plus支持
        # 默认为Round Robin 轮询
        # Least Connections:指定为least_conn; 将请求发送到最少活跃连接数的server
        # IP Hash:指定为ip_hash; ip地址哈希 请求发送到的服务器由客户端IP地址确定 
        # Generic Hash:发送请求的服务器由用户定义的键确定
        server backend1.example.com weight=5;
        # 轮询算法中,每个server默认权重为1 
        server backend2.example.com;
        # 仅当上面两个server不可用时才会发请求
        server 192.0.0.1 backup; 
        
    }
    
    server {
        location / {
            # proxy_pass中http后设置为upsteam组的名字
            proxy_pass http://backend; 
        }
    }
}

TCP与UDP

stream {
    upstream stream_backend {
        # 轮询算法:Round Robin、Least Connections、Hash、Random
        # 默认为轮询算法
        # Hash:根据用户定义的键来选择服务器 例:hash $remote_addr; 根据源IP
        # Random:random
        least_conn;
        server backend1.example.com:12345 weight=5;
        server backend2.example.com:12345 max_fails=2 fail_timeout=30s;
        server backend3.example.com:12345 max_conns=3;
    }
    
    upstream dns_servers {
        least_conn;
        server 192.168.136.130:53;
        server 192.168.136.131:53;
        server 192.168.136.132:53;
    }
    # 定义虚拟代理服务器代理stream_backend组 通过proxy_pass参数指定
    server {
        listen        12345;
        proxy_pass    stream_backend;
        proxy_timeout 3s;
        proxy_connect_timeout 1s;
    }
    
    server {
        listen     53 udp;
        proxy_pass dns_servers;
    }
    # 也可以将流量代理到单个服务器
    server {
        listen     12346;
        proxy_pass backend4.example.com:12346;
    }
}

请求分发原理

以listen 12345为例

  • 客户端发出的请求http://xxxx:12345/,由于Nginx监听了机器的12345 端口,所以最终该请求会找到Nginx进程;
  • Nginx首先会根据配置的proxy_pass找到名为stream_backend的upstream;
  • 最后根据upstream中的配置信息,将请求转发到后端运行服务的机器处理;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值