Nginx(三):负载均衡策略 与 Nginx静态服务器

Nginx(三):负载均衡策略 与 Nginx静态服务器

 

相关阅读:

Nginx(一):Nginx原理概述 与 安装步骤详解

Nginx(二):反向代理原理 与 配置文件详解

Nginx(三):负载均衡策略 与 Nginx静态服务器

Nginx(四):Nginx配置实战


 

Nginx使用最多的三个核心功能是反向代理、负载均衡和静态服务器。在前面的博客中,我们已经介绍过Nginx的反向代理功能能,这篇博客主要介绍nginx的负载均衡策略,以及作为静态服务器的使用。

所谓负载均衡, 负载均衡即是代理服务器将接收的请求均衡的分发到各服务器。负载均衡主要解决网络拥塞问题,提高服务器响应速度,服务就近提供,达到更好的访问质量,减少后台服务器大并发压力。

 

一、Nginx的负载均衡策略:

1、加权轮询算法(默认)

按照接收的请求顺序 逐一分配到不同的后端服务器,即使在使用的过程中,某一台后端服务器宕机,nginx会自动将该后端服务器剔除,请求受理情况不会受到任何影响。存在session丢失的问题。

upstream backserver { 

server 192.168.0.14; 

server 192.168.0.15; 

在这种方式下,可以给不同的后端服务器设置权重值weight,用于调整不同的服务器上的请求的分配率;权重数据越大,被分配到的请求的几率越大;适合用于后端服务器性能不均衡的情况。

upstream backserver { 

server 192.168.0.14 weight=10; 

server 192.168.0.15 weight=10; 

2、与IP地址绑定 ip_hash:

每个请求 按照 发起请求的客户端的ip的hash结果进行分配,在这种算法下,每个ip请求都会访问到一个固定的后端服务器。可以再一定程度上解决集群部署环境下session共享的问题。

upstream backserver { 

ip_hash; 

server 192.168.0.14:88; 

server 192.168.0.15:80; 

3、fair智能调整算法:

智能调整调度算法,动态根据后端服务器处理请求的响应时间进行均衡分配,响应时间短处理效率高的服务器 分配到请求的概率高,响应时间长处理效率低的服务器分配到请求的概率低。nginx本身不支持fair算法,需要安装upstream_fair模块。

upstream backserver { 

server server1; 

server server2; 

fair; 

4、url_hash:

按照访问的url 的hash结果分配请求,每个请求的url都会指向后端固定的某台服务器。在nginx作为静态服务器的情况下 可以提高后端服务器的缓存效率。nginx默认不支持这种调度算法,要使用的话需要安装nginx的hash软件包。

upstream backserver { 

server squid1:3128; 

server squid2:3128; 

hash $request_uri; 

hash_method crc32; 

 

二、Upstream支持的状态参数:

在Nginx的Upstream模块中,除了可以通过server指定到特定服务器和端口,还可以设置服务器在负载均衡中的状态。目前的状态如下:

1、down:代表当前的服务器server不参与负载均衡。

2、backup:预留的备用设备,也就是当其它的服务器故障或忙时才会分配它给客户请求,所以它的压力最小。

3、max_fails:服务器server允许请求失败的次数,默认为1次,当失败次数超过限定的次数,就会返回proxy_next_upstream错误信息。

4、fail_timeout:当经历了max_fails的次数后,暂停服务的时间,一般与max_fails配合使用。

注意:

当服务器的调度算法为ip_hash时,服务器在负载均衡中的状态不能是weight和backup。

 

三、搭建nginx静态文件服务器:

本部分内容基于Centos7系统。

(1)进入配置文件目录:

cd /usr/local/nginx/conf/

(2)在nginx的默认配置文件中进行配置:

vim nginx.conf

需要把nginx的根目录指向上传文件的目录:按下面代码修改root的目录路径,然后保存退出。

 server {

        listen       80;
        server_name  localhost;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {

            root   /home/servicemarketpic/serviceMarket;
            index  index.html index.htm;
        }

(3)重新加载nginx配置文件:

 ./nginx -s reload

 

 

参考博客:https://blog.csdn.net/why_2012_gogo/article/details/50967520 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/114626.html原文链接:https://javaforall.net

(0)
上一篇 2021年10月5日 上午6:00
下一篇 2021年10月5日 上午6:00


相关推荐

  • 组合模式解决什么问题_组合模式实例

    组合模式解决什么问题_组合模式实例组合模式 Composite动机模式定义实例结构要点总结笔记动机在软件某些情况下,客户代码过多地依赖于对象容器复杂的内部实现结构,对象内部实现结构(而非抽象接口)地变化将引起客户代码地频繁变化.带来代码地维护性,扩展性等弊端如何将”客户代码与复杂地对象容器结构”解耦?让对象容器自己来实现自身地复杂结构,从而使得客户代码就像处理简单对象一样来处理复杂地对象容器模式定义将对象组合成树形结构以表示”整体-部分”地层次结构.Composite使得用户对单个对象和组合对象地使用具有一致性(稳定)实例树形

    2022年8月9日
    7
  • 外网访问内网的FTP服务器

    外网访问内网的FTP服务器1 背景简介最近研究如何在内网搭架 FTP 服务器 同时要保证外网 公网 能访问的到 终成正果 但走了一些弯路 在此记下 以飨后人 2 基础知识 FTP 使用 2 个端口 一个数据端口和一个命令端口 也叫做控制端口 这两个端口一般是 21 命令端口 和 20 数据端口 当然你也可以自定义 控制 Socket 用来传送命令 数据 Socket 是用于传送数据 每一个 FTP 命令发送之后

    2026年3月18日
    2
  • springboot+Vue_从零搭建springboot项目

    springboot+Vue_从零搭建springboot项目Hello,你好呀,我是灰小猿,一个超会写bug的程序猿!利用国庆期间做了一个基于springboot+vue的前后端分离的个人博客网站,今天在这里将开发过程和大家分享一下,手把手教你搭建一个自己专属的个人博客。完整源码放置在Gitee上了,【源码链接】小伙伴们记得⭐star⭐哟!小伙伴们一键三连➕关注!灰小猿带你上高速啦????????????!先看一下博客网站的演示视频:⚡项目目录⚡个人博客网站项目整体思路Java后端接口开发(1)数据库设计​(2)整合My

    2022年9月30日
    5
  • es6数组和对象常用方法

    es6数组和对象常用方法数组forEach()方法对数组的每个元素执行一次给定的函数。vararr=[1,2,3]arr.forEach((value,index)=>{console.log(‘数组值:’+value);console.log(‘数组索引:’+index);})map()方法创建一个新数组,其结果是该数组中的每个元素都调用一次提供的函数后的返回值。vararr=[1,2,3]vararr1=arr.map((value,in

    2022年5月26日
    53
  • 分布式数据存储系统的三要素是什么_分布式存储和集中式存储

    分布式数据存储系统的三要素是什么_分布式存储和集中式存储顾客:生产和消费数据顾客相当于分布式存储系统中的应用程序。根据数据的产生和使用,顾客分为生产者和消费者两种类型。生产者负责添加数据,消费者负责使用数据根据数据的特征,不同的数据划分为三类:结构化数

    2022年8月1日
    12
  • linux find查找深度,linux find 用法

    linux find查找深度,linux find 用法find 命令用来查找文件 在当前目录以及当前目录的子目录下查找 该命令能够基于正则表达式 目录树深度 文件日期 文件类型等条件查找文件 一 根据文件名或正则表达式搜索文件根据名称搜索用法 1 findpath name filename 用法 2 findpath iname filename 两种用法都支持通配符 其中 用法 1 区分大小写 用法 2 不区分大小写 实例 查找

    2026年3月17日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号