You need to enable JavaScript to run this app.
导航

实现负载均衡

最近更新时间2023.12.15 14:08:34

首次发布时间2023.02.08 13:10:08

本文档介绍如何在火山引擎私网解析(PrivateZone)中实现基于 DNS 的负载均衡。

功能概述

如果一个记录集包含多个记录值,而且每个记录值都有一个权重,那么私网解析 PrivateZone 会统计记录集中所有记录值的权重的和,并计算出每个记录值所占的权重比例。根据每个记录值所占的权重比例,私网解析 PrivateZone 会在响应相同比例的 DNS 查询请求时返回该记录值。

例如,www.example.com 下有一个记录集,包含两个记录值 10.0.0.1 和 10.0.0.2,其权重分别为 1 和 3。如果私网解析 PrivateZone 收到 100 条匹配该记录集的 DNS 查询请求,25 条 DNS 查询请求的响应中的记录值是 10.0.0.1,75 条 DNS 查询请求的响应中的记录值是 10.0.0.2

  • 在私网解析 PrivateZone 的控制台中,私网解析 PrivateZone 自动为您管理记录集。您可以为一条解析记录创建多个记录值。然后,您可以通过为记录值设置权重实现基于 DNS 的负载均衡。
  • 在私网解析 PrivateZone 的 OpenAPI 中,您可以通过记录集实现基于 DNS 的负载均衡。

私网解析 PrivateZone 对负载均衡有以下限制:

  • A 和 AAAA 类型的记录:您可以开启或关闭负载均衡。
  • CNAME 类型的记录:负载均衡默认是开启的并且您无法关闭。
  • TXT、MX 和 PTR 类型的记录:负载均衡默认是关闭的并且您无法开启。

参见 功能版本规格 了解私网解析 PrivateZone 对记录集中的解析记录数量和权重值范围的限制。

注意

在您启用负载均衡之后,私网解析 PrivateZone 的解析缓存会失效。因此,私网域名的解析请求数量会增加,这也会造成计费增加。

例如:

  • 您分别设置两条记录值的权重为 4 和 1。4/(4+1) = 80% 的 DNS 查询请求会被路由到第 1 个记录值;1/(4+1)=20% 的 DNS 查询请求会被路由到第 2 个记录值。

  • 您分别设置三条记录值的权重为 8、6、3。8/(8+6+3) = 47% 的 DNS 查询请求会被路由到第 1 个记录值;6/(8+6+3) = 35% 的 DNS 查询请求会被路由到第 2 个记录值;3/(8+6+3) = 18% 的 DNS 查询请求会被路由到第 3 个记录值。

操作场景

一个常见的场景是新服务的灰度发布。新服务有独立的 IP 地址。您可以先为新服务设置较小的权重,使少量的流量被路由到新服务的 IP 地址。经过监控和测试,您通过增加权重来逐渐增加路由到新服务的 IP 地址的流量,并最终实现新服务的全量发布。

假设您的业务域名是 internal.example.com。该域名指向的 IP 地址是 10.0.0.128。您需要灰度发布一个新服务。新服务的 IP 地址是 10.0.0.1。您希望 22% 的流量被路由到 10.0.0.1,78% 的流量被路由到 10.0.0.128。

操作步骤

步骤一:添加域名

添加域名 internal.com。参见 添加域名。您需要在添加域名时开启负载均衡。

步骤二:实现负载均衡

参见以下步骤实现示例场景中的流量分配比例。

说明

如果您在创建域名时,没有开启负载均衡,为该域名创建解析记录时,控制台就不会显示权重相关的设置。

  1. 打开 internal.example.com 解析记录的 编辑记录 页面。参见 更新解析记录

  2. 编辑记录 页面,设置以下参数。

    基本信息

    参数描述
    域名设置为 internal
    记录类型设置为 A
    TTL设置为 10分钟
    线路设置为 默认线路
    负载均衡设置为 开启

    记录值

    记录值权重是否启用
    10.0.0.122启用
    10.0.0.12878启用

alt

  1. 设置完成后,点击 提交