Node.js自动导航模式在Docker的应用

简介: 本文讲的是Node.js自动导航模式在Docker的应用【编者的话】Joyent公司作为云计算和服务提供商,不久前刚被三星公司并购。该公司开源了两个Node.js模块,Consulite和Piloted,旨在使用Node.js来整合Docker容器。
本文讲的是Node.js自动导航模式在Docker的应用【编者的话】Joyent公司作为云计算和服务提供商,不久前刚被三星公司并购。该公司开源了两个Node.js模块,Consulite和Piloted,旨在使用Node.js来整合Docker容器。本文通过实例介绍了如何使用这两个模块在Node.js中应用AutoPilot Patten(自动导航模式)在Docker容器中快捷地构建应用。

自动导航模式使得当程序被部署的时候能够自动根据配置构建应用程序变得非常简单(容易在开发和测试的时候获得一个拷贝),当应用程序更新或者由于故障需要扩展或者缩减的时候。接下来我们将通过两个Node.js模块如何使用自动导航模式更容易地构建app。

这两个模块分别是 Consulite  和 Piloted ,使用 npm 安装和如何为自动导航模式程序提供常用功能,其中包含使用Consul进行交互以及因为拓扑结构变更而重新加载配置文件的内容。这些虽然不是自动导航模式所必需,但是提供了更加便捷的方式。

让我们看看这两个模块是如何工作的。

为Node.js提供容器导航

在我们演示这些模块如何使用之前,让我们先快速浏览下 容器导航 是如何与在Docker容器中运行的Node.js应用程序进行整合的。下面的图片说明了通常情况下一个应用程序的生命周期在 容器导航 中配置的要点。
app-lifecycle.png

如图所示, 容器导航 配置通常会发送一个 SIGHUP 信号给Node.js应用程序。一旦发送完毕,不论这个应用程序是否依赖后台的变更。当 容器导航 通知这些后台依赖变更的时候,他不会发送应用程序的后台主机名以及端口信息。这个任务留着给应用开发人员决定如何去实现它。下图演示一个类似 Consul 的典型数据流,从应用程序到 容器导航 再到服务注册的过程。
app-flow.png

上面的模块是设计被用来解决上图所示的经常遇到的问题,比如处理后台地址由于 onChange 事件而需要重新加载的情况。当后台服务变更的时候 onChange 事件触发。这有可能是因为某个后台服务突然不健康或者新的后台地址通过Consul注册而造成的。无论是哪种方式,容器导航都会执行已经配置好的命令通知Node.js应用。

保存一份应用依赖的健康的后台地址清单对 自动导航模式 而言影响重大。其中一个原因是最初的设计就是为了能够提前了解应用的健康情况,为了确保请求不会被发送到那些不健康的后台服务。这也意味着负载均衡器对部署一个应用及后台服务而言不再那么重要了。

Consulite

另一个对于 容器导航 目标而言, 自动导航模式 显著的收益是我们不需要注册你的应用到服务发现上了。服务导航为你管理这些常用任务,当出现中断或者任何应用依赖的服务发生变更的时候它会第一时间通知应用这一消息。

你无需再为服务注册和从注册订阅的消息担心,你需要知道的只是如何与注册者通信并定位应用依赖的主机及端口信息。 Consulite 有助于使得获取这些应用依赖的服务信息变得便捷。正如Consul的名字一样,它实现了如何与 consulite 进行通讯的注册实现。

实现注册路由

让我们通过一个实例来演示consulite是如何使得这一切变得便捷和有意义的。这个例子源自 Autopilot workshop ,一个标准的  销售者 服务。
const Consulite = require('consulite');
const Wreck = require('wreck');

Consulite.getService('customers', (err, host) => {
if (err) {
return console.error(err);
}

Wreck.get(`http://${host.address}:${host.port}/data`, (err, res, customers) => {
// Handle error or respond with relevant customer data
});
});

在上面的例子中,没有任何消费者服务被缓存,那么Consul将使得一个请求获取到所有健康的服务地址列表。通常情况,会为一个特定服务提供多功能后台地址列表。为了建立这个服务, consulite 将会循环遍历这个地址列表。循环的逻辑从当前地址列表的第一个还没有被使用的地址直到最后一个地址完全被使用。这些在一个模块中实现功能的结果有助于减少使用Consul保持与这个地址列表通讯的资源消耗。

管理注册变更

Consulite 使得保持与缓存后的健康服务列表通讯变得异常容易,当服务器更新的时候也同时更新了这个服务列表。之前的例子中,已经演示了容器导航是如何当一个后台服务变更的时候通过向配置好的Node.js应用发送一个 SIGHUP 信号通知。下面的实例演示了在 容器导航 中如何使用 consulite 管理可配置的 onChange 行为来统一管理这些信号,目的是刷新这些本地服务缓存。
process.on('SIGHUP', () => {
Consulite.refreshService('customers', (err) => {
if (err) {
  console.error(err);
}
});
});

就算是一个应用开发人员都可以通过 consulite 很容易的调试 容器导航 ,他们的职责仅仅只需计算一直保持通信的初始化服务列表来管理进程事件而以。为了解决这个问题我们创建了 piloted 项目。

Piloted项目

为了代替应用程序开发人员去实现管理 SIGNUP 事件以及初始化服务地址列表加载,我们决定用 piloted 模块来处理这些工作。所有应用依赖的后台和服务们都已经配置在了 containerpilot.json 的配置文件中。因此应用开发人员可以通过 piloted 来替换这些配置信息,且它会自动加载,并为应用保存一份健康的后台地址信息列表。下面的例子演示了如何发送已经 piloted 的配置文件信息并取回 customers 服务的后台服务地址列表。

Usage

const Piloted = require('piloted');
const Wreck = require('wreck');
const ContainerPilot = require('/etc/containerpilot.json');

Piloted.config(ContainerPilot, () => {
const host = Piloted('customers');

Wreck.get(`http://${host.address}:${host.port}/data`, (err, res, customers) => {
// Handle error or respond with relevant customer data
});
}); 

上面的例子中 容器导航 的配置文件被加载到 piloted 中。在这之后, piloted 将会维护一份本地的应用依赖健康服务列表。在这个事件中,一旦这些服务中有变更发生, piloted 将会通过Consul更新这个列表信息到最新版本。

另一个使用这个模块的好处是你只需要配置一次 piloted ,就可以在运行时对同一线程获得对应用更广泛的服务地址的管理权限。

总结

综上所述,遵循 自动导航模式 构建Node.js应用将变得更加容易。如果你想查看完整的实例应用请访问 Autopilot Workshop 仓库。一如既往,我们希望得到您的任何反馈和建议,请为我们的仓库提交问题。

原文链接:Autopilot Pattern Node.js in Docker(翻译:隋鑫)

原文发布时间为:2016-09-13

本文作者:隋鑫

本文来自云栖社区合作伙伴Dockerone.io,了解相关信息可以关注Dockerone.io。

原文标题:Node.js自动导航模式在Docker的应用

相关文章
《docker高级篇(大厂进阶):4.Docker网络》包括:是什么、常用基本命令、能干嘛、网络模式、docker平台架构图解
《docker高级篇(大厂进阶):4.Docker网络》包括:是什么、常用基本命令、能干嘛、网络模式、docker平台架构图解
180 56
《docker高级篇(大厂进阶):4.Docker网络》包括:是什么、常用基本命令、能干嘛、网络模式、docker平台架构图解
如何使用内存监控工具来定位和解决Node.js应用中的性能问题?
总之,利用内存监控工具结合代码分析和业务理解,能够逐步定位和解决 Node.js 应用中的性能问题,提高应用的运行效率和稳定性。需要耐心和细致地进行排查和优化,不断提升应用的性能表现。
206 77
如何优化Node.js应用的内存使用以提高性能?
通过以上多种方法的综合运用,可以有效地优化 Node.js 应用的内存使用,提高性能,提升用户体验。同时,不断关注内存管理的最新技术和最佳实践,持续改进应用的性能表现。
151 62
如何使用内存监控工具来优化 Node.js 应用的性能
需要注意的是,不同的内存监控工具可能具有不同的功能和特点,在使用时需要根据具体工具的要求和操作指南进行正确使用和分析。
83 31
|
1月前
Next.js 实战 (三):优雅的实现暗黑主题模式
这篇文章介绍了在Next.js中实现暗黑模式的具体步骤。首先,需要安装next-themes库。然后,在/components/ThemeProvider/index.tsx文件中新增ThemeProvider组件,并在/app/layout.tsx文件中注入该组件。如果想要加入过渡动画,可以修改代码实现主题切换时的动画效果。最后,需要在需要的位置引入ThemeModeButton组件,实现暗黑模式的切换。
|
1月前
|
docker的默认网络模式有哪些
Docker 默认网络模式包括:1) bridge:默认模式,各容器分配独立IP,可通过名称或IP通信;2) host:容器与宿主机共享网络命名空间,性能最优但有安全风险;3) none:容器隔离无网络配置,适用于仅需本地通信的场景。
50 6
探索容器化技术Docker及其在现代软件开发中的应用
探索容器化技术Docker及其在现代软件开发中的应用
Docker容器内进行应用调试与故障排除的方法与技巧,包括使用日志、进入容器检查、利用监控工具及检查配置等,旨在帮助用户有效应对应用部署中的挑战,确保应用稳定运行
本文深入探讨了在Docker容器内进行应用调试与故障排除的方法与技巧,包括使用日志、进入容器检查、利用监控工具及检查配置等,旨在帮助用户有效应对应用部署中的挑战,确保应用稳定运行。
65 5
Docker 是一种容器化技术,支持开发者将应用及其依赖打包成容器,在不同平台运行而无需修改。
Docker 是一种容器化技术,支持开发者将应用及其依赖打包成容器,在不同平台运行而无需修改。本文探讨了 Docker 在多平台应用构建与部署中的作用,包括环境一致性、依赖管理、快速构建等优势,以及部署流程和注意事项,展示了 Docker 如何简化开发与部署过程,提高效率和可移植性。
76 4
Docker镜像采用分层存储,每层代表镜像的一部分,如基础组件或应用依赖,多层叠加构成完整镜像
Docker镜像采用分层存储,每层代表镜像的一部分,如基础组件或应用依赖,多层叠加构成完整镜像。此机制减少存储占用,提高构建和传输效率。Docker还通过缓存机制提升构建和运行效率,减少重复工作。文章深入解析了Docker镜像分层存储与缓存机制,包括具体实现、管理优化及实际应用案例,帮助读者全面理解其优势与挑战。
67 4

热门文章

最新文章

AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等