红帽发布多容器应用规范Nulecule

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: 本文讲的是红帽发布多容器应用规范Nulecule,【编者的话】这篇文章简单的介绍了Nulecule的产生、特性以及目标, Nulecule致力于构建一个统一的复合应用(基于多容器)的描述规范。笔者认为想法很好,但是要想实现这一目标不仅仅是一个技术问题,更多的是需要实现各个容器厂商的利益均衡,而做到这一点并不那么容易。
本文讲的是红帽发布多容器应用规范Nulecule 【编者的话】这篇文章简单的介绍了Nulecule的产生、特性以及目标, Nulecule致力于构建一个统一的复合应用(基于多容器)的描述规范。笔者认为想法很好,但是要想实现这一目标不仅仅是一个技术问题,更多的是需要实现各个容器厂商的利益均衡,而做到这一点并不那么容易。不过还是应该肯定Project Atomic为此所做的事情。

为了帮助开发和管理人员创建和启动多容器组合的应用, Project Atomic 的童鞋们正在起草一份与平台无关的规范,叫做Nulecule(noo-le-kyul)。你可以在 RHEL博客中 找到关于此方案的完整解释以及我们的解决方案。

我们也已经创建了一个叫做 Atomic App 的应用,可以帮助我们运行使用Nulecule规范的应用。如果你想尝试一下,可以从那些链接中获取更多的信息。

QQ截图20150525210456.png


那我们为什么要做这件事情了?因为容器正在重塑IT版图,并且很快就会颠覆之前那些根深蒂固的技术。这是件好事,因为它确实可以解决很多的问题。但是容器的生态系统并不完善,毕竟它才刚刚开始发展。现在仍然还有很多挑战,但是每个挑战都是一个机会。既然如此,这里就有这样一个机会:构建应用的可管理性,并且创建一个标准化的方法使得可扩展的、复合(composite)应用配置变的更容易。

在这次IT技术的演进过程中,我们遵循的是“MYSM(make your stuff manageable)”,就是“让你的东西可以管理”。Linux以及其它的一些组件组合而成的LAMP堆栈构建了一个非常大的开源软件生态系统。但是他们在可管理性方面还是做的不够,这也为各种各样的配置管理工具创造了机会。Java程序员总是对LAMP开发者不太满意,不断提醒他们缺少与管理工具的整合。不幸的是尝到了JMX以及WAR文件轻松部署带来的可管理性甜头之后,你不得不强迫自己去学习Java框架。那么玩开源的开发者应该怎么办?

其中一个答案就是把应用容器化,从而你可以独立的开发和更新应用的各个组件。但是,管理单个容器相对容易,而管理多个容器就比较困难了。这也正是Nulecule存在的意义。

Nulecule定义了一个模式(pattern)和模型(model)来打包复杂的多容器应用,所有的依赖,包括编排的元数据(orcherstration metadata),都会在一个容器镜像中构建、部署、监控以及管理。只要创建一个拥有Nulecule文件的容器,应用就可以运行了。在Nulecule规范中,你要在一个图中定义编排提供者、容器位置和配置参数,Atomic App在Kubernetes和Docker的帮助下会把他们拼凑到一起。Nulecule规范还支持多个复合应用的整合,它不绑定任何的容器以及编排工具,你可以使用任何容器和编排工具引擎。

Nulecule规范亮点:
  • 可以在一个容器中通过可扩展的元数据来维护应用描述和上下文
  • 可以通过继承来定义复杂应用,这些容器的组合定义都会放到一个单一的、标准的、轻便的描述中
  • 通过一个有向图来反应依赖之间的关系以简化复杂应用的依赖管理
  • 对容器和编排引擎不可知,可以使用任何的引擎和编排技术

我希望你使用我们的规范和实现,然后告诉我们,特别是跟其它实现一起工作时的缺陷,我们很想知道这些。因为我们真的想为开发者、工具创建者以及管理框架找到一个好的解决方案。理想地说,Nulecule将会涉及开发和运维两方面的工具。从运维方面来说有,Apache CloudStack、OpenStack、ManageIQ以及Ansible。从开发者方面来说有Visual Studio、Docker Compose、OpenShift和Eclipse。

考虑到现在有很多流行的容器格式、编排引擎和策略(Policy)管理工具,我想我们应该使用统一的定义和语言来描述复合应用。很明显,未来将会出现很多的多容器应用框架。如果他们使用同样的语言,那将会极大的简化开发者和运维人员的工作。

我们创建了 一些例子 来帮助你开始。第一个,也是最简单的例子叫做 helloapache 。它是一个基于centos/httpd镜像的单个pod,但要使用它,你需要一个拥有Atomic CLI和kubectl的机器。 实例录像

这里还有个复杂点的例子,展示了如何使用Docker部署OpenStack,以及使用answerfile.conf实现自动安装。 实例录像

另外一个例子是展示如何使用Atomic App、Docker和Kubernetes部署一个链接在一起的复合应用。 示例录像

我们在很短的时间内取得了很大的突破,但是接下来还有很多事情要做。我们非常激动可以分享我们到目前为止的工作,并且期望与大的社区合作,一起开发Nulecule,使得复杂容器化应用部署变得更简单容易。

原文链接:Announcing the Nulecule Specification for Composite Applications (翻译:左伟 校对:李颖杰)

===========================
译者介绍
左伟,就职于IBM,软件工程师,现从事于DevOps,云计算相关的研究,实现和推广。

原文发布时间为: 2015-05-25
本文作者:左伟 
本文来自云栖社区合作伙伴DockerOne,了解相关信息可以关注DockerOne。
原文标题:红帽发布多容器应用规范Nulecule
目录
相关文章
|
2月前
|
持续交付 开发者 Docker
探索容器化技术Docker及其在现代软件开发中的应用
探索容器化技术Docker及其在现代软件开发中的应用
|
1月前
|
存储 Prometheus 监控
Docker容器内进行应用调试与故障排除的方法与技巧,包括使用日志、进入容器检查、利用监控工具及检查配置等,旨在帮助用户有效应对应用部署中的挑战,确保应用稳定运行
本文深入探讨了在Docker容器内进行应用调试与故障排除的方法与技巧,包括使用日志、进入容器检查、利用监控工具及检查配置等,旨在帮助用户有效应对应用部署中的挑战,确保应用稳定运行。
41 5
|
1月前
|
开发框架 安全 开发者
Docker 是一种容器化技术,支持开发者将应用及其依赖打包成容器,在不同平台运行而无需修改。
Docker 是一种容器化技术,支持开发者将应用及其依赖打包成容器,在不同平台运行而无需修改。本文探讨了 Docker 在多平台应用构建与部署中的作用,包括环境一致性、依赖管理、快速构建等优势,以及部署流程和注意事项,展示了 Docker 如何简化开发与部署过程,提高效率和可移植性。
66 4
|
2月前
|
持续交付 开发者 Docker
探索容器化技术Docker及其在现代软件开发中的应用
探索容器化技术Docker及其在现代软件开发中的应用
|
2月前
|
运维 Kubernetes Docker
深入理解容器化技术及其在微服务架构中的应用
深入理解容器化技术及其在微服务架构中的应用
65 1
|
2月前
|
安全 网络安全 数据安全/隐私保护
利用Docker的网络安全功能来保护容器化应用
通过综合运用这些 Docker 网络安全功能和策略,可以有效地保护容器化应用,降低安全风险,确保应用在安全的环境中运行。同时,随着安全威胁的不断变化,还需要持续关注和研究新的网络安全技术和方法,不断完善和强化网络安全保护措施,以适应日益复杂的安全挑战。
46 5
|
2月前
|
存储 安全 Java
Java多线程编程中的并发容器:深入解析与实战应用####
在本文中,我们将探讨Java多线程编程中的一个核心话题——并发容器。不同于传统单一线程环境下的数据结构,并发容器专为多线程场景设计,确保数据访问的线程安全性和高效性。我们将从基础概念出发,逐步深入到`java.util.concurrent`包下的核心并发容器实现,如`ConcurrentHashMap`、`CopyOnWriteArrayList`以及`BlockingQueue`等,通过实例代码演示其使用方法,并分析它们背后的设计原理与适用场景。无论你是Java并发编程的初学者还是希望深化理解的开发者,本文都将为你提供有价值的见解与实践指导。 --- ####
|
2月前
|
Kubernetes Linux 开发者
深入探索容器化技术——Docker 的实战应用
深入探索容器化技术——Docker 的实战应用
92 0
|
2月前
|
存储 Cloud Native 开发者
深入探索容器化技术——Docker的实战应用
深入探索容器化技术——Docker的实战应用
42 0
|
2月前
|
JavaScript Linux 持续交付
深入探索容器化技术——Docker 的实战应用
深入探索容器化技术——Docker 的实战应用
60 0