Docker 快速部署代码之道.docxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Docker 快速部署代码之道

Docker 快速部署代码之道在 Ionic,我们是 Docker 的铁杆粉丝。我们的代码以及代码的依赖全部运行在 Docker 中,Docker 让我们的产品更充分地利用计算资源,比如 Ionic Creator,以及即将到来的 Ionic.io 服务。使用 Docker 面对的一个挑战是,尽管我们只是对我们的代码做了一个小小的变更,我们都必须要走一遍构建一个新容器的过程,把它拉取(pull)到我们的服务器,并替代正在运行的版本。我们所有的代码都存储在 GitHub,使用 Docker Registry(这里推荐下国内的 ,速度比官方的快很多,不用担心“你懂的”问题) 来自动构建和存储我们的代码,并使用 Ansible 来管理和部署我们的容器到我们的服务器上。即使是一个完全自动化的过程,部署一个小变更都可能需要花费我们 20 分钟或者更多的时间。经过头脑风暴,我们意识到我们有一个更好的方法来利用 Docker。在最初的容器构建之后,99% 的变更都是纯代码。我们不需要添加任何依赖,或者是改变任何代码运行所必需的东西。Docker 实际上只是一种封装基础架构的方式,要求我们的代码运行在一个自包含的包中。因为我们 99% 的变更都是代码,不是基础架构,我们意识我们不需要在每次变更的时候都努力重新构建我们的基础架构。让我们解决这个问题的是 Docker 的杀手级特性 volumes。在我们 Docker files 的第一次迭代中,我们从 GitHub 拉取代码,并直接构建进容器中。现在,我们故意把代码放在容器外面,并在容器启动的时候,通过加载一个主机卷(host volume) 来代替。当我们想做一个新发布,Ansible 从 GitHub 上拉取 master 分支到我们服务器的 app 目录。这时,它通过检查来确保相关联的容器正在运行,如果没有在运行,它将启动这个容器并把 app 代码映射进容器。使得我们的工作更便捷的另外一个组件是 uWSGI,因为我们的大部分 app 是 Python 的(Django),所以我们在 Docker 容器中使用 uWSGI 提供服务。uWSGI 有一个 touch reload 特性,可以监控指定的文件,当该文件被 touch 的时候,会重载 uWSGI 服务。在 Ansible 从 GitHub 拉取我们的变更之后,我们使用 Ansible 来 touch uwsgi.ini 文件,这会触发正在运行的容器中的 uWSGI 重载。我们就是这样来运行我们代码的更新版本的!这是什么意思呢?简单地说,花费我们 20+ 分钟的部署过程是这样的:提交(Commit)和 推送(push)变更到 GitHub。 Docker Registry 拉取(pulls)变更和构建一个新容器。 Ansible 连接到我们的服务器并拉取(pulls)这个新容器 。 Ansible 发现任何旧容器正在运行的实例并停止它们。 Ansible 启动该容器的新实例。 类似的 10 秒的过程是这样的:提交(Commit)和 推送(push)变更到 GitHub。 Ansible 连接到我们的服务器,从 GitHub 拉取最新的 master。 Ansible touches 该 app 的 uwsgi.ini 文件来触发 UWSGI 的重载。 步骤分解Supervisor / uWSGI我们在 Docker 容器中使用 Supervisor 来启动容器中的进程运行。我们的 supervisord.conf 文件看起来像下面这样:[supervisord]?nodaemon=true?[program:uwsgi]?command?=?/usr/local/bin/uwsgi?--touch-reload=/path/to/code/in/container/uwsgi.ini?--ini?/path/to/code/in/container/uwsgi.ini?我们通过 --touch-reload 选项来把 uwsgi.ini 文件作为触发文件。Docker当我们启动我们的容器,我们添加一个包含我们 app 代码的主机卷(host volume),该主机卷被映射到容器中的一个 app 路径,uWSGI 将从这个路径加载 app。docker?run?-d?-P?-v?/path/to/code/on/host:/path/to/code/in/container?--name=container_name?driftyco/testapp?AnsibleAnsible 负责从 GitHub 克隆(clone)我们应用程序的代码到我们主机的 app 目录,确保 Docker 容器正在运行以及 touch 配置的 uWSGI t

文档评论(0)

xcs88858 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

版权声明书
用户编号:8130065136000003

1亿VIP精品文档

相关文档