Odoo role

Deploy Odoo Docker container.

Usage

Configure the role.

vars.yml

odoo_image: odoo:14
odoo_hostname: odoo01
odoo_replicas: 3 # default: 1
odoo_description: Odoo14 # default: Odoo
odoo_state: stopped # default: started
odoo_ports:
 - "8069:8069" # default: "127.0.0.1:8069:8069"
odoo_data_dir: /usr/share/odoo # default: "/usr/share/{{ odoo_hostname }}"
odoo_volume_name: odoo_data01 # default: "{{ odoo_hostname}}"
odoo_timezone: Europe/Paris # default: Europe/Berlin
odoo_postgres_hostname: postgres01
odoo_postgres_user: example # default: odoo
odoo_postgres_password: # default: "{{ vault_postgres_password }}"
odoo_master_password: # default: "{{ vault_odoo_master_password }}"
odoo_conf_limit_request: 4096 # default: 8192
odoo_conf_limit_time_cpu: 300 # default: 600
odoo_conf_limit_time_real: 600 # default: 1200
odoo_conf: | # default: proxy_mode = True
  proxy_mode = True
  workers = 2
odoo_backup_set: # See restic_backup_set var in role restic_client

And include it in your playbook.

- hosts: odoo
  roles:
  - role: odoo

Docs

Configure workers

If Odoo should make use of workers workers = x>0 then this proxy config must be applied:

nginx_proxies:
  - src_hostname: odoo.example.com
    dest_hostname: odoo01
    dest_port: 8069
    options: |
      location /longpolling {
        proxy_pass http://odoo01:8072;
        include /etc/letsencrypt/proxy-params.conf;
      }

Once workers are active the longpolling port moves from 8069 to 8072 and therefore a redirect is required.