Docker Gatsby Strapi 产生 ECONNREFUSED 127.0.0.1:1337 错误

TGM*_*MNF 7 docker docker-compose strapi gatsby

我一直通过命令行与 Strapi 和 Gatsby 合作来启动并运行网站和 CMS,类似于此设置 - https://strapi.io/blog/building-a-static-website-using-gatsby-和-strapi。一切顺利,我已准备好进入下一步并将项目放入 Docker 中进行部署。

在 Docker 中启动并运行 Strapi 和 Mongo DB 实例非常简单,与此设置几乎相同 - https://strapi.io/documentation/3.0.0-beta.x/installation/docker.html

当我尝试将 Gatsby 安装到 Docker 中时出现问题。我在 docker-compose.yml 和 Dockerfile 中尝试了大量不同的配置设置,但我不断遇到以下错误

错误 #11321 插件

“gatsby-source-strapi”在运行 sourceNodes 生命周期时抛出错误:connect ECONNREFUSED 127.0.0.1:1337

错误:连接ECONNREFUSED 127.0.0.1:1337

Strapi 和 Mongo 服务在同一个 docker-compose.yml 文件中运行良好,如下所示

version: "3"
services:
  strapi:
    image: strapi/strapi
    environment:
      DATABASE_CLIENT: mongo
      DATABASE_NAME: strapi
      DATABASE_HOST: mongo
      DATABASE_PORT: 27017
      DATABASE_USERNAME: strapi
      DATABASE_PASSWORD: strapi
    links:
      - mongo:mongo
    volumes:
      - ./cms:/srv/cms
    ports:
      - "1337:1337"

  mongo:
    image: mongo
    environment:
      MONGO_INITDB_ROOT_USERNAME: strapi
      MONGO_INITDB_ROOT_PASSWORD: strapi
    volumes:
      - ./db/db:/db/db
    ports:
      - "27017:27017"

  gatsby:
    image: docker-gatsby-client
    build: ./website
    command: gatsby develop -H 0.0.0.0
    volumes:
      - ./website:/usr/src/app/website
      - /usr/src/app/website/node_modules
    ports:
      - "8000:8000"
    depends_on:
      - strapi
      - mongo
    environment:
      GATSBY_WEBPACK_PUBLICPATH: /
      STRAPI_URL: strapi:1337
Run Code Online (Sandbox Code Playgroud)

我的 Dockerfile 看起来像这样

FROM node:12

WORKDIR /usr/src/app/website

COPY package*.json ./

RUN npm install

RUN npm install -g gatsby-cli

RUN npm install --save gatsby-source-strapi

COPY . .

EXPOSE 8000

CMD ["yarn", "develop", "-H", "0.0.0.0" ]
Run Code Online (Sandbox Code Playgroud)

我在 compose 文件中尝试了很多不同的设置,例如不使用卷,以及 Dockerfile,例如使用不同的节点版本。它们都不起作用,并且都返回上面相同的错误。

如果我从命令行运行 Gatsby 服务,它会从 Docker 容器连接到 Strapi 服务,一切都很好。这让我觉得 Docker 中的 Gatsby 服务有一个设置不正确,导致了连接错误。

有人有主意吗?

TGM*_*MNF 9

在查看了 Gatsby 容器的日志后,我用一个简单的 Hello World 实例替换了已完成的网站,这样我就可以将其从列表或潜在障碍中删除。盖茨比继续成功旋转。

更改 gatsby-config.js 文件中的某些内容以包含与 api 相关的数据会导致返回连接错误。将文件中的 apiURL 值从http://localhost:1337更改为http://0.0.0.0:1337不会改变任何内容。

在 Mac 上搜索跨容器连接问题找到了一条线索,最终为我工作。

这个问题 - https://github.com/docker/for-mac/issues/2705 - 是关键。将 apiURL 值更改为http://docker.for.mac.localhost:1337允许 API 在 Strapi 和 Gatsby 之间进行连接。我对这个价值不太满意,因为一些同事使用电脑,所以这看起来不太合适。进一步挖掘发现了有效的http://host.docker.internal:1337的 apiURL 值。我将在生产构建上与开发构建进行比较,测试所有这些内容,看看它们的表现如何。