无法在dockers中通过节点应用程序连接到redis

时间:2018-06-06 22:02:56

标签: node.js docker redis docker-compose ioredis

我正在尝试将我的应用程序连接到redis,但我得到了:

[ioredis] Unhandled error event: Error: connect ECONNREFUSED 127.0.0.1:6379

当我这样做时:

docker exec -it ed02b7e19810 ping test_redis_1 我收到了所有的数据包。

redis容器也声明:

* Running mode=standalone, port=6379

* Ready to accept connections

(我得到警告,但我认为不相关:

Warning: no config file specified, using the default config. In order to specify a config file use redis-server /path/to/redis.conf

WARNING: The TCP backlog setting of 511 cannot be enforced because /proc/sys/net/core/somaxconn is set to the lower value of 128

这是我的docker-compose.yaml:

version: '3'

services:
  test-service:
      build: .
      volumes:
        - ./:/usr/test-service/
      ports:
        - 5001:3000
      depends_on:
        - redis
  redis:
    image: "redis:alpine"

DockerFile

 FROM node:8.11.2-alpine

 WORKDIR /usr/test-service/

 COPY . /usr/test-service/

 RUN yarn install

 EXPOSE 3000

 CMD ["yarn", "run", "start"]

app.js

const Redis = require('ioredis');
const redis = new Redis();

redis.set('foo', 'bar');
redis.get('foo').then(function (result) {
    console.log(result);
});

我也尝试使用redis包,但仍然无法连接:

 var redis = require("redis"),
     client = redis.createClient();

 client.on("error", function (err) {
     console.log("Error " + err);
 });

得到:

 Error Error: Redis connection to 127.0.0.1:6379 failed - connect ECONNREFUSED 127.0.0.1:6379

1 个答案:

答案 0 :(得分:4)

对于特定的docker-compose.ymlredis上没有127.0.0.1,您应该使用redis作为主机,因为同一个Docker网络上的服务能够找到对方使用服务名称作为DNS。

const Redis = require('ioredis');
const redis = new Redis({ host: 'redis' });

此外,depends_on不会等待redis容器在启动之前准备就绪,它只会先启动它,所以在开始app.js之前要等待或只是处理它是你的工作在app.js

io-redis附带reconnection策略,因此您可能需要先尝试。

您可以在此处查看我的答案:

Wait node.js until Logstash is ready using containers