Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/inushin/dockerodoosymfonyssl

This is a complete stack for running Odoo with NGINX, PostgreSQL and PHP into Docker containers using docker-compose tool and with Certbot for the HTTPS certificate.
https://github.com/inushin/dockerodoosymfonyssl

certbot docker docker-compose nginx nginx-proxy odoo odoo13 php74 postgresql symfony

Last synced: about 1 month ago
JSON representation

This is a complete stack for running Odoo with NGINX, PostgreSQL and PHP into Docker containers using docker-compose tool and with Certbot for the HTTPS certificate.

Awesome Lists containing this project

README

        

# 🐳 Docker + PHP 7.4 + PostgreSQL 13 + Odoo 13 + Nginx + Certbot(HTTPS) + Symfony 5 Boilerplate 🐳

![symfonyOdoo](https://user-images.githubusercontent.com/57062736/151148982-188f8427-5a88-430d-9247-5eca67072f40.png)

If you find this useful, remember about giving a start ⭐ to this repo or share it 🔁

Created from `https://github.com/Inushin/dockerSymfonySSL`

## Description 📋

![docker_facebook_share](https://user-images.githubusercontent.com/57062736/139103227-36f3cb32-c3c1-4158-b99e-25a31e955f44.png)

This is a complete stack for running Odoo with NGINX, PostgreSQL and PHP into Docker containers using docker-compose tool and with Certbot for the HTTPS certificate.

It is composed by 5 containers:

- `nginx`, acting as the webserver.
- `php`, the PHP-FPM container with the 7.4 PHPversion.
- `db` which is the PostgreSQL database container with a **PostgreSQL 13** image.
- `web` the Odoo container with the 13 Odoo version.
- `certbot` generates the SSL certificate for your personal domain.

## 🚨 Warning 🚨

We are using Symfony for the webservice, and Symfony works better with IDs (if we talk about using Doctrine ORM, more), so we will need to adjust the tables of our database in order to add an ID automatically. This is an installation, so that info it is not given here.

## Installation ⌨

![Docker Installation Illustration](https://user-images.githubusercontent.com/57062736/139102730-d6f51d53-ffb3-44bb-be5e-2bdf48d91295.png)

0. You need **Docker** and **Docker-compose** where you are going to launch this so, if you do not have it... click [HERE](https://github.com/Inushin/dockerOdooSymfonySSL#installing-docker-docker-compose-and-composer) or go to the end of this `.md` ^^

1. Clone this rep.

2. Check that the dir. `data/certbot/www/.well-known` exist. If it is not, create it 😀.

3. Edit `initOdooSSL` with your ODOO domain and an email.

4. Edit the `docker-compose.yml` with your DB information.

5. Edit `data/nginx/web.conf` with your ODOO domain.

6. Run `./initOdooSSL`.

7. Edit `initSymfonySSL` with your Symfony domain and an email.

8. Edit `data/nginx/web.conf` with your SYMFONY domain.

9. Run `./initSymfonySSL`.

10. Edit `data/nginx/web.conf` and uncomment the HTTPS config.

11. Generate your Symfony proyect going to the php container `docker-compose exec php bash`. Then, go to symfony folder, `/var/www/certbot/phpDir/symfony`, and run `composer create-project symfony/skeleton NAME_OF_THE_PROJECT`. If you need to install **Composer** click [HERE](https://github.com/Inushin/dockerOdooSymfonySSL#installing-docker-docker-compose-and-composer) or go to the end of this `.md` ^^

12. Edit `data/nginx/web.conf` with your domain and your project dir.

13. Run `docker-compose down`

14. Run `docker-compose up -d`

15. The 5 containers are deployed:

```yaml
Creating docker_db_1 ... done
Creating docker_web_1 ... done
Creating docker_php_1 ... done
Creating docker_nginx_1 ... done
Creating docker-certbot-1 ... done
```

🚨 If you have the folling error `Connection matched pg_hba.conf line 99: "host all all all md5"`, go to `/var/lib/docker/volumes/dockerOdooSymfonySSL/_data/pg_hba.conf` and edit last line to `"host all all all trust"`

16. Remember to edit the `env` file at the root of the Symfony's project. `db` is the name of the container that has your database:

```yaml
DATABASE_URL=postgresql://postgresql_db_user_name:postgresql_db_user_pass@db:5432/db_odoo_name?serverVersion=13&charset=utf8
```

## Docker's useful commands 📑
![Docker Commands Illustration](https://user-images.githubusercontent.com/57062736/139102966-25f28be1-f768-49bd-a8a1-915a8465de9e.png)

- Run Docker-compose: `docker-compose up -d` / `docker-compose up`

- Check Docker-compose's volumens status: `docker-compose ps -a` / `docker-compose ps`

- Check Docker's images: `docker images -a`

- Remove Docker's images: `docker rmi -f imageID1 imageID2 ...` (-f = force)

- Enter to a Docker's volumen: `docker-compose exec VolumenID sh` / `docker-compose exec VolumenID bash`

- Copy a file to the docker we want to: `docker cp file docker_id:/dir`

- Remove all dangling (not tagged or associated with a container) containers, volumes, networks and images: `docker system prune`

- Remove all unused containers and images with at least one container associated to them: `docker system prune -a`

- Shows all unused local images: `docker images ls -f dangling=true`

- Shows all unused local volumes: `docker volume ls -f dangling=true`

- Remove all local volumes not used by at least one container: `docker volume prune`

## Installing Docker, Docker-compose and Composer 🛠
![Docker-composer](https://user-images.githubusercontent.com/57062736/141182130-b8ed2d7a-9a68-4387-b838-ba0d44bb4e0e.png)

**Adjust the installation to your OS. Here you have the one for EC2(AWS) with CentOS**

- Docker installation

1. Download and install Docker: `yum install docker`

2. Gives permisions so you can run it everywhere: `usermod -a -G docker ec2-user`

3. Starts Docker's service: `service docker start`

4. Starts Docker's service each time you run the SO: `chkconfig docker on`

- Docker-compose installation

1. Download and install Docker-compose: `curl -L "https://github.com/docker/compose/releases/download/1.26.2/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose`

2. Make it executable from anywhere: `chmod +x /usr/local/bin/docker-compose`

3. Makes an direct access for docker-compose: `ln -s /usr/local/bin/docker-compose /usr/bin/docker-compose`

4. Check the version and the installation: `docker-compose --version`

- Composer installation

1. Download and install Composer: `curl -sS https://getcomposer.org/installer | php`

2. Moves the config file to the composer dir: `mv composer.phar /usr/local/bin/composer`

3. Makes an direct access of `composer.phar` file: `ln -s /usr/local/bin/composer /usr/bin/composer`

## ⭐ Feedback and bugs 🐞

If you find any bug or just want to give your feedback (remember the ⭐ ^^), **Feel free to do it**. I am, like you, constantly learning and things change so quickly that... no one knows ^^

## Version control 📝

- 1.0 - Creation of the rep with the config finished - 27/01/2022
- 1.1 - Added pdo pdo_pgsql pgsql to the PHP Dockerfile - 28/01/2022
- 1.2 - Updated useful Docker commands - 10/02/2022
- 2.1 - Added the OdooDB initialitation command to the docker-compose.yml - 10/04/2022
- [v2.2 - Current](https://github.com/Inushin/dockerOdooSymfonySSL/tree/v2.2) - Remove unneeded files and folders - 03/12/2022