当前位置 主页 > 服务器问题 > Linux/apache问题 >

    在 Linux 上用 DNS 实现简单的负载均衡的方法

    栏目:Linux/apache问题 时间:2019-11-20 12:05

    DNS 轮询将多个服务器映射到同一个主机名,并没有为这里展示的魔法做更多的工作。

    如果你的后端服务器是由多台服务器构成的,比如集群化或者镜像的 Web 或者文件服务器,通过负载均衡器提供了单一的入口点。业务繁忙的大型电商在高端负载均衡器上花费了大量的资金,用它来执行各种各样的任务:代理、缓存、状况检查、SSL 处理、可配置的优先级、流量整形等很多任务。

    但是你并不需要做那么多工作的负载均衡器。你需要的是一个跨服务器分发负载的简单方法,它能够提供故障切换,并且不太在意它是否高效和完美。DNS 轮询和使用轮询的子域委派是实现这个目标的两种简单方法。

    DNS 轮询是将多台服务器映射到同一个主机名上,当用户访问 foo.example.com 时多台服务器都可用于处理它们的请求,使用的就是这种方式。

    当你有多个子域或者你的服务器在地理上比较分散时,使用轮询的子域委派就比较有用。你有一个主域名服务器,而子域有它们自己的域名服务器。你的主域名服务器将所有的到子域的请求指向到它们自己的域名服务器上。这将提升响应时间,因为 DNS 协议会自动查找最快的链路。

    DNS 轮询

    轮询和旅鸫鸟robins没有任何关系,据我相熟的图书管理员说,它最初是一个法语短语,ruban rond、或者 round ribbon。很久以前,法国政府官员以不分级的圆形、波浪线、或者直线形状来在请愿书上签字,以盖住原来的发起人。

    DNS 轮询也是不分级的,简单配置一个服务器列表,然后将请求转到每个服务器上。它并不做真正的负载均衡,因为它根本就不测量负载,也没有状况检查,因此如果一个服务器宕机,请求仍然会发送到那个宕机的服务器上。它的优点就是简单。如果你有一个小的文件或者 Web 服务器集群,想通过一个简单的方法在它们之间分散负载,那么 DNS 轮询很适合你。

    你所做的全部配置就是创建多条 A 或者 AAAA 记录,映射多台服务器到单个的主机名。这个 BIND 示例同时使用了 IPv4 和 IPv6 私有地址类:

    fileserv.example.com. IN A 172.16.10.10
    fileserv.example.com. IN A 172.16.10.11
    fileserv.example.com. IN A 172.16.10.12
    fileserv.example.com. IN AAAA fd02:faea:f561:8fa0:1::10
    fileserv.example.com. IN AAAA fd02:faea:f561:8fa0:1::11
    fileserv.example.com. IN AAAA fd02:faea:f561:8fa0:1::12
    

    Dnsmasq 在 /etc/hosts 文件中保存 A 和 AAAA 记录:

    172.16.1.10 fileserv fileserv.example.com
    172.16.1.11 fileserv fileserv.example.com
    172.16.1.12 fileserv fileserv.example.com
    fd02:faea:f561:8fa0:1::10 fileserv fileserv.example.com
    fd02:faea:f561:8fa0:1::11 fileserv fileserv.example.com
    fd02:faea:f561:8fa0:1::12 fileserv fileserv.example.com
    

    请注意这些示例都是很简化的,解析完全合格域名有多种方法,因此,关于如何配置 DNS 请自行学习。

    使用 dig 命令去检查你的配置能否按预期工作。将 ns.example.com 替换为你的域名服务器:

    $ dig @ns.example.com fileserv A fileserv AAA

    它将同时显示出 IPv4 和 IPv6 的轮询记录。

    子域委派和轮询

    子域委派结合轮询要做的配置会更多,但是这样有一些好处。当你有多个子域或者地理位置比较分散的服务器时,就应该去使用它。它的响应时间更快,并且宕机的服务器不会去响应,因此客户端不会因为等待回复而被挂住。一个短的 TTL,比如 60 秒,就能帮你做到。

    这种方法需要多台域名服务器。在最简化的场景中,你需要一台主域名服务器和两个子域,每个子域都有它们自己的域名服务器。在子域服务器上配置你的轮询记录,然后在你的主域名服务器上配置委派。