nginx负载均衡及配置

1 负载均衡概述

  1. 负载均衡由来是因为当一台服务器单位时间内的访问量很大时,此时服务器的压力也会很大,当超过自身承受能力时,服务器就会崩溃.为避免让服务器崩溃,用户拥有更好的体验,就诞生了负载均衡来分担服务器压力.
  2. 负载均衡实质上就是用反向代理的原理实现的,是一种优化服务器资源,合理处理高并发的一种技术,能够平衡个服务器的压力,减少用户请求等待时间,并确保容错.一般采用nginx作为一种高效的HTTP负载均衡服务器,将流量分配到多个应用服务器上以提高性能,可扩展和高可用性.
  3. 原理: 内网可以建很多服务器,组成服务器集群,当用户访问该网站时,先访问公网中间服务器,中间服务器根据算法合理分配到内网服务器,分担服务器的压力,因此户的每次访问,都会保证服务器集群中的每个服务器压力趋于平衡,分担了服务器压力,避免了服务器崩溃的情况。
  4. nginx反向代理实现包括下面这些负载均衡HTTPHTTPSFastCGIuwsgiSCGImemcached
  5. 要配置HTTPS的负载均衡,只需使用'http'开头的协议。
  6. 当要设置FastCGIuwsgiSCGI,或者memcached的负载平衡,分别使用fastcgi_passuwsgi_passscgi_passmemcached_pass指令。

2 负载均衡的常见平衡机制

1 轮询(round-robin) :以轮询方式将请求分配到不同服务器上,每个请求按时间顺序逐一分配到不同的后端服务器, 如果后端服务器挂掉,自动剔除,保证正常的服务。


  1. 配置1
  2. upstream server_back { #nginx分发服务请求
  3. server 192.168.162.49;
  4. server 192.168.162.50;
  5. }
  6. 配置2
  7. http {
  8. upstream servergroup { # 服务组接受请求,nginx轮询分发服务请求
  9. server srv1.demo.com;
  10. server srv2.demo.com;
  11. server srv3.demo.com;
  12. }
  13. server {
  14. listen 80;
  15. location / {
  16. proxy_pass http://servergroup; #所有的请求被代理到servergroup服务组
  17. }
  18. }
  19. }
  20. proxy_pass 后面是被代理的服务器ip,也可以是主机名,域名,ip端口模式
  21. upstream 设定负载均衡后台服务器列表

2 权重负载均衡(weight):如果没有配置权重,每个服务器的负载都是一样的,当出现服务器性能不均时,采用 权重轮询,指定的服务器的权重参数,权重占比为负载均衡决定的一部分。权重大负载就大。

  1. upstream server_back {
  2. server 192.168.162.49 weight=3;
  3. server 192.168.162.50 weight=7;
  4. }

3 最少连接数(least-connected):将下一个请求分配到连接数最少的那台服务器上,当一些请求需要更长的时 间响应, 最少连接可以更公平地控制应用程序实例的负载。nginx会将请求转发到负载较少的服务器。

  1. upstream servergroup {
  2. least_conn;
  3. server srv1.demo.com;
  4. server srv2.demo.com;
  5. server srv3.demo.com;
  6. }

4 ip-hash :基于客户端的IP地址。原因时负载均衡每次请求都会重新定位到服务器集群中的某一个,那么已经登录某一个服务器的用户再重新定位到另一个服务器,其登录信息将会丢失,这样明显不太妥。采用ip_hash解决这个问题,如果客户已经访问了某个服务器,当用户再次访问时,会将该请求通过哈希算法,自动定位到该服务器。

每个请求按照IP hash的结果分配,因此请求被固定到某一个后端服务器,也可以解决session问题

  1. upstream servergroup {
  2. ip-hash;
  3. server srv1.demo.com;
  4. server srv2.demo.com;
  5. server srv3.demo.com;
  6. }

附上一个实例:

  1. #user nobody;
  2. worker_processes 4;
  3. events {
  4. # 最大并发数
  5. worker_connections 1024;
  6. }
  7. http{
  8. # 待选服务器列表
  9. upstream myserver{
  10. # ip_hash指令,将同一用户引入同一服务器。
  11. ip_hash;
  12. server 125.219.42.4 fail_timeout=60s; #max_fails失败后暂定时间60s
  13. server 172.31.2.183;
  14. }
  15. server{
  16. # 监听端口
  17. listen 80;
  18. # 根目录下
  19. location / {
  20. # 选择哪个服务器列表
  21. proxy_pass http://myserver;
  22. }
  23. }
  24. }
  25. max_fails 允许请求失败的次数默认为1
  26. fail_timeout=60s fail_timeout=60s失败暂停的时间
  27. down 表示当前的服务器暂时不参与负载
  28. backup 所有非backup机器忙的时候会请求backup,因此其压力会最轻

参考:http://www.ttlsa.com/nginx/using-nginx-as-http-loadbalancer/ 非常感谢

更多:http://nginx.com/blog/load-balancing-with-nginx-plus/

http://nginx.com/blog/load-balancing-with-nginx-plus-part2/

nginx负载均衡及配置的更多相关文章

  1. nginx负载均衡简单配置

    nginx负载均衡简单配置准备三台虚拟机来做这个实验:192.168.232.132        web服务器192.168.232.133        web服务器192.168.232.134 ...

  2. nginx 负载均衡简单配置

    配置要求: 三台服务器 127.0.0.1       主负载(把访问请求分给主机池) 127.0.0.2       主机2 127.0.0.3       主机3 第一步: 配置127.0.0.1 ...

  3. nginx负载均衡常见问题配置信息

    nginx为后端web服务器(apache,nginx,tomcat,weblogic)等做反向代理 几台后端web服务器需要考虑文件共享,数据库共享,session共享问题.文件共享可以使用nfs, ...

  4. Nginx负载均衡各种配置方式

    Nginx负载均衡 - 小刚qq - 博客园http://www.cnblogs.com/xiaogangqq123/archive/2011/03/04/1971002.html Module ng ...

  5. php nginx 负载均衡简单配置过程

    负载均衡 负载均衡是我们大流量网站要做的一个东西,下面我来给大家介绍在Nginx服务器上进行负载均衡配置方法,希望对有需要的同学有所帮助哦. 简单了解一下什么是负载均衡,单从字面上的意思来理解就可以解 ...

  6. Nginx负载均衡NFS配置

    Nginx配置 首先在两台服务器上部署同一个项目,例如下: 测试网站节点1: http://192.168.168.61/nfstest/ 测试网站节点2: http://192.168.64.145 ...

  7. window下nginx负载均衡简单配置-----权重的实现

    下面介绍一个在window下的nginx的负载均衡配置. 需要你在你的电脑上跑两个tomcat.一个8080,一个9080. 需要一个nginx服务器. 需要修改本机的host 注意:我们这里配置不会 ...

  8. NGINX负载均衡缓存配置

    环境:VMware-Workstation-12-Pro,Windows-10,CentOS-7.5,Xshell5 1 概述 如果我们的架构是前端负载均衡后端WEB集群时,可以开启nginx的缓存功 ...

  9. Nginx负载均衡简易配置

    多台Web服务器水平扩展,进行负载均衡对外服务,是一种很常见的方案. 常用方法用DNS轮询,LVS. DNS轮询虽然有配置简单的有点,但无法实现健康检查,DNS修改需要较长时间失效,对于无域名的内部服 ...

随机推荐

  1. C++ 判断当前系统x64 or x86

    BOOL IsWow64(){ BOOL bIsWow64 = FALSE; //IsWow64Process is not available on all supported versions o ...

  2. AWS CSAA -- 02 AWS - 10000 Feet Overview

    004 The History Of AWS So Far 005 AWS - 10000 Foot Overview 006 AWS - 10000 Foot Overview 007 AWS - ...

  3. 一些简单的SQL Server服务器监控

    1:磁盘活动的一些监控 指标 吞吐量:IOPS,存储子系统每秒能提供多少次I/O 吞吐量,MB/S,I/O子系统每秒能提供多少MB 延时:每个I/O请求占用多少时间 队列长度:队列中有多少IO请求在等 ...

  4. show tables from information_schema/performance_schema/sys;

    root@localhost:3306.sock [performance_schema]>select version();+------------+| version()  |+----- ...

  5. REST Framework 的分页

    分页: PageNumberPagination from rest_framework.pagination import PageNumberPagination 导入分页之后你要实例化分页这个对 ...

  6. [UI] 精美UI界面欣赏[12]

    精美UI界面欣赏[12]

  7. word 排版用到双直线、波浪线、虚线 、直线、隔行线等技巧

    在办公或毕业设计时,有时排版需要插入双直线.波浪线.虚线 .直线.隔行线等而烦恼, 今天小白与大家分享技巧如下: 感谢您的阅读,如果您觉得阅读本文对您有帮助,请点一下“推荐”按钮.本文欢迎各位转载,但 ...

  8. Linux 文件的读写执行权限的说明

    文件的读写执行权限的说明 X 进入目录的权限: cd 1.文件本身是可执行的 2.普通用户还具备r的权限 3.root用户只需要有r的权限即可 r 查看目录/文件的内容 :ls dir 没有读的权 限 ...

  9. 铁乐学Python_Day33_网络编程Socket模块1

    铁乐学Python_Day33_网络编程Socket模块1 部份内容摘自授课老师的博客http://www.cnblogs.com/Eva-J/ 理解socket Socket是应用层与TCP/IP协 ...

  10. angularjs中URL中的#号问题,$locationProvider.html5Mode(true)刷新404

    解决办法原文地址:https://blog.csdn.net/weixin_36185028/article/details/72179568 angularjs支持两种url模式,hash模式和ht ...