Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Use docker-compose with multiple repositories

I'm currently struggling with the deployment of my services and I wanted to ask, what's the proper way when you have to deal with multiple repositories. The repositories are independent, but to run in production, everything needs to be launched.

My Setup:

  • Git Repository Backend:
    • Backend Project Rails
    • docker-compose: backend(expose 3000), db and redis
  • Git Repository Frontend
    • Express.js server
    • docker-compose: (expose 4200)

Both can be run independently and test can be executed by CI

  • Git Repository Nginx for Production
    • Needs to connect to the other two services (same docker network)
    • forwards requests to the right service

I have already tried to include the two services as submodules into the Nginx repository and use the docker-compose of the nginx repo, but I'm not really happy with it.

like image 776
Mathias Aichinger Avatar asked Jan 19 '17 00:01

Mathias Aichinger


People also ask

Can you use multiple Docker compose files?

Using Multiple Docker Compose Files The use of multiple Docker Compose files allows you to change your application for different environments (e.g. staging, dev, and production) and helps you run admin tasks or tests against your application. Docker Compose reads two files by default, a docker-compose.

Is Docker compose deprecated?

Following the deprecation of Compose on Kubernetes, support for Kubernetes in the stack and context commands in the docker CLI is now marked as deprecated as well.

Can we have two Dockerfiles?

Let's say we have two Dockerfiles, one for building the backend and another for building the frontend. We can name them appropriately and invoke the build command two times, each time passing the name of one of the Dockerfiles: $ docker build -f Dockerfile.


1 Answers

You can have your CI build and push images for each service you want to run, and have the production environment run all 3 containers.

Then, your production docker-compose.yml would look like this:

lb:   image: nginx   depends_on:     - rails     - express   ports: 80:80    rails:     image: yourorg/railsapp    express:     image: yourorg/expressapp 

Be noted that docker-compose isn't recommended for production environments; you should be looking at using Distributed Application Bundles (this is still an experimental feature, which will be released to core in version 1.13)

Alternatively, you can orchestrate your containers with a tool like ansible or a bash script; just make sure you create a docker network and attach all three containers to it so they can find each other.

Edit: since Docker v17 and the deprecation of DABs in favour of the Compose file v3, it seems that for single-host environments, docker-compose is a valid way for running multi-service applications. For multi-host/HA/clusterised scenarios you may want to look into either Docker Swarm for a self-managed solution, or Docker Cloud for a more PaaS approach. In any case, I'd advise you to try it out in Play-with-Docker, the official online sandbox where you can spin out multiple hosts and play around with a swarm cluster without needing to spin out your own boxes.

like image 62
gvilarino Avatar answered Sep 28 '22 16:09

gvilarino