2

所以我正在编写一个节点应用程序,我的 docker-compose.yml 看起来像:

version: '2'
services:
  redis:
    image: "redis:latest"
  web:
    build: .
    ports:
     - "3000:3000"
    volumes:
     - .:/app
    links:
     - redis
  emailworker:
    build: .
    env_file:
      - ./.env
    command: node ./lib/workers/email.js
    volumes:
      - .:/app
    links:
      - redis
  smsworker:
    build: .
    env_file:
      - ./.env
    command: node ./lib/workers/sms.js
    volumes:
      - .:/app
    links:
      - redis

非常简单,一个网络服务器和两个处理电子邮件和短信工作的工作人员。一切都很好,直到今天下午,似乎什么都没有改变,但是当我的应用程序启动时,我无法再连接到 redis 容器。docker-compose up尝试使用kuenode 模块连接到 redis 时,我运行并收到以下错误:

Error: Redis connection to 127.0.0.1:6379 failed - connect ECONNREFUSED 127.0.0.1:6379
at Object.exports._errnoException (util.js:1022:11)
at exports._exceptionWithHostPort (util.js:1045:20)
at TCPConnectWrap.afterConnect [as oncomplete] (net.js:1087:14)

kue与 redis 的连接如下所示:

const kue = require('kue'),
  queue = kue.createQueue({
    root: __dirname,
    redis: {
      host: 'redis',
      port: 6379
    }
  });

queue.on('error', err => {
  console.log('QUEUE ERROR: ', err);
});

有什么想法我在这里出错了吗?我昨晚刚设置好,电子邮件就被愉快地发送了,就像我提到的,唯一会改变的是网络服务中的应用程序代码。如果这有所不同,我正在 Mac 上开发,并且拥有最新版本的 docker 和 docker-compose。docker ps做了一个节目docker-compose up后:

CONTAINER ID        IMAGE                COMMAND                  CREATED              STATUS              PORTS                    NAMES
3af92333ad53        expapi_web           "yarn docker"            About a minute ago   Up About a minute   0.0.0.0:3000->3000/tcp   expapi_web_1
d26f1d81ad22        expapi_emailworker   "node ./lib/workers/e"   About a minute ago   Up About a minute   3000/tcp                 expapi_emailworker_1
1695ec819777        expapi_smsworker     "node ./lib/workers/s"   About a minute ago   Up About a minute   3000/tcp                 expapi_smsworker_1
5cb6701f3586        redis:latest         "docker-entrypoint.sh"   About a minute ago   Up About a minute   6379/tcp                 expapi_redis_1
4

0 回答 0