SQL Server 高可用性(八)负载平衡

  高可用与负载平衡是两种不同的技术,却经常被混淆。


一、服务的类型

1. 无状态的服务(stateless service)

  对单次请求的处理,不依赖其他请求。

  处理一次请求所需的全部信息都包含在这个请求里或者可以从外部获取(例如,数据库),服务本身不存储任何信息。

  IIS(Web服务)可以设计成无状态的服务,可以实现池化(负载均衡),从而横向扩展。


2. 有状态的服务(stateful service)

  会在自身保存一些数据。

  先后的请求是有关联的,通常用于实现事务。

  数据库服务一般是有状态的服务。



二、区别

1. 高可用

  高可用是针对“有状态”的服务,其目标是为了减少硬件或软件故障造成的影响,保持业务的连续性,从而将用户可以察觉到的停机时间送到最少。

wKiom1OxZwGzACVsAACxxXpCwsM829.jpg


2. 负载平衡

  负载平衡是针对“无状态”的服务,其目标是通过对服务的“池化”(多个服务,形成一个“池”)使客户端的请求被分摊到多个服务。

wKiom1OxZ2fDvF6aAAEXOky-eFk272.jpg



三、联系

  高可用技术中兼具一部分的负载分摊功能。例如,AlwaysOn可用性组的辅助副本可以提供只读访问,从而分摊一部分的只读请求给报表等应用程序。

  负载均衡给客户端的感觉就像高可用技术一样,保持了业务的连续性。例如,客户端连接到IIS池,池中的某台IIS服务器发生故障后,客户端的连接被重定向到池中的其它IIS服务器。

  数据库产品几乎都没有宣称自己的“产品功能”(feature)中包含有负载均衡、读写分离等技术特性。对于SQL Server来说,负载分摊、读写分享应当作为一个解决方案(Solution)来实现。例如,指定一个只读副本专门用来查询,应当从业务需求角度事先进行设计。


四、SQL Server 负载分离示例

  生产环境通常在设计时就要考虑到未来的数据增长,并且预留负载分离的接口。

  以下案例显示了一家OTA企业在遇到数据库规模迅速增长时,依次实施了三期部署。

  第一期:数据库将所有数据都存放在一台服务器。

wKioL1OxZ5fS6pZIAAE1eHU5ZqI086.jpg



  第二期:进行了负载分离,将原先的单台服务器根据业务类型进行分离。

wKiom1OxaBygEdadAAE17hzwAVQ536.jpg



  第三期:继续进行分离。

wKioL1OxaILgxa7TAAHeg9pReBc411.jpg


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值