使用Traefik代理而不是Nginx的Odoo

使用Traefik代理而不是Nginx的Odoo,nginx,proxy,odoo,traefik,Nginx,Proxy,Odoo,Traefik,我已经成功地将Traefik用于几个容器化应用程序,我对使用LetsEncrypt的本机SSL支持感到满意(非常感谢Traefik团队)。但是,具体来说,要运行Odoo(开源ERP/CRM),我在后端以及通过javascript日志在浏览器中遇到了一个异常: 异常:bus.bus不可用+此处调用堆栈不重要。显然,此异常的根本原因是,当odoo.conf文件中的参数workers>1时,Traefik没有代理到达URL的请求/longpolling Odoo服务器公开两个不同的端口: 8069:

我已经成功地将Traefik用于几个容器化应用程序,我对使用LetsEncrypt的本机SSL支持感到满意(非常感谢Traefik团队)。但是,具体来说,要运行Odoo(开源ERP/CRM),我在后端以及通过javascript日志在浏览器中遇到了一个异常:
异常:bus.bus不可用
+此处调用堆栈不重要。显然,此异常的根本原因是,当odoo.conf文件中的参数
workers>1
时,Traefik没有代理到达URL的请求
/longpolling

Odoo服务器公开两个不同的端口:

  • 8069:对webapp的正常请求
  • 7082:由聊天服务在
    /longpolling
我解释了如何复制这个“bug”(我不知道它是bug还是我不知道如何正确使用它)

作为参考,我还添加了一个不使用SSL的文件(只是为了简单起见)

这是我的
docker compose.yml
用于运行Odoo+Traefik:

version: "2.3"
networks:
  web:
    external: true

services:
  traefik:
    image: "traefik:v2.4"
    container_name: "traefik"
    env_file: .env
    environment:
      - UID=2000
      - GID=2000
    ports:
      - "80:80"
      - "443:443"
    command:
      - --api.insecure=true
      - --api.dashboard=true
      - --api.debug=true
      - --log=true
      - --log.level=INFO
      - --providers.docker=true
      - --providers.docker.exposedbydefault=false
      - --providers.file.filename=/dynamic.yml
      - --providers.docker.network=web
      - --entrypoints.http.address=:80
      - --entrypoints.https.address=:443
      - --certificatesresolvers.le.acme.httpchallenge=true
      - --certificatesresolvers.le.acme.httpchallenge.entrypoint=http
      - --certificatesresolvers.le.acme.email=${LETS_ENCRYPT_CONTACT_EMAIL}
      - --certificatesresolvers.le.acme.storage=/letsencrypt/acme.json
    networks:
      - web
    volumes:
      - "${BASE_VOLUME_DIR}/traefik/conf/letsencrypt:/letsencrypt"
      - "${BASE_VOLUME_DIR}/traefik/conf/dynamic.yml:/dynamic.yml"
      - "/var/run/docker.sock:/var/run/docker.sock:ro"
    labels:  
      - traefik.enable=true
      - traefik.http.routers.traefik-http.rule=Host(`${TRAEFIK_HOSTNAME}`)
      - traefik.http.routers.traefik-http.entrypoints=http
      - traefik.http.routers.traefik-http.service=traefik
      - traefik.http.routers.traefik-http.middlewares=redirect@file
      - traefik.http.routers.traefik-https.rule=Host(`${TRAEFIK_HOSTNAME}`)
      - traefik.http.routers.traefik-https.entrypoints=https
      - traefik.http.routers.traefik-https.tls=true
      - traefik.http.routers.traefik-https.tls.options=default
      - traefik.http.routers.traefik-https.service=traefik
      - traefik.http.routers.traefik-https.tls.certresolver=le
      - traefik.http.services.traefik.loadbalancer.server.port=8080
      - traefik.http.routers.traefik-https.middlewares=gzip
      - traefik.http.middlewares.gzip.compress=true

  odoo:
    image: registry.wisecoding.io/docker/odoo:11.0
    container_name: odoo
    networks:
      - web
    env_file: .env
    ports:
      - "8069:8069"
      - "8072:8072"
    volumes:
      - "${BASE_VOLUME_DIR}/odoo/extra-addons:/opt/odoo/extra-addons"
      - "${BASE_VOLUME_DIR}/odoo/data:/opt/odoo/data"
      - "${BASE_VOLUME_DIR}/odoo/logs:/opt/odoo/logs"
      - "${BASE_VOLUME_DIR}/odoo/conf:/opt/odoo/conf"
    ulimits:
      nofile:
        soft: 65536
        hard: 65536
    labels:
      - traefik.enable=true
      - traefik.http.routers.odoo-http.rule=Host(`${ODOO_HOSTNAME}`)
      - traefik.http.routers.odoo-http.entrypoints=http
      - traefik.http.routers.odoo-http.service=odoo-http
      - traefik.http.services.odoo-http.loadbalancer.server.port=8069
      - traefik.http.routers.odoo-http.middlewares=redirect@file
      - traefik.http.routers.odoo-https.rule=Host(`${ODOO_HOSTNAME}`)
      - traefik.http.routers.odoo-https.entrypoints=https
      - traefik.http.routers.odoo-https.service=odoo-https
      - traefik.http.routers.odoo-https.tls.certresolver=le
      - traefik.http.routers.odoo-https.middlewares=gzip
      - traefik.http.services.odoo-https.loadbalancer.server.port=8069

       #====> On the next line was my mistake. It was typo as pointed out by @Veikko
      - traefik.http.routers.odoo-im-https.rule=Host(`${ODOO_HOSTNAME}`) && (PathPrefix(`/longpooling`))
      - traefik.http.routers.odoo-im-https.entrypoints=https
      - traefik.http.routers.odoo-im-https.service=odoo-im-https
      - traefik.http.routers.odoo-im-https.tls.certresolver=le
      - traefik.http.routers.odoo-im-https.middlewares=gzip,sslheader
      - traefik.http.services.odoo-im-https.loadbalancer.server.port=8072

      # middlewares
      - traefik.http.middlewares.gzip.compress=true
      - traefik.http.middlewares.sslheader.headers.customrequestheaders.X-Forwarded-Proto=https
我找到的最接近的解决方案是在Traefik论坛上,建议包括下面的一行(我尝试过,但仍然没有成功):
traefik.http.middleware.sslheader.headers.customrequestheaders.X-Forwarded-Proto=https

我可能错过了什么,但我想不出来


想法?

正确的Odoo url路径是
/longpolling
。检查您的Traefik和Odoo配置是否使用
longpolling
,而不是
longpooling
,例如Traefik的Odoo容器标签…
PathPrefix('/longpooling')“
->…
PathPrefix('/longpolling')”
谢谢@Veikko,问题是打字错误。修好后一切都好:-)