热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

读书笔记负载均衡与反向代理

当访问一个域名例如www.baidu.com时候,浏览器首先查询DNS服务器获取对应IP,然后通过IP访问对应服务。
一个很简单问题,当某台服务器重启或者故障,DNS有一定缓存事件,故障后切换时间长。
外网DNS应该用GSLB(全局负载均衡)进行流量调度,将请求分配到最近服务器以提升体验。而当某一区域机房出现问题,可以通过DNS指向其他区域机房。
对于内网DNS,使用一般轮询就可以了。
对于一般应用,使用Nginx就可以了。LVS(软件负载均衡器)和F5(硬负载均衡器)
读书笔记-负载均衡与反向代理

  • 二层负载均衡是通过改写报文的目标MAC地址为上游服务器MAC地址,源IP地址和目标IP地址是没有变的,负载均衡服务器和真实服务器共享一个VIP,如LVS DR工作模式。
  • 四层负载均衡是根据端口将报文转发到上游服务器(不同IP地址+端口),入LVS NAT模式、HaProxy,七层负载均衡是根据端口号和应用协议入HTTP协议主机名、URL,转发报文到上游服务器(不同IP地址+端口),入HaProxy、Nginx

负载均衡主要关心以下几个方面

  • 上游服务器配置:使用upstream server 配置上游服务器
  • 负载均衡算法:配置多个上游服务器时负载均衡机制
  • 失败重试机制:配置当超时或者上游服务器不存活时,是否需要重试其他上游服务器
  • 服务器心跳检查:上游服务器健康/心跳检查

以下配置步骤指Nginx中配置:

upstream配置

  • IP地址和端口
  • 权重,权重越大,分配请求越多。

负载均衡算法

默认采取轮询即round-robin。
同时支持以下几种:

  • round-robin:轮询,配合权重(weight)可以实现基于权重轮询
  • ip_hash:根据客户IP进行负载,即相同ip负载均衡到同一upstream
  • hash key [consistent]:对某一个key进行哈希或者使用一致性哈希进行负载均衡。使用Hash算法存在问题,当添加或者删除一台服务器时,将导致很多key被重新负载均衡到不同服务器(从而导致后端可能出现问题);因此建议使用一致性哈希算法,有consisten_key动态指定,这样当删除/添加一台服务器时,只有少数key将被重新负载均衡到不同服务器。
    哈希算法:使用uri进行hash。一致性哈希算法,传入consisten_key动态执行定
  • least_conn:将请求负载均衡到最少活跃连接的上游服务器。如果配置服务器较少,则将转使用基于权重轮询。

失败重试

主要有两部分配置:upstream server和 proxy_pass。
同步上游服务器的max_fails 和fail_timeout,来指定每个上游服务器,当fail_timeout时间内失败了max_fails次请求,则认为该上游服务器不可用,然后摘掉该上游服务器,fail_timeout时间后会再次将该服务器加入到存活上游服务器列表进行重试。

健康检查

Nginx对上游服务器的健康检查采用默认的惰性策略。

  1. TCP心跳检查
  2. HTTP心跳检查

其他配置

对上游服务器的一些配置

  1. 域名上游服务器,当某一台服务器IP变化,Nginx解析配置文件阶段会将IP地址记录,但是当ip变化是Nginx不会动态更新,需要使用
    set $backend "http://c0.3.cn"
  2. 备份上游服务器
  3. 不可用上游服务器,即把一个服务器置为不可用

长连接

配置Nginx与上游服务器的长连接。
只建议对小报文进行长连接

HTTP动态负载均衡

使用负载均衡实现中,每次upstream列表有变更,都需要到服务器修改。需要一种服务注册,可以将upstream 动态注册到Nginx上,从而实现upstream服务自动发现。
Consul是一款开源的分布式服务注册与发现系统,通过HTTP API可以使得服务注册、发现实现起来非常简单。
步骤:

  1. upstream服务启动,我们通过管理后台向consul注册服务。
  2. 我们需要Nginx机器上部署并启动Consul-template Agent,其通过长轮询监听服务变更
  3. Consul-template监听到变更后,动态修改upstream列表
  4. Consul-template修改完upstream列表后,调用重启Nginx脚本重启Nginx。

使用Consul注册服务,使用OpenResty balancer_by_lua实现无reload动态负载均衡。即会实时更新到共享字典。

  1. 通过upstream server 启动/停止时注册服务,或者通过Consul管理后台注册服务
  2. Nginx启动时会调用init_by_lua,启动时拉去配置,并更新到共享字典来存储upstream列表;然后通过init_worker_by_lua启动定时器,定期去COnsul拉去配置并实时更新到共享字典
  3. balancer_by_lua使用共享字典存储upstream列表进行动态负载均衡。

Nginx四层负载均衡

Nginx1.9.0起支持四层负载均衡。

  • 四层就是基于IP+端口的负载均衡;四层通过虚拟IP+端口接收请求,然后再分配到真实的服务器;
  • 七层就是基于URL等应用层信息的负载均衡;七层通过虚拟的URL或主机名接收请求,然后再分配到真实的服务器。
  • 同理,还有基于MAC地址的二层负载均衡和基于IP地址的三层负载均衡。 换句换说,二层负载均衡会通过一个虚拟MAC地址接收请求,然后再分配到真实的MAC地址;
  • 三层负载均衡会通过一个虚拟IP地址接收请求,然后再分配到真实的IP地址;

参考资料:

  1. 亿级流量网站架构核心技术
  2. https://kb.cnblogs.com/page/188170/

推荐阅读
  • Java Socket 关键参数详解与优化建议
    Java Socket 的 API 虽然被广泛使用,但其关键参数的用途却鲜为人知。本文详细解析了 Java Socket 中的重要参数,如 backlog 参数,它用于控制服务器等待连接请求的队列长度。此外,还探讨了其他参数如 SO_TIMEOUT、SO_REUSEADDR 等的配置方法及其对性能的影响,并提供了优化建议,帮助开发者提升网络通信的稳定性和效率。 ... [详细]
  • 用阿里云的免费 SSL 证书让网站从 HTTP 换成 HTTPS
    HTTP协议是不加密传输数据的,也就是用户跟你的网站之间传递数据有可能在途中被截获,破解传递的真实内容,所以使用不加密的HTTP的网站是不 ... [详细]
  • IOS Run loop详解
    为什么80%的码农都做不了架构师?转自http:blog.csdn.netztp800201articledetails9240913感谢作者分享Objecti ... [详细]
  • 网站访问全流程解析
    本文详细介绍了从用户在浏览器中输入一个域名(如www.yy.com)到页面完全展示的整个过程,包括DNS解析、TCP连接、请求响应等多个步骤。 ... [详细]
  • 秒建一个后台管理系统?用这5个开源免费的Java项目就够了
    秒建一个后台管理系统?用这5个开源免费的Java项目就够了 ... [详细]
  • MySQL的查询执行流程涉及多个关键组件,包括连接器、查询缓存、分析器和优化器。在服务层,连接器负责建立与客户端的连接,查询缓存用于存储和检索常用查询结果,以提高性能。分析器则解析SQL语句,生成语法树,而优化器负责选择最优的查询执行计划。这一流程确保了MySQL能够高效地处理各种复杂的查询请求。 ... [详细]
  • 基于Net Core 3.0与Web API的前后端分离开发:Vue.js在前端的应用
    本文介绍了如何使用Net Core 3.0和Web API进行前后端分离开发,并重点探讨了Vue.js在前端的应用。后端采用MySQL数据库和EF Core框架进行数据操作,开发环境为Windows 10和Visual Studio 2019,MySQL服务器版本为8.0.16。文章详细描述了API项目的创建过程、启动步骤以及必要的插件安装,为开发者提供了一套完整的开发指南。 ... [详细]
  • 本文详细介绍了如何使用OpenSSL自建CA证书的步骤,包括准备工作、生成CA证书、生成服务器待签证书以及证书签名等过程。 ... [详细]
  • 应用链时代,详解 Avalanche 与 Cosmos 的差异 ... [详细]
  • Python 数据可视化实战指南
    本文详细介绍如何使用 Python 进行数据可视化,涵盖从环境搭建到具体实例的全过程。 ... [详细]
  • XAMPP 遇到 404 错误:无法找到请求的对象
    在使用 XAMPP 时遇到 404 错误,表示请求的对象未找到。通过详细分析发现,该问题可能由以下原因引起:1. `httpd-vhosts.conf` 文件中的配置路径错误;2. `public` 目录下缺少 `.htaccess` 文件。建议检查并修正这些配置,以确保服务器能够正确识别和访问所需的文件路径。 ... [详细]
  • DVWA学习笔记系列:深入理解CSRF攻击机制
    DVWA学习笔记系列:深入理解CSRF攻击机制 ... [详细]
  • 如何将TS文件转换为M3U8直播流:HLS与M3U8格式详解
    在视频传输领域,MP4虽然常见,但在直播场景中直接使用MP4格式存在诸多问题。例如,MP4文件的头部信息(如ftyp、moov)较大,导致初始加载时间较长,影响用户体验。相比之下,HLS(HTTP Live Streaming)协议及其M3U8格式更具优势。HLS通过将视频切分成多个小片段,并生成一个M3U8播放列表文件,实现低延迟和高稳定性。本文详细介绍了如何将TS文件转换为M3U8直播流,包括技术原理和具体操作步骤,帮助读者更好地理解和应用这一技术。 ... [详细]
  • 在对WordPress Duplicator插件0.4.4版本的安全评估中,发现其存在跨站脚本(XSS)攻击漏洞。此漏洞可能被利用进行恶意操作,建议用户及时更新至最新版本以确保系统安全。测试方法仅限于安全研究和教学目的,使用时需自行承担风险。漏洞编号:HTB23162。 ... [详细]
  • 在优化Nginx与PHP的高效配置过程中,许多教程提供的配置方法存在诸多问题或不良实践。本文将深入探讨这些常见错误,并详细介绍如何正确配置Nginx和PHP,以实现更高的性能和稳定性。我们将从Nginx配置文件的基本指令入手,逐步解析每个关键参数的最优设置,帮助读者理解其背后的原理和实际应用效果。 ... [详细]
author-avatar
我_不是无双
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有