• Linux配置Nginx负载均衡


    nginx配置负载均衡其实很简单,一直还以为负载均衡是个很高端人士玩的

    首先先了解下负载均衡,假设一个场景,如果有1000个客户同时访问你服务器时,而你只有一台服务器的Nginx,且只有一个MySQL服务器,那么这些请求

    可能会高出你的的服务器承受能力,就会down掉;

    解决方法:

    1.垂直升级:就是增加服务器的配置,CPU,内存等

    2.水平升级:添加多台服务器来分担服务器压力

    常见的负载均衡器

    根据工作在的协议层划分可划分为:

    • 四层负载均衡:根据请求报文中的目标地址和端口进行调度
    • 七层负载均衡:根据请求报文的内容进行调度,这种调度属于「代理」的方式

    根据软硬件划分:

    • 硬件负载均衡:
      • F5 的 BIG-IP
      • Citrix 的 NetScaler
      • 这类硬件负载均衡器通常能同时提供四层和七层负载均衡,但同时也价格不菲
    • 软件负载均衡:
      • TCP 层:LVS,HaProxy,Nginx
      • 基于 HTTP 协议:Haproxy,Nginx,ATS(Apache Traffic Server),squid,varnish
      • 基于 MySQL 协议:mysql-proxy

    配置Nginx负载均衡

    vi /nignx目录/nginx.conf

    #添加下面这段 backend可以自由命名

    upstream backend {

       #添加服务器到负载均衡

         server 192.168.1.252;

                 server 192.168.1.251 weight=2;#设置该服务器在负载均衡中的权重  默认为1;越高则访问的频次越大

                 server 192.168.1.252 down;  #表示down掉这台服务器,不参与负载均衡

                 server 192.168.1.247 backup; #备用服务器 当其他服务器很忙或者down掉之后才会启动这台的

             }

    #配置参数
    #max_fails :允许请求失败的次数默认为1.当超过最大次数时,返回proxy_next_upstream 模块定义的错误

    #fail_timeout:max_fails次失败后,暂停的时间。

    server {

            listen       80;

            server_name  localhost;

            location / {

                 #反向代理的地址

                 proxy_pass http://backend;     

            }

    }
    这样子就已经配置完成了

    访问localhost,如果三台服务器能轮询切换就证明配置成功

  • 相关阅读:
    How does “void *” differ in C and C++?
    Can we use function on left side of an expression in C and C++?
    apache配置局域网访问
    apache以天为单位生成日志
    尝试读取或写入受保护的内存。这通常指示其他内存已损坏。
    IIS 处理程序“PageHandlerFactory-Integrated”
    IIS无法识别的属性targetFramework
    php开启短标签支持
    Notepad++配色方案
    vim常用操作整理
  • 原文地址:https://www.cnblogs.com/cyq632694540/p/6957038.html
Copyright © 2020-2023  润新知