负载均衡的配置,是为了实现程序的高并发和可用性进行服务器访问配置
负载均衡是指将用户的请求分配到多个后端服务器上进行处理,以达到优化资源利用率、提高响应速度和增加系统的可靠性的目的。负载均衡器通常位于用户和服务器之间,接收用户的请求,并根据某种算法将请求分发给合适的后端服务器
在nginx中,可以使用upstream模板来配置后端服务器集群组,并使用server指令指定服务器的地址和参数。然后在server配置中使用proxy_pass 指令请求转发到定义好的服务器群组。
http { upstream backend { server backend1.example.com; server backend2.example.com; server backend3.example.com; # 可以设置权重 server backend4.example.com weight=2; } server { listen 80; location / { proxy_pass http://backend; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-Proto $scheme; } } }
在这个upstream 定义了一个名为 backend 的服务器群组。三个服务器通过server指定添加到群组中,第四个服务器有一个额外的weight参数,用于指定更高的权重。意味着负载均衡中将更倾向于分配更多的请求给它。
- listen 指令指定了监听的端口。
- location / 指定了对于所有请求,使用 proxy_pass 指令转发到定义的服务器群组。
- 几个 proxy_set_header 指令用于确保正确地转发原始请求信息
轮询算法是最简单的负载均衡算法之一,它按照顺序将请求依次分发给每个后端服务器。当所有服务器都被分配了一次请求后,重新开始下一轮分配。
优点:简单以实现/适应于后端服务器性能相近的情况
缺点:无法考虑服务器的负载情况,不适用于后端服务器性能差异较大的情况。
通过配置, Nginx将以轮询的方式默认分配进入的请求到上面定义的后端服务器,可以通过upstream中添加额外参数来调整负载均衡算法
例如使用:ip_hash保持会话或者使用least_conn进行最少连接数的负载均衡。
配置过程中可以新增健康检查,以确保请求分配给健康的后端服务器,可以使用
ngx_http_upstream_check_module
模块实现健康检查
http { upstream backend { server backend1.example.com; server backend2.example.com; check interval=5000 rise=2 fall=5 timeout=3000; } server { listen 80; server_name example.com; location / { proxy_pass http://backend; } } }