Docker:如何Dockerize和部署LAMP应用程序的多个实例

时间:2014-07-24 08:31:49

标签: web-applications web-deployment lamp docker

我需要部署同一个LAMP(或LEMP)应用程序的许多实例:

  • 每个实例都可以通过前置loadbalancer / proxy
  • 从子域访问
  • 每个实例都必须有自己的数据库数据和文件数据。
  • 可能会监控每个实例
  • 每个应用实例可能设置内存限制/ cpu
  • 易于自动部署新的webapp实例
  • 环境可能很容易重现,无法进行测试和开发。

申请要求:

  • dameon流程(NginxMariaDBPHPFPM
  • 二进制文件(composerbower,...)
  • 其他系统特定的libs&配置

在阅读了Docker文档和许多howtos之后,我看到了将此Web应用程序停靠的不同解决方案:


解决方案1:使用一体化容器

所有筹码都在一个容器中:

  • webapp源文件,EMP守护进程,二进制文件......
  • 已装入mysql和webapp数据文件的卷

示例:

优点(恕我直言):

  • 似乎很容易自动化部署,监控,摧毁......
  • 易于在prod,test和dev环境中使用。

缺点(恕我直言):

  • 单片
  • 难以扩展
  • 不使用Docker的所有优势

解决方案2:每个webapp实例使用容器堆栈

对于要部署的每个Web应用程序,都会部署容器堆栈:

  • 每个流程一个容器:NginxMysqlPHP-FPM
  • 二进制容器(composerbower,...)也可以泊坞化,或者在phpfpm容器中合并
  • 为mysql和webapp数据文件装载卷

示例:

专业(恕我直言):

  • 解耦
  • 每个实例隔离的进程
  • 每个容器一个进程,不需要守护程序管理器作为RUnit或 Supervisord

缺点(恕我直言):

  • 看起来工作更复杂
  • 很难维护,看到所有容器状态,链接,版本的“大图”......

解决方案3:混合2种先前的溶液

  • 一个“app”容器:app src文件,nginx,phpfmp,composer,git ..
  • db mysql的一个容器,可以与应用容器共享或不共享

我比Ops更多Dev,也让我感到困惑。

所以,问题:

  1. 在选择这些解决方案时,有哪些标准,优点/缺点?
  2. 如何选择解决方案2,如何管理所有容器堆栈,以获得"大图片"所有容器状态,链接,版本......?
  3. App src文件(PHP)可以在容器中构建,也可以作为卷安装,例如。 / var / www?

2 个答案:

答案 0 :(得分:18)

我最近对Docker进行了此类设置的分析。我知道有些人认为Docker是一种MicroVM,但我的看法是Docker的理念更倾向于每个容器的单个进程。这与编程中的单一责任原则很吻合。 Docker容器越多,可重用性越低,管理难度越大。我在这里发布了我的所有想法:

http://software.danielwatrous.com/a-review-of-docker/

然后我继续使用Docker构建LEMP堆栈。在将PHP和Nginx进程拆分为单独的Docker容器时,我没有找到很多价值,但Web和数据库函数位于不同的容器中。我还将展示如何管理链接和卷共享,以避免在容器中运行SSH守护程序。你可以按照我在这里做的作为参考点。

http://software.danielwatrous.com/use-docker-to-build-a-lemp-stack-buildfile/

对于每个容器的单个函数增加复杂度的观点,您是对的。它的外观和感觉就像你有不同的分布式层。非常大的应用程序已经做了多年,并且在通信,安全性和管理方面确实增加了复杂性。当然,它也带来了许多好处。

答案 1 :(得分:9)

两种解决方案都是可行的。但是,我会选择解决方案2 - 每个进程一个容器 - 因为它更兼容Docker"哲学"。

Docker的优点在于,您可以创建具有独立构建块(单个应用程序的图像)的应用程序堆栈(与您的一样)。您可以组合这些构建块并重用它们。如果您查看official Docker registry,您会发现大多数组件都是预构建映像。例如。你会在https://registry.hub.docker.com/u/dockerfile/nginx找到一个Nginx,在https://registry.hub.docker.com/_/mysql找到一个MySQL数据库。因此,如果您选择为每个进程/应用程序使用一个容器,则设置堆栈变得非常容易:

(注意,这只是一个例子,我不熟悉PHP和东西......)

获取图片:

docker pull mysql
docker pull dockerfile/nginx
docker pull tutum/apache-php

docker run --name some-mysql -e MYSQL_ROOT_PASSWORD=mysecretpassword -d mysql
docker run -d -p 80:80 -v <sites-enabled-dir>:/etc/nginx/sites-enabled -v <log-dir>:/var/log/nginx dockerfile/nginx
docker run -d -p 80:80 tutum/apache-php

您可以像这样轻松设置堆栈。而且,如果您愿意,可以更改一些单个组件。例如。您可以使用MariaDB更改MySQL数据库,而无需触及其他组件。

该解决方案最复杂的是如何配置堆栈。要关联容器,请查看https://docs.docker.com/userguide/dockerlinks。您可以使用此方法链接,例如你的MySQL容器的应用程序容器。