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

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
容器服务 Serverless 版 ACK Serverless,317元额度 多规格
容器服务 Serverless 版 ACK Serverless,952元额度 多规格
简介: 本文讲的是用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构建工具来自动化容器产品部署

相关文章
|
16天前
|
监控 文件存储 Docker
实现NAS远程下载,Docker部署qBittorrent、Transmission、贝锐花生壳
与电脑不同,NAS通常7x24小时运行,便于下载资源,解决BT/PT下载需长时间在线的问题。因此,qBittorrent、Transmission等下载管理工具成为NAS用户的必备应用。通过Docker,用户可在多种NAS设备上快速安装这些工具,并通过局域网IP地址+端口访问。然而,缺乏公网IPv4地址导致远程访问困难,贝锐花生壳提供了解决方案,允许无公网IP情况下通过固定域名远程访问NAS中的下载工具,简化了部署过程,使用户能随时随地控制家中的下载任务。
136 33
实现NAS远程下载,Docker部署qBittorrent、Transmission、贝锐花生壳
|
17天前
|
负载均衡 网络协议 开发者
掌握 Docker 网络:构建复杂的容器通信
在 Docker 容器化环境中,容器间的通信至关重要。本文详细介绍了 Docker 网络的基本概念和类型,包括桥接网络、宿主网络、覆盖网络和 Macvlan 网络等,并提供了创建、管理和配置自定义网络的实用命令。通过掌握这些知识,开发者可以构建更健壮和灵活的容器化应用,提高应用的可扩展性和安全性。
|
15天前
|
Linux iOS开发 Docker
Docker:容器化技术的领航者 —— 从基础到实践的全面解析
在云计算与微服务架构日益盛行的今天,Docker作为容器化技术的佼佼者,正引领着一场软件开发与部署的革命。它不仅极大地提升了应用部署的灵活性与效率,还为持续集成/持续部署(CI/CD)提供了强有力的支撑。
198 69
|
9天前
|
应用服务中间件 Docker 容器
docker应用部署---Tomcat的部署配置
这篇文章介绍了如何使用Docker部署Tomcat服务器,包括搜索和拉取Tomcat镜像、创建容器并设置端口映射和目录映射,以及如何创建一个HTML页面并使用外部机器访问Tomcat服务器。
docker应用部署---Tomcat的部署配置
|
9天前
|
关系型数据库 MySQL 数据安全/隐私保护
docker应用部署---MySQL的部署配置
这篇文章介绍了如何使用Docker部署MySQL数据库,包括搜索和拉取MySQL镜像、创建容器并设置端口映射和目录映射、进入容器操作MySQL,以及如何使用外部机器连接容器中的MySQL。
docker应用部署---MySQL的部署配置
|
3天前
|
Kubernetes Cloud Native 持续交付
云原生之旅:Docker容器化与Kubernetes集群管理
【9月更文挑战第33天】在数字化转型的浪潮中,云原生技术如同一艘航船,带领企业乘风破浪。本篇文章将作为你的航海指南,从Docker容器化的基础讲起,直至Kubernetes集群的高级管理,我们将一起探索云原生的奥秘。你将学习到如何封装应用、实现环境隔离,以及如何在Kubernetes集群中部署、监控和扩展你的服务。让我们启航,驶向灵活、可伸缩的云原生未来。
|
16天前
|
运维 Cloud Native Docker
云原生技术入门:Docker容器化实战
【9月更文挑战第20天】本文将引导你走进云原生技术的世界,通过Docker容器化技术的实战演练,深入理解其背后的原理和应用。我们将一起探索如何在云平台上利用Docker简化部署、扩展和管理应用程序的过程,并揭示这一技术如何改变现代软件的开发和运维模式。
|
9天前
|
运维 Linux 网络安全
自动化运维的利器:Ansible、Puppet和Chef详解
自动化运维的利器:Ansible、Puppet和Chef详解
32 5
|
10天前
|
前端开发 应用服务中间件 nginx
docker部署本地前端项目思路
docker部署本地前端项目思路
23 7
|
10天前
|
Cloud Native 持续交付 Docker
云原生技术入门与实践:Docker容器化部署示例
【9月更文挑战第25天】在数字化转型的浪潮下,云原生技术成为推动企业创新的重要力量。本文旨在通过浅显易懂的语言,为初学者揭示云原生技术的核心概念及其应用价值。我们将以Docker容器为例,逐步引导读者了解如何将应用程序容器化,并在云端高效运行。这不仅是对技术趋势的跟随,更是对资源利用和开发效率提升的探索。
30 4
下一篇
无影云桌面