.. _add_your_own_docker_image: ************************* Add your own Docker image ************************* This section is all about customizing the Devilbox and its Docker images specifically to your needs. **Table of Contents** .. contents:: :local: Prerequisites ============= The new Docker image definition will be added to a file called ``docker-compose.override.yml``. So before going any further, read the following section that shows you how to create this file for the Devilbox as well as what pitfalls to watch out for. .. seealso:: :ref:`docker_compose_override_yml` What information do you need? ============================= 1. ```` - A name, which you can use to refer in the ``docker-compose`` command 2. ```` - The Docker image name itself 3. ```` - The Docker image tag 4. ```` - An unused IP address from the devilbox network (found inside ``docker-compose.yml``) How to add a new service? ========================= Generic example --------------- A single new service ^^^^^^^^^^^^^^^^^^^^ Open ``docker-compose.override.yml`` with your favourite editor and paste the following snippets into it. .. code-block:: yaml :caption: docker-compose.override.yml :name: docker-compose.override.yml :emphasize-lines: 4,5,8 version: '2.1' services: # Your custom Docker image here: : image: : networks: app_net: ipv4_address: # For ease of use always automatically start these: depends_on: - bind - php - httpd # End of custom Docker image .. note:: * ```` has to be replaced with any name of your choice * ```` has to be replaced with the name of the Docker image * ```` has to be replaced with the tag of the Docker image * ```` has to be replaced with an unused IP address Two new services ^^^^^^^^^^^^^^^^ .. code-block:: yaml :caption: docker-compose.override.yml :name: docker-compose.override.yml :emphasize-lines: 4,5,8,16,17,20 version: '2.1' services: # Your first custom Docker image here: : image: : networks: app_net: ipv4_address: # For ease of use always automatically start these: depends_on: - bind - php - httpd # End of first custom Docker image # Your second custom Docker image here: : image: : networks: app_net: ipv4_address: # For ease of use always automatically start these: depends_on: - bind - php - httpd # End of second custom Docker image .. note:: * ```` has to be replaced with any name of your choice * ```` has to be replaced with the name of the Docker image * ```` has to be replaced with the tag of the Docker image * ```` has to be replaced with an unused IP address .. note:: * ```` has to be replaced with any name of your choice * ```` has to be replaced with the name of the Docker image * ```` has to be replaced with the tag of the Docker image * ```` has to be replaced with an unused IP address CockroachDB example ------------------- Gather the requirements for the `Cockroach DB `_ Docker image: 1. Name: ``cockroach`` 2. Image: ``cockroachdb/cockroach`` 3. Tag: ``latest`` 4. IP: ``172.16.238.200`` Now add the information to ``docker-compose.override.yml``: .. code-block:: yaml :caption: docker-compose.override.yml :name: docker-compose.override.yml :emphasize-lines: 4-5,9 version: '2.1' services: # Your custom Docker image here: cockroach: image: cockroachdb/cockroach:latest command: start --insecure networks: app_net: ipv4_address: 172.16.238.200 # For ease of use always automatically start these: depends_on: - bind - php - httpd # End of custom Docker image How to start the new service? ============================= The following will bring up your service including all of its dependent services, as defined with ``depends_on`` (bind, php and httpd). You need to replace ```` with the name you have chosen. .. code-block:: bash host> docker-compose up In the example of Cockroach DB the command would look like this .. code-block:: bash host> docker-compose up cockroach Further reading =============== .. seealso:: * :ref:`docker_compose_override_yml` * :ref:`overwrite_existing_docker_image`