Skip to content
Michael Härtl edited this page Sep 9, 2015 · 3 revisions

To use this image you'll follow these two steps:

  • Create a new project
  • Set up and configure your development environment

We'll cover both steps in more detail below.

Create a new project

As mentioned above, this project is a template for your own projects. So when creating a new project you basically will

  1. copy the code into some directory,
  2. modify the main app configuration, usable environment variables, composer dependencies, README.md, inital DB migration, etc.
  3. commit the above to your repository

To copy the code to your computer, you can use composer to do the main work for you:

composer create-project --no-install codemix/yii2-dockerized myproject

As for step 2 above, you may first want to select a flavour of the docker base. You only need to uncomment the appropriate line in the Dockerfile:

FROM codemix/yii2-base:2.0.6-apache
#FROM codemix/yii2-base:2.0.6-php-fpm
#FROM codemix/yii2-base:2.0.6-hhvm

Then you should check the following files and directories:

  • Dockerfile: Optionally add PHP extensions
  • docker-compose-example.yml: Provide an example machine configuration for other developers
  • config/web.php / config/console.php: Update the main configuration
  • .env-example: Add more environment variables
  • composer.json: Add more dependencies for your project
  • migrations/: Update the initial DB migration to match your DB model
  • README.md: Describe your application

If you think everything is fine, it's time for the first commit to your project's repository. This will now be the starting point for your developers.

Set up a development environment

When you have the project in your repository, it's easy to set up a new development environment, e.g. for a new team member:

git clone <your-repo-url> ./myapp
cd myapp
cp docker-compose-example.yml docker-compose.yml
cp .env-example .env
docker-compose up
# From another terminal window:
docker-compose run --rm web ./yii migrate

It may take some minutes to download the required docker images. When done, you can access the new app from http://localhost:8080.

Note: The local app directory will be mapped into the /var/www/html directory of the web container. So you can always work on your local source files and will immediately see the results under the URL of the container.

The next step is to configure the application. For example you will want to enable YII_DEBUG or set other local configurations during development. So read on in the next section.

Clone this wiki locally