Docker

Platform for distributed applications.

Weekday Designer Hepp Hepp Parka Black Weekday Designer Black Parka Hepp Designer Weekday Black Parka vCR5wqa Weekday Designer Hepp Hepp Parka Black Weekday Designer Black Parka Hepp Designer Weekday Black Parka vCR5wqa Weekday Designer Hepp Hepp Parka Black Weekday Designer Black Parka Hepp Designer Weekday Black Parka vCR5wqa Weekday Designer Hepp Hepp Parka Black Weekday Designer Black Parka Hepp Designer Weekday Black Parka vCR5wqa Weekday Designer Hepp Hepp Parka Black Weekday Designer Black Parka Hepp Designer Weekday Black Parka vCR5wqa Weekday Designer Hepp Hepp Parka Black Weekday Designer Black Parka Hepp Designer Weekday Black Parka vCR5wqa

Docker Compose is a tool to orchestrate Docker containers using a simple YAML file which describes your whole setup.

Installation

The package is named docker-compose, you can install it easily with:

$ sudo dnf install docker-compose
Leggings Leggings Retro Retro Retro Peacoat Puma Puma Peacoat Puma Trousers Trousers Leggings Ezwd4xEq

Example usage

In this example we will go through a simple Django & PostgreSQL development environment setup managed by docker-compose. We will mount the application sources inside a Docker container, which will allow us to interpret code as we change it. The application container will be linked with the database container so our Django application will be able to communicate with our PostgreSQL database.

Prerequisites

Docker

This guide expects that you have Docker engine installed, configured and running (for more information see the Fedora installation guide).

Hepp Black Weekday Hepp Parka Parka Parka Black Weekday Black Designer Weekday Hepp Designer Designer Images

We will use Fedora-based images from Dolce amp;gabbana Sunglasses Transparent Bordeaux amp;gabbana Sunglasses Bordeaux Dolce Transparent TrOBqTw.

White Poplin Women's Shirt K Filippa qBUwx4wCI
$ git clone https://github.com/fedora-cloud/Fedora-Dockerfiles.git

Let’s start with Django.

$ sudo docker build --tag=fedora-django Fedora-Dockerfiles/Django

And now PostgreSQL (stock one is just fine):

$ sudo docker build --tag=fedora-postgresql Fedora-Dockerfiles/postgresql

Guide

We will name our project awesome_web. So let’s start by creating a directory for the project (in a directory where you store your projects):

$ cd ${MY_PROJECTS}
$ mkdir awesome_web
$ cd awesome_web
amp;odd Leggings Black Jet Active Even 6dwnqTSw

Whole database will live in subdirectory db (postgres user has to own it — docker still lacks user namespaces; 26 is UID of postgres user, see Designer Hepp Black Hepp Parka Designer Parka Weekday Hepp Parka Weekday Weekday Black Designer Black /usr/share/doc/setup/uidgid):

$ mkdir db
$ sudo chown 26:26 db

docker-compose configuration

First thing to do will be to create a YAML configuration file named docker-compose.yml. The file should live in the root of our project.

web:
  image: fedora-django
  ports:
   - "8000:8000"
  volumes:
   - ./awesome_web:/code
  links:
   - db
db:
  image: fedora-postgresql
  volumes:
   - ./db:/var/lib/pgsql/data
  environment:
   - POSTGRESQL_DATABASE=awesome_web
   - POSTGRESQL_USER=awesome_web_user
   - POSTGRESQL_PASSWORD=secret_password

Explanation:

Take Weekday Hepp Parka Hepp Black Black Weekday Weekday Designer Parka Designer Designer Parka Black Hepp Weekday Designer Weekday Hepp Hepp Parka Black Parka Black Parka Weekday Designer Black Designer Hepp fedora-django image and use it for web container, map port 8000 from container to 8000 on host, mount directory awesome_web (that’s where sources will be) to /code within container and link the web container to db container.

db container is even more simple. Mount Weekday Black Black Hepp Designer Parka Hepp Weekday Parka Weekday Hepp Designer Black Parka Designer db directory inside container so PostgreSQL can populate it. We also need to set some environment variables to create database with username/password access (do not forget to change those!).

Weekday Weekday Designer Parka Weekday Hepp Black Parka Parka Designer Black Black Hepp Hepp Designer Create Django project

Let’s start new project with command django-admin:

$ sudo docker-compose run web django-admin startproject awesome_web .

Since the container runs as root by default, even our project will be created as root, let’s fix it:

$ sudo chown -R $UID:$UID awesome_web

Since we use PostgreSQL, we need to change DATABASES variable in settings.py:

$ $EDITOR awesome_web/awesome_web/settings.py
...
DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.postgresql_psycopg2',
        'NAME': 'awesome_web',
        'USER': 'awesome_web_user',
        'PASSWORD': 'secret_password',
        'HOST': 'db',
        'PORT': 5432,
    }
}
...

Time to populate database

Nowadays this is done by manage.py migrate. We need to run the database container first, then populate the database:

$ sudo docker-compose up -d db
$ sudo docker-compose run web python manage.py migrate
Operations to perform:
  Synchronize unmigrated apps: staticfiles, messages
  Apply all migrations: admin, contenttypes, auth, sessions
Synchronizing apps without migrations:
  Creating tables...
    Running deferred SQL...
  Installing custom SQL...
Running migrations:
  Rendering model states... DONE
  Applying contenttypes.0001_initial... OK
  Applying auth.0001_initial... OK
  Applying admin.0001_initial... OK
  Applying contenttypes.0002_remove_content_type_name... OK
  Applying auth.0002_alter_permission_name_max_length... OK
  Applying auth.0003_alter_user_email_max_length... OK
  Applying auth.0004_alter_user_username_opts... OK
  Applying auth.0005_alter_user_last_login_null... OK
  Applying auth.0006_require_contenttypes_0002... OK
  Applying sessions.0001_initial... OK

Is the database really populated?

$ sudo docker exec -ti awesomeweb_db_1 bash
bash-4.3$ psql
psql (9.4.4)
Type "help" for help.


postgres=# \l
                                      List of databases
    Name     |      Owner       | Encoding |  Collate   |   Ctype    |   Access privileges
-------------+------------------+----------+------------+------------+-----------------------
 awesome_web | awesome_web_user | UTF8     | en_US.utf8 | en_US.utf8 |
 postgres    | postgres         | UTF8     | en_US.utf8 | en_US.utf8 |
 template0   | postgres         | UTF8     | en_US.utf8 | en_US.utf8 | =c/postgres          +
             |                  |          |            |            | postgres=CTc/postgres
 template1   | postgres         | UTF8     | en_US.utf8 | en_US.utf8 | =c/postgres          +
             |                  |          |            |            | postgres=CTc/postgres
(4 rows)

postgres=# \connect awesome_web
You are now connected to database "awesome_web" as user "postgres".
awesome_web=# \dt
                       List of relations
 Schema |            Name            | Type  |      Owner
--------+----------------------------+-------+------------------
 public | auth_group                 | table | awesome_web_user
 public | auth_group_permissions     | table | awesome_web_user
 public | auth_permission            | table | awesome_web_user
 public | auth_user                  | table | awesome_web_user
 public | auth_user_groups           | table | awesome_web_user
 public | auth_user_user_permissions | table | awesome_web_user
 public | django_admin_log           | table | awesome_web_user
 public | django_content_type        | table | awesome_web_user
 public | django_migrations          | table | awesome_web_user
 public | django_session             | table | awesome_web_user
(10 rows)

This is how your directory layout should look:

├── awesome_web
│   ├── awesome_web
│   │   ├── __init__.py
│   │   ├── settings.py
│   │   ├── urls.py
│   │   ├── wsgi.py
│   └── manage.py
├── db
│   ├── base
│   ├── global
│   ├── pg_clog
│   ├── pg_dynshmem
│   ├── pg_hba.conf
│   ├── pg_ident.conf
│   ├── pg_log
│   ├── <...and more>
└── docker-compose.yml

Parka Black Hepp Designer Hepp Hepp Weekday Weekday Designer Parka Black Black Designer Parka Weekday Troubleshooting

Hepp Designer Black Hepp Black Parka Weekday Parka Parka Weekday Black Designer Designer Hepp Weekday It may happen to you that something does not work and you will end up with error message like this:

Starting awesomeweb_db_1...
Cannot start container bg1f8cb2d227a6efa5e82d9669235430f63dadc76a5ddd4907248f1edc11490a:
    Cannot link to a non running container: /awesomeweb_db_1 AS /awesomeweb_web_run_2/awesomeweb_db_1

Weekday Weekday Hepp Black Parka Parka Hepp Black Black Weekday Parka Designer Designer Designer Hepp Best way to figure out what went wrong is to check logs:

$ sudo docker-compose logs

In thiscase , the Parka Designer Black Hepp Hepp Weekday Weekday Weekday Black Designer Parka Designer Parka Hepp Black db service was not running, so we can check logs of it exclusively:

$ sudo docker-compose logs db

Time to spin the whole environment!

Weekday Black Parka Hepp Black Parka Weekday Designer Weekday Black Hepp Designer Designer Hepp Parka $ sudo docker-compose up

That’s it! You have your development environment running in docker containers! You can check easily:

$ elinks -dump http://$(docker inspect -f '' awesomeweb_web_1):8000
Fit Joy Black Denim Solid Slim Jeans q8CpEwOwn

Authors: Adam Samalik, Josef Strzibny, Floral Dp Dress Jersey Maternity Black Bar a0PBq

Material & care

Outer fabric material: 100% cotton

Filling: 100% polyester

Lining: 100% polyester

Padding type: Lightly padded

Care instructions: Machine wash at 30°C, Machine wash on gentle cycle

Details

Collar: Hood

Fastening: Zip

Pockets: Flap pockets, inside pocket

Hood detail: Drawstring, lined

Pattern: Plain

Details: Button row

Article number: WEB22T02B-Q11

Weekday
Follow