首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >刷新中的DNS缓存

刷新中的DNS缓存
EN

Server Fault用户
提问于 2020-06-15 00:58:01
回答 1查看 308关注 0票数 1

最近,我们的一个Google应用程序在我们的数据库服务器(托管在Aiven中)的计划维护过程中失败了。

在计划维护期间,通过更新DNS记录,DB服务器将无法转移到替换服务器。这应该是即时的,但是我们发现在GAE中运行的节点应用程序在几分钟内由于连接故障而崩溃。

连接错误被视为一个硬错误,因此节点应用程序退出,然后通过再次运行npm立即替换为一个新进程。但是,这个过程也失败了,因为它也无法连接等等,直到GAE决定服务器是一个lame鸭子并替换它。

当实例被替换时,连接问题似乎已经解决,但我不清楚为什么要花这么长时间才能解决。

我怀疑旧数据库主机名可能已被缓存,因此它无法连接到旧IP。

作为一项工作,我想知道是否有可能(从实例中)刷新google应用程序引擎实例上的DNS缓存?

我已经查找了有关App如何解析DNS的文档,但最终会在有关设置自定义或内部DNS的页面上结束。

总之:我们运行在GAE上的节点应用程序连接到外部托管的数据库,并通过DNS查找来标识主机。

因此,我需要刷新的缓存是一个缓存查找的公共DNS记录不是托管在谷歌,而是由一个GAE应用程序请求。

ie:

代码语言:javascript
复制
Node GAE App -> { Public Internet } -> Database
EN

回答 1

Server Fault用户

发布于 2020-06-16 01:33:09

我认为解决方案应该是稍微修改一下体系结构。

作为一个PaaS,您没有太多的访问GAE来运行一些管理操作。

知道了这一点,我建议对这些架构进行更改:

  1. 对正在运行的数据库服务器使用Virtual,并在故障转移时在服务器之间进行更改。DNS将仅映射到虚拟IP。

  1. 验证DNS记录的TTL,并将其缩短到您可以等待DNS复制的最短时间,比如60秒。问题是机器将更频繁地访问DNS服务器。

  1. 在数据库服务器前放置一个负载均衡器,并更改故障转移上的负载均衡器映射。DNS将映射到负载均衡器。
票数 1
EN
页面原文内容由Server Fault提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://serverfault.com/questions/1021442

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档