Skip to content

ng-ife/odoo-deployment

Repository files navigation

Odoo development deployment

This Repo contains a helperscript deploy to setup a new local odoo instance easily. This is only testet on windows with wsl but should work on plain linux too. Of course requirements differ then.

Default values

  • Odoo Master Password: odoo
  • DB User: odoo Password: odoo

Requirements

There are some submodules (other addons) that you may not have access to. You can easily adapt the templates in the templates folder to your needs.

On windows we need

  • Windwows Subsystem for Linux (aka. wsl2)
  • Ubuntu
  • Docker Desktop
  • installed root certifivate from mkcert (see below)

WSL and Ubuntu can be installed from Microsoft Store, Docker Desktop can be downloaded from here. If you star Docker Desktop for the first time make sure to share Settings -> Resources -> WSL integration with Ubuntu.

In Ubuntu we need

  • mkcert
  • docker.io
  • docker-compose

All packages can be installed from package management

sudo apt install mkcert docker.io docker-compose

After installing mkcert, we need to generate a root-certificate for our upcomming docker deployments. This can be done by mkcert -install. Afterwards the root-certificate must be importet to your windows or firefox. Run mkcert -CAROOT to find the folder where the certificates are.

Now on Windows search for "User certificates" (german Benutzerzertifikate), and right-click on Certificate Authority -> Tasks -> Import (german Vertrauenswürdige Stammzertifikate -> Alle Aufgeben -> Importieren).

For Firefox you can find the import option in Settings -> Privacy -> Certificates.

Go back to your Ubuntu and clone this repo into a separate folder.

git clone git@github.com:ng-ife/odoo-deployment.git 

For nginx to work, we first create a shared network.

docker network create nginx-net

Now everything should be ready to deploy.

How to deploy a new odoo instance

Simply go to your deployment folder (in my case docker) and create an new instance.

➜  cd docker
➜  ./deploy create odoo16ee test

If everything went well, you can now go back to your Browser and enjoy http://test.odoo

For the hostname to be pointing to localhost you could either put the name of the deployment into your local dns or manipulate the /mnt/c/Windows/System32/drivers/etc/hosts (/etc/hosts on linux). You need admin rights for that. Just open notepad with rightclick from the start menu to do so.

Explanation

deploy has to modes: create and remove

create requires two arguments: deployment template and deployment name deployment templates can be found in the tempaltes folder and are simply docker compose setups. On creation they get copyied to deployment folder and a new nginx file is created for resolving and certificates. Next to odoo, there is a mailcatcher with a webinterface on Port 8025. From odoo, use mailhog as SMTP Server and Port 1025. custom modules go into the following directory: ./deployments/[deploymentname]/extra-addons

remove takes only one arguemnt: the deployment. As the name sugests it removes the deployment. Kepp in mind that it doesn't remove the volumes (where the data is stored). So if you delete a deployment and create a new one by the same name you're old databases and filestore are back. You can delete them in Docker Desktop in the Volume tab.

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages