连接容器的Docker网络错误

时间:2020-08-13 17:59:25

标签: docker docker-compose

我无法集中精力配置如何配置我认为是Docker中非常基本的网络设置。

容器:

  • Wordpress
  • MariaDB
  • Node.js

我已经启动并运行了Wordpress和MariaDB容器,并且彼此聊天,但是由于某种原因,我的Node.js容器无法执行对Wordpress服务器的基本HTTP调用。我立即从Node脚本收到一个Error: connect ECONNREFUSED 192.168.128.4:3000错误。

我正在Mac OS v2.3.0.3上运行Docker Desktop Community。

我的docker-compose.yml文件如下:

services:

  db:
    image: mariadb:10.5.4-focal
    container_name: db
    volumes:
      - ./cms/conf/mysql/data:/var/lib/mysql
      - ./cms/sql:/docker-entrypoint-initdb.d
    environment:
      - MYSQL_ROOT_PASSWORD=******
      - MYSQL_USER=******
      - MYSQL_PASSWORD=******
      - MYSQL_DATABASE=wordpress
    restart: always

  cms.mysite.local:
    container_name: cms.mysite.local
    build:
      context: ./cms
    image: mysite/cms:5.4.2
    ports:
      - '3000:80'
    volumes:
      - ./cms/conf/php/uploads.ini:/usr/local/etc/php/conf.d/uploads.ini
      - ./cms/conf/nginx:/etc/nginx/conf.d
      - ./cms/logs/nginx:/var/log/nginx
      - ./cms/app/public:/var/www/html
    environment:
      - WORDPRESS_DB_NAME=wordpress
      - WORDPRESS_TABLE_PREFIX=wp_
      - WORDPRESS_DB_HOST=db
      - WORDPRESS_DB_USER=root
      - WORDPRESS_DB_PASSWORD=password
    depends_on:
      - db
    restart: always

  node:
    container_name: node
    build:
      context: ./www
    image: mysite/gatsby:2.23.12
    user: 'node'
    working_dir: /home/node/www
    volumes:
      - ./www:/home/node/www
      - /home/node/www/node_modules
    ports:
      - '8000:8000'
    depends_on:
      - cms.mysite.local
    restart: "always"

cms.mysite.local容器具有在3000中指定的开放端口。我修改了本地Mac OS计算机的/etc/hosts文件以添加一个127.0.0.1 cms.mysite.local条目,然后能够在浏览器中访问Wordpress站点并获得有效的响应。这样看来一切都在这里工作。

然后在node容器中设置了以下脚本:

const axios = require('axios')
const url = 'http://cms.mysite.local:80'
console.log('URL=' + url)
axios.get(url).then( (response) => {
  console.log('response=' + JSON.stringify(response.data))
})
.catch(function (error) {
  console.log('error=' + error)
})

我已将此脚本设置为在容器启动时执行。每次运行时,都会出现错误:Error: connect ECONNREFUSED 192.168.128.4:3000。当然,当我尝试在MacOS浏览器中手动访问192.168.128.4:3000时,确实没有任何连接。

为什么Node.js脚本试图访问http://192.168.128.4:3000而不是我的书面http://cms.mysite.local:3000/ URL?

如何强制其使用正确映射到Wordpress Docker容器的URL?或者如何设置URL,以便我的node容器可以对我的cms.mysite.local容器进行HTTP调用?

[编辑#1]我还尝试过更新Node.js脚本以调出http://cms.mysite.local:80/。我添加了一些日志记录,以使输出更加清晰。

> node ./test.js
URL=http://cms.mysite.local:80
error=Error: connect ECONNREFUSED 192.168.128.4:80

[编辑2:Ur。我没有适当地停止并重建我的docker映像进行编辑。重新启动后,我确实看到了正在使用的适当端口。 #1]

[解决:感谢Fernando和Shizzen83的端口标注!] 这就是正在发生的事情。我将Wordpress站点配置为端口3000,以便可以通过浏览器在该端口上访问它。但是我有一个nginx配置在Docker内部的端口80上为站点服务。由于内部Docker端口与外部Wordpress端口不匹配,因此Wordpress在端口80请求上向端口3000发出了301重定向。我切换了nginx来直接侦听端口3000,并更新了docker-compose文件以映射3000:3000而不是3000:80。现在,一切都整齐了。谢谢大家!

2 个答案:

答案 0 :(得分:3)

似乎是您要暴露的cms.mysite.local的端口

ports:
  - 3000:80

这意味着此容器已映射到端口3000到外部(您的主机),但在docker网络内部,该容器仍具有80用于传入连接。

对于您的node容器,必须类似

axios.get('http://cms.mysite.local:80').then( (response) => {
  console.log('response=' + response.data)
})
.catch(function (error) {
 // handle error
console.log('error=' + error);
})

node会向您显示IP,因为他正在解析docker网络中您wordpress容器的DNS

答案 1 :(得分:1)

您的错误来自Node用来访问Wordpress的端口。当您在容器的3000:80部分中设置ports时,这意味着发送到端口3000上的主机的查询将被重定向到Wordpress容器的内部端口80。尽管您的Node容器不是主机,所以您必须直接访问端口80。