AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 66121
Accepted
Tom
Tom
Asked: 2009-09-17 18:10:43 +0800 CST2009-09-17 18:10:43 +0800 CST 2009-09-17 18:10:43 +0800 CST

如何将 Web 服务器的 DNS 从一个 IP 地址平滑迁移到另一个 IP 地址?

  • 772

我目前有一个为 Linux/Apache 服务器注册的域名,我将在新的 IP 地址上用另一个域名替换它。

迁移数据将相对较快,并且在此过程中中断 5 分钟是可以接受的。

DNS 记录的 TTL 显然是 6-12 小时,我无法加快速度。

这种变化的可能后果是什么?大概还在查看旧地址的用户会继续访问旧服务器,而 dns 缓存已过期或为空的用户将看到新域。

是否可以从旧服务器(使用 Apache 或 iptables)到新 IP 进行某种重定向?旧服务器可以根据需要继续运行。

apache-2.2
  • 5 5 个回答
  • 8218 Views

5 个回答

  • Voted
  1. James Sneeringer
    2009-09-17T20:26:21+08:002009-09-17T20:26:21+08:00

    我的公司刚刚在几个大型网站上做到了这一点。我们遵循的基本程序是:

    1. 尽可能降低域的 TTL。至少提前与当前 TTL 一样多的时间执行此操作。
    2. 在新服务器上按照您希望的“最终产品”设置网站
    3. 为新服务器上的站点添加别名,例如 www2.domain.com 或 www-new.domain.com。对于 Apache,您将使用ServerAlias指令。如果站点有任何动态代码(PHP、mod_perl、RubyOnRails 等),请确保站点将使用这个新名称正确运行和响应。
    4. 在切换时,在旧服务器上设置指向新服务器的重定向
    5. 更改 www 的 DNS 以转到新 IP。

    对于 Apache,您可能应该使用 mod_rewrite 进行重定向,这样您就可以保留客户端请求的 URI。一个简单的实现是:

    # old server
    <VirtualHost 1.1.1.1:80>
        ServerName www.domain.com
        RewriteEngine on
        RewriteRule ^(.*)$ http://www-new.domain.com$1 [L]
    </VirtualHost>
    
    # new server
    <VirtualHost 1.1.1.2:80>
        ServerName www.domain.com
        ServerAlias www-new.domain.com
    </VirtualHost>
    

    这将为 www.domain.com/anything 执行 302 临时重定向到 www-new.domain.com/anything。您希望它是临时的,因为您可能希望搜索引擎仅索引 www.domain.com,而不是 www-new.domain.com。

    一旦 www.domain.com 的 DNS 更改传播到您的满意,您可以完全转储 www-new,或者通过另一个重定向轻轻地让任何使用它的人回到 www。与上面的过程几乎相同;将旧服务器设置为处理 www-new,将 www-new 的 DNS 更改为指向旧服务器,并在旧服务器上设置重定向,将 www-new 流量发送到 www:

    # old server
    <VirtualHost 1.1.1.1:80>
       ServerName www-new.domain.com
       RewriteEngine on
       RewriteRule ^(.*)$ http://www.domain.com$1 [R=301,L]
    </VirtualHost>
    
    # new server
    <VirtualHost 1.1.1.2:80>
        ServerName www.domain.com
        # ServerAlias removed, no longer needed
    </VirtualHost>
    

    这次你想做一个永久的 301 重定向,再次提示搜索引擎爬虫 www.domain.com 是你希望他们索引的站点。

    • 11
  2. Best Answer
    Mark Henderson
    2009-09-17T18:17:52+08:002009-09-17T18:17:52+08:00

    您可以在旧 Web 服务器上使用反向代理。设置可能需要一些工作,但只要ITS DNS 是最新的,您就可以了。

    将会发生的是:

    1. 旧 Web 服务器配置为反向代理
    2. DNS 切换
    3. 新的 Web 服务器提供来自最新 DNS 记录的命中
    4. 旧网站受到打击时,会将请求转发到正确的 DNS,然后逐字输出内容。

    如果您正在运行 Apache,请查看 mod_proxy。如果您正在运行 IIS,请查看 ISAPI Rewrite 以获得此类功能。

    (请注意,如果要使用域名进行代理,旧 Web 服务器上的 DNS 需要保持最新。否则,将其直接代理到 IP 地址并确保主机正在侦听没有主机名的 IP)

    • 6
  3. Tom
    2009-09-18T05:26:28+08:002009-09-18T05:26:28+08:00

    好的,根据@Farseeker 的建议,我在旧的 Apache 服务器上设置了以下配置,以将请求转发到新服务器:

    <VirtualHost *>
      UseCanonicalName Off
      ServerAdmin  [email protected]
      ServerName domain.com
      DocumentRoot /var/www/
    
      ProxyRequests Off
    
      <Proxy *>
        Order deny,allow
        Allow from all
      </Proxy>
    
      ProxyPass / http://domain.com/
      ProxyPassReverse / http://domain.com/
    </VirtualHost>
    

    为了确保旧服务器有正确的地址,我输入了一个条目/etc/hosts:

    1.2.3.4 domain.com
    

    我还必须启用 Apachemod_proxy和mod_proxy_http模块,并重新加载配置:

    a2enmod proxy
    a2enmod proxy_http
    /etc/init.d/apache force-reload
    
    • 5
  4. cephuo
    2012-12-04T04:53:47+08:002012-12-04T04:53:47+08:00

    这是一个旧线程,但也许它会帮助某人:

    除了 Mark Henderson (mod_proxy) 或 James Sneeringer(302,301 重定向到新子域)的答案之外,在移动大型应用程序时,还可以添加关于数据库同步的另一件事。

    如果您的 Web 项目使用数据库(例如 MySQL),在切换 DNS 之前,请确保来自两台服务器的应用程序(例如 PHP)连接到同一个数据库。这样读取和写入都在同一个地方,之后您不必处理不同的数据库同步工具。

    这(很可能)会影响一台服务器上的加载时间,但在切换期间这是可以接受的。

    如果无法从外部访问数据库服务器,您还可以在可以访问它并且可以从外部 IP 访问的 Web 服务器上设置mysql_proxy 。

    • 4
  5. womble
    2009-09-18T04:33:53+08:002009-09-18T04:33:53+08:00

    当我需要这样做时,我会使用 iptables;快速的 DNAT/SNAT 和你所有的流量神奇地重新出现在它应该出现的地方。如果您确实需要维护源 IP 地址,则反向代理可以通过设置适当的标头来提供帮助,但这需要在两端进行大量工作以确保它们都匹配,所以我通常不担心对于像迁移这样的事情,因为它是瞬态的,降低 TTL 可以处理大部分问题。

    • 3

相关问题

  • Apache Django Mod_Wsgi - 自动重新加载应用程序

  • Apache:对多个虚拟主机使用相同的目录指令

  • Apache 上的子域不工作 - 找不到服务器

  • PHP 作为 CGI 还是 Apache 模块?

  • 避免将某些丢失的文件记录到 Apache2 错误日志中

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    从 IP 地址解析主机名

    • 8 个回答
  • Marko Smith

    如何按大小对 du -h 输出进行排序

    • 30 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    Windows 中执行反向 DNS 查找的命令行实用程序是什么?

    • 14 个回答
  • Marko Smith

    如何检查 Windows 机器上的端口是否被阻塞?

    • 4 个回答
  • Marko Smith

    我应该打开哪个端口以允许远程桌面?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    MikeN 在 Nginx 中,如何在维护子域的同时将所有 http 请求重写为 https? 2009-09-22 06:04:43 +0800 CST
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    0x89 bash中的双方括号和单方括号有什么区别? 2009-08-10 13:11:51 +0800 CST
  • Martin Hope
    kch 如何更改我的私钥密码? 2009-08-06 21:37:57 +0800 CST
  • Martin Hope
    Kyle Brandt IPv4 子网如何工作? 2009-08-05 06:05:31 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve