What would be a good docker webdev workflow?

2019-01-29 14:43发布

I have a hunch that docker could greatly improve my webdev workflow - but I haven't quite managed to wrap my head around how to approach a project adding docker to the stack.

The basic software stack would look like this:

Software

  • Docker image(s) providing custom LAMP stack

    • Apache with several modules
    • MYSQL
    • PHP
    • Some CMS, e.g. Silverstripe
  • GIT

Workflow

I could imagine the workflow to look somewhat like the following:

Development

  1. Write a Dockerfile that defines a LAMP-container meeting the requirements stated above
    • REQ: The machine should start apache/mysql right after booting
  2. Build the docker image
  3. Copy the files required to run the CMS into e.g. ~/dev/cmsdir
    • Put ~/dev/cmsdir/ under version control
  4. Run the docker container, and somehow mount ~/dev/cmsdir to /var/www/ on the container
  5. Populate the database
  6. Do work in /dev/cmsdir/
  7. Commit & shut down docker container

Deployment

  1. Set up remote host (e.g. with ansible)
  2. Push container image to remote host
  3. Fetch cmsdir-project via git
  4. Run the docker container, pull in the database and mount cmsdir into /var/www

Now, this looks all quite nice on paper, BUT I am not quite sure whether this would be the right approach at all.

Questions:

  1. While developing locally, how would I get the database to persist between reboots of the container instance? Or would I need to run sql-dump every time before spinning down the container?

  2. Should I have separate container instances for the db and the apache server? Or would it be sufficient to have a single container for above use case?

  3. If using separate containers for database and server, how could I automate spinning them up and down at the same time?

  4. How would I actually mount /dev/cmsdir/ into the containers /var/www/-directory? Should I utilize data-volumes for this?

  5. Did I miss any pitfalls? Anything that could be simplified?

标签: docker
4条回答
在下西门庆
2楼-- · 2019-01-29 15:36

I understand this post is over a year old at this time, but I have recently asked myself very similar questions and have several great answers to your questions.

  1. You can setup a MySQL docker instance and have data persist on a stateless data container, aka the data container does not need to be actively running

  2. Yes I would recommend having a separate instance for your web server and database. This is the power of Docker.

  3. Check out this repo I have been building. Basically it is as simple as make build & make run and you can have a web server and database container running locally.

  4. You use the -v argument when running the container for the first time, this will link a specific folder on the container to the host running the container.

  5. I think your ideas are great and it is currently possible to achieve all that you are asking.

Here is a turn key solution achieving all of the needs you have listed.

查看更多
欢心
3楼-- · 2019-01-29 15:39
  1. If you need database persistance indepent of your CMS container, you can use one container for MySQL and one container for your CMS. In such case, you can have your MySQL container still running and your can redeploy your CMS as often as you want independently.

    For development - the another option is to map mysql data directories from your host/development machine using data volumes. This way you can manage data files for mysql (in docker) using git (on host) and "reload" initial state anytime you want (before starting mysql container).

  2. Yes, I think you should have a separate container for db.

  3. I am using just basic script:

    #!/bin/bash
    
    $JOB1 = (docker run ... /usr/sbin/mysqld)
    $JOB2 = (docker run ... /usr/sbin/apache2)
    echo MySql=$JOB1, Apache=$JOB2
    
  4. Yes, you can use data-volumes -v switch. I would use this for development. You can use read-only mounting, so no changes will be made to this directory if you want (your app should store data somewhere else anyway).

    docker run -v=/home/user/dev/cmsdir:/var/www/cmsdir:ro image /usr/sbin/apache2
    

    Anyway, for final deployment, I would build and image using dockerfile with ADD /home/user/dev/cmsdir /var/www/cmsdir

  5. I don't know :-)

查看更多
时光不老,我们不散
4楼-- · 2019-01-29 15:41

You want to use docker-compose. Follow the tutorial here. Very simple. Seems to tick all your boxes.

https://docs.docker.com/compose/

查看更多
冷血范
5楼-- · 2019-01-29 15:43

I've put together an easy to use docker compose setup that should match your development workflow requirements.

https://github.com/ehyland/docker-silverstripe-dev

Main Features

  • Persistent DB
  • Your choice of HHVM + NGINX or Apache2 + PHP5
  • Debug and set breakpoints with xDebug

The README.md should be clear enough to get you started.

查看更多
登录 后发表回答