用Puppet和Docker构建工具来自动化容器产品部署

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: 本文讲的是用Puppet和Docker构建工具来自动化容器产品部署【编者的话】本文介绍了最新版本的Puppet企业版支持的Docker自动化构建工具,包括了集成的Jenkins持续集成和部署以及支持新的编排系统。
本文讲的是用Puppet和Docker构建工具来自动化容器产品部署【编者的话】本文介绍了最新版本的Puppet企业版支持的Docker自动化构建工具,包括了集成的Jenkins持续集成和部署以及支持新的编排系统。

Puppet希望能将Docker构建工具纳入到自己的IT自动化管理中。新版本的Puppet企业版(Puppet Enterprise 2016.4)支持构建Docker容器,并自动部署到生产环境中。

Puppet的最新版本是在Puppet的用户年会PuppetConf 2016上公布的。该版本也和Jenkin持续集成和部署工具相整合,并提供了新的编排能力。

Puppet的资深软件工程师Gareth Rushgrove提到,Docker的入门很容易。作为构建工具,他将Dockerfile称为“80%的解决方案”(80 percent solution),但是复制粘贴(copy-and-paste)是开发者们复用镜像的常用方式之一。

他提到,“那么问题来了:当你有了500个开发者和几百个服务时,情况是怎样的呢?三年之后,你会发现一切变得碎片化,难以管理。”

Puppet Docker Image Build可以用来提供一致的方式来构建和发布容器,Rushgrove说,它和Docker build一样,但是着重于大组织的扩展。你可以使用与docker build命令相同的构建方式,但是使用Puppet的新工具。

Rushgrove提到,相对于Dockerfile来说,Puppet的方式更易复用,也更容易组合。它允许开发者创建可以复用的模块,同时可以使用Puppet的测试工具,进行持续集成和构建(CI/CD)。

关注度(Visibility)

与之前的版本相比,对于跨组织架构的变化,Puppet Enterprise 2016.4更能体现其中的原因。

Puppet的产品市场副总裁Tim Zonca说,“人们使用Puppet来规定安全和合规政策,Puppet能让他们知道其中的任何变化”。

Zonca说,“通常我们说,某个东西改变了,是不合规的(out of policy),我们会修复它。现在我们会说,某个东西改变了,但是它是有意的(intentional)。有人通过Puppet做到了这点,你可以深入进去查看他们是怎么做的,这可能是有意的,也可能是恶意的,但是我们可以修复这个问题。它能帮助区分Puppet中发生了什么。“

由于较差的可见性,传统的编排会导致冲突的配置或者未被记录的、临时的(ad-hoc)更改。现在,你可以在整个架构的某个部分,进行阶段化的部署和更改。分块架构(segment infrastructure)和应用是基于Puppet中储存的信息,比如位置、环境、配置资源,只会将变化部署在制定的块(segment)上。

Zonca说,“你可以使用金丝雀部署(canary deployments),例如,我先部署在10个节点上,如果一切正常的话,那么我就会在5000个节点上进行部署。”

他说,“你可能会说,我只想在Linux网络服务器上进行部署。对于使用某个版本的OpenSSL的节点,我需要更新这些变化。Puppet可以给你颗粒化的控制(granular control)和基于角色(role-based)的控制,你可以针对架构中的某个特定部分进行修改。”

Zonca提到,新版本的Jenkins允许用户使用代码定义他们的架构(define their infrastructure as code)。Puppet Jenkins流水线插件可以用一种自动化方式将Puppet和Jenkins结合在一起。
puppet-jenkins-plugin-1024x540.png

项目组可以使用Jenkins和Puppet Enterprise来搭建一个可持续化部署的流水线(continuous delivery pipelines),编排所有应用的部署任务。使用该流水线,Jenkins用户可以搭建CI流水线,然后针对特定应用创建Puppet编排任务。现在,所有这些都可以自动化完成。

针对VMware的vRealize云管理平台,该公司还发布了一款插件,可以在on-prem和混合云环境中自助部署架构(self-service provisioning of compliant infrastructure)。

未来之路(The Road Ahead)

随着容器技术在生产环境中的部署越来越多,配置管理工具供应商(如Puppet和Chef)面临了新的挑战,来证明自身的价值。随着去年Red Hat收购了Ansible,Ansible也日益突出了。

最近的OpenStack的用户调查指出,Ansible的流行重点突出了编排工具,如Kubernetes、Swarm和Mesos。

Puppet自己的编排器在去年秋天发布了。PQL(Puppet Query Language)的扩展使用,这种语法可以用来描述节点上的各种服务,也可以用来直接部署更改,并监控发生了什么。如果有什么事情发生了错误,你可以停止它,并排错,然后继续部署。

Docker整合技术(Docker integration technologies)是Puppet的BlueShift项目的结果,该项目在四月份启动。Zonca告诉The New Stack,“该项目是Puppet内部工程师、技术公司(technology companies)和各自社区的合作,将Puppet作为一种通用语言来管理新技术。”

Puppet之前发布了很多模块:Kubernetes模块,可以用Puppet代码来管理编排环境;管理Docker程序和容器的模块;Consul(HashiCorp的服务发现工具)模块。目前,Mesos模块正在开发中。

目前,正在将Puppet和VMWare的Photon、其他的容器即服务(container-as-a-service)平台整合。

BlueShift项目的Rushgrove说,这一系列显示了我们正在做什么。

原文链接:Puppet Now Comes with Docker Build Tools to Automate Container Production Deployments(翻译:夏彬)

原文发布时间为:2016-12-15

本文作者:夏彬

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

原文标题:用Puppet和Docker构建工具来自动化容器产品部署

相关文章
|
21天前
|
监控 NoSQL 时序数据库
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
173 77
|
29天前
|
监控 Docker 容器
在Docker容器中运行打包好的应用程序
在Docker容器中运行打包好的应用程序
|
1天前
|
Ubuntu Linux 开发工具
docker 是什么?docker初认识之如何部署docker-优雅草后续将会把产品发布部署至docker容器中-因此会出相关系列文章-优雅草央千澈
Docker 是一个开源的容器化平台,允许开发者将应用程序及其依赖项打包成标准化单元(容器),确保在任何支持 Docker 的操作系统上一致运行。容器共享主机内核,提供轻量级、高效的执行环境。本文介绍如何在 Ubuntu 上安装 Docker,并通过简单步骤验证安装成功。后续文章将探讨使用 Docker 部署开源项目。优雅草央千澈 源、安装 Docker 包、验证安装 - 适用场景:开发、测试、生产环境 通过以上步骤,您可以在 Ubuntu 系统上成功安装并运行 Docker,为后续的应用部署打下基础。
docker 是什么?docker初认识之如何部署docker-优雅草后续将会把产品发布部署至docker容器中-因此会出相关系列文章-优雅草央千澈
|
7天前
|
存储 Kubernetes 开发者
容器化时代的领航者:Docker 和 Kubernetes 云原生时代的黄金搭档
Docker 是一种开源的应用容器引擎,允许开发者将应用程序及其依赖打包成可移植的镜像,并在任何支持 Docker 的平台上运行。其核心概念包括镜像、容器和仓库。镜像是只读的文件系统,容器是镜像的运行实例,仓库用于存储和分发镜像。Kubernetes(k8s)则是容器集群管理系统,提供自动化部署、扩展和维护等功能,支持服务发现、负载均衡、自动伸缩等特性。两者结合使用,可以实现高效的容器化应用管理和运维。Docker 主要用于单主机上的容器管理,而 Kubernetes 则专注于跨多主机的容器编排与调度。尽管 k8s 逐渐减少了对 Docker 作为容器运行时的支持,但 Doc
54 5
容器化时代的领航者:Docker 和 Kubernetes 云原生时代的黄金搭档
|
13天前
|
关系型数据库 应用服务中间件 PHP
实战~如何组织一个多容器项目docker-compose
本文介绍了如何使用Docker搭建Nginx、PHP和MySQL的环境。首先启动Nginx容器并查看IP地址,接着启动Alpine容器并安装curl测试连通性。通过`--link`方式或`docker-compose`配置文件实现服务间的通信。最后展示了Nginx配置文件和PHP代码示例,验证了各服务的正常运行。
38 3
实战~如何组织一个多容器项目docker-compose
|
12天前
|
Serverless 决策智能 UED
构建全天候自动化智能导购助手:从部署者的视角审视Multi-Agent架构解决方案
在构建基于多代理系统(Multi-Agent System, MAS)的智能导购助手过程中,作为部署者,我体验到了从初步接触到深入理解再到实际应用的一系列步骤。整个部署过程得到了充分的引导和支持,文档详尽全面,使得部署顺利完成,未遇到明显的报错或异常情况。尽管初次尝试时对某些复杂配置环节需反复确认,但整体流程顺畅。
|
22天前
|
数据建模 应用服务中间件 nginx
docker替换宿主与容器的映射端口和文件路径
通过正确配置 Docker 的端口和文件路径映射,可以有效地管理容器化应用程序,确保其高效运行和数据持久性。在生产环境中,动态替换映射配置有助于灵活应对各种需求变化。以上方法和步骤提供了一种可靠且易于操作的方案,帮助您轻松管理 Docker 容器的端口和路径映射。
75 3
|
29天前
|
数据库 Docker 容器
Docker在现代软件开发中扮演着重要角色,通过Dockerfile自动化构建Docker镜像,实现高效、可重复的构建过程。
Docker在现代软件开发中扮演着重要角色,通过Dockerfile自动化构建Docker镜像,实现高效、可重复的构建过程。Dockerfile定义了构建镜像所需的所有指令,包括基础镜像选择、软件安装、文件复制等,极大提高了开发和部署的灵活性与一致性。掌握Dockerfile的编写,对于提升软件开发效率和环境管理具有重要意义。
58 9
|
27天前
|
运维 jenkins Java
Jenkins 自动化局域网管控软件构建与部署流程
在企业局域网管理中,Jenkins 作为自动化工具,通过配置源码管理、构建及部署步骤,实现了高效、稳定的软件开发与部署流程,显著提升局域网管控软件的开发与运维效率。
40 5
|
29天前
|
负载均衡 网络协议 算法
Docker容器环境中服务发现与负载均衡的技术与方法,涵盖环境变量、DNS、集中式服务发现系统等方式
本文探讨了Docker容器环境中服务发现与负载均衡的技术与方法,涵盖环境变量、DNS、集中式服务发现系统等方式,以及软件负载均衡器、云服务负载均衡、容器编排工具等实现手段,强调两者结合的重要性及面临挑战的应对措施。
67 3