首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Odoo使用Traefik代理而不是Nginx

Odoo使用Traefik代理而不是Nginx
EN

Stack Overflow用户
提问于 2021-02-11 09:21:43
回答 1查看 1.2K关注 0票数 0

我已经成功地在几个容器化应用程序中使用了Traefik,并且我对使用LetsEncrypt的本地SSL支持感到高兴(非常感谢Traefik团队)。但是,具体来说,为了运行Odoo (开放源码ERP/CRM),我在后端和浏览器中通过javascript日志获得了一个异常:Exception: bus.Bus unavailable +调用堆栈在这里并不重要。显然,这个异常的根本原因是Traefik没有代理当参数/longpolling文件中的参数workers > 1时向URL odoo.conf发出的请求。

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

  • 8069: the应用程序的正常请求
  • 7082:由/longpolling下的聊天服务使用

我制作了一个GitHub仓库来解释如何复制这个" bug“(我不知道它是一个bug还是我不知道如何正确地使用它)。

作为参考,我还添加了一个不使用SSL的nginx.conf文件(只是为了使其简单)。

下面是我用来运行Odoo +Traefik的docker-compose.yml

代码语言:javascript
运行
复制
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.middlewares.sslheader.headers.customrequestheaders.X-Forwarded-Proto = https

我可能漏掉了什么,但我想不出来。

有什么想法?

EN

回答 1

Stack Overflow用户

发布于 2021-02-12 07:52:52

正确的Odoo路径是/longpolling。检查您的Traefik和Odoo配置是否使用longpolling,而不是longpooling,例如Traefik的Odoo容器标签.PathPrefix('/longpooling')" -> .PathPrefix('/longpolling')"

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/66151900

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档