- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
使用 vagrant 1.6.5 和 virtual box 运行 windows 7。我有两个码头容器;- Node - 雷迪斯
我的部分解决方案正在运行并正常工作!当我在 VM 外部运行 nodejs 应用程序时,它可以连接到端口 6379 上的 redis 容器。当我在 nodejs docker 容器内运行相同的应用程序时,出现以下异常:
Redis connection to 127.0.0.1:6379 failed - connect ECONNREFUSED
我可以通过停止 redis 容器在外部项目上复制异常,因此问题看起来与容器如何链接/绑定(bind)到 VM 上的内部端口有关。
容器启动如下;
$ docker run -d -p 6379:6379 --name redis myproject/redis
$ docker run --rm -it -P -p 9090:9090 --name node --link redis:rs myproject/node
第二个命令允许我运行和删除图像,以便我可以验证和调试问题。据我了解,容器之间的联系是正确的!
我想删除主机端口 6379,这样您就只能访问 9090 端口,这将公开 Redis 功能。
示例 nodejs dockerfile;
# DOCKER-VERSION 0.10.0
FROM ubuntu
RUN env
# make sure apt is up to date
RUN apt-get update
# install nodejs and npm
RUN apt-get install -y nodejs npm git git-core
RUN PATH=/usr/bin/node:$PATH
# Bundle app source
ADD src /opt/app/
# use changes to package.json to force Docker not to use the cache
# when we change our application's nodejs dependencies:
ADD src/package.json /tmp/package.json
RUN cd /tmp && npm install
RUN mkdir -p /opt/app && cp -a /tmp/node_modules /opt/app/
RUN cp -a /tmp/node_modules /opt/app/redis
EXPOSE 9090
CMD ["nodejs", "/opt/app/redis/server.js"]`
Any help is appreciated.
示例 Redis dockerfile
# Pull base image.
FROM dockerfile/ubuntu
# Install Redis.
RUN \
cd /tmp && \
wget http://download.redis.io/redis-stable.tar.gz && \
tar xvzf redis-stable.tar.gz && \
cd redis-stable && \
make && \
make install && \
cp -f src/redis-sentinel /usr/local/bin && \
mkdir -p /etc/redis && \
cp -f *.conf /etc/redis && \
rm -rf /tmp/redis-stable* && \
sed -i 's/^\(bind .*\)$/# \1/' /etc/redis/redis.conf && \
sed -i 's/^\(daemonize .*\)$/# \1/' /etc/redis/redis.conf && \
sed -i 's/^\(dir .*\)$/# \1\ndir \/data/' /etc/redis/redis.conf && \
sed -i 's/^\(logfile .*\)$/# \1/' /etc/redis/redis.conf
# Define mountable directories.
VOLUME ["/data"]
# Define working directory.
WORKDIR /data
# Define default command.
ENTRYPOINT ["redis-server"]
# Define default command.
#CMD ["redis-server", "/etc/redis/redis.conf"]
# Expose ports locally on VM
EXPOSE 6379
J
最佳答案
找到解决方案!!!
我用以下内容更新了我的 JS 文件;
var redisHost = process.env.REDIS_PORT_6379_TCP_ADDR;
var redisPort = process.env.REDIS_PORT_6379_TCP_PORT;
console.log('Settings ' + redisHost + ' ' + redisPort);
var http = require("http"), server, redis_client = require("redis").createClient(redisPort, redisHost);
这些环境变量是根据链接容器时使用的别名配置的,即运行以下命令;
docker run --rm -it -P -p 9090:9090 --name node --link redis:redis sapvagrant/node env
将产生以下输出;
TERM=xterm
REDIS_PORT=tcp://172.17.0.38:6379
REDIS_PORT_6379_TCP=tcp://172.17.0.38:6379
REDIS_PORT_6379_TCP_ADDR=172.17.0.38
REDIS_PORT_6379_TCP_PORT=6379
REDIS_PORT_6379_TCP_PROTO=tcp
REDIS_NAME=/node/redis
HOME=/root
这里重要的是链接 redis:redis 中使用的别名,如果我将其重命名为 redis:rs 那么环境将是;
RS_PORT=tcp://172.17.0.38:6379
RS_PORT_6379_TCP=tcp://172.17.0.38:6379
RS_PORT_6379_TCP_ADDR=172.17.0.38
RS_PORT_6379_TCP_PORT=6379
RS_PORT_6379_TCP_PROTO=tcp
RS_NAME=/node/redis
现在,当我运行容器时,nodejs 能够绑定(bind)到 Redis 数据库,并且我能够公开端口 9090,这将显示一些数据库功能,但端口 6379 未公开。
示例项目位于; https://github.com/longieirl/docker-redis-nodejs
快乐的日子。
J
关于windows - 将 Redis DB docker 容器暴露给 NodeJS docker 容器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26787241/
我有一个关于 Redis Pubsub 的练习,如下所示: 如果发布者发布消息但订阅者没有收到服务器崩溃。订阅者如何在重启服务器时收到该消息? 请帮帮我,谢谢! 最佳答案 在这种情况下,消息将永远消失
我们正在使用 Service Stack 的 RedisClient 的 BlockingDequeue 来保存一些数据,直到它可以被处理。调用代码看起来像 using (var client =
我有一个 Redis 服务器和多个 Redis 客户端。每个 Redis 客户端都是一个 WebSocket+HTTP 服务器,其中包括管理 WebSocket 连接。这些 WebSocket+HTT
我有多个 Redis 实例。我使用不同的端口创建了一个集群。现在我想将数据从预先存在的 redis 实例传输到集群。我知道如何将数据从一个实例传输到集群,但是当实例多于一个时,我无法做到这一点。 最佳
配置:三个redis集群分区,跨三组一主一从。当 Master 宕机时,Lettuce 会立即检测到中断并开始重试。但是,Lettuce 没有检测到关联的 slave 已经将自己提升为 master
我想根据从指定集合中检索这些键来删除 Redis 键(及其数据集),例如: HMSET id:1 password 123 category milk HMSET id:2 password 456
我正在编写一个机器人(其中包含要禁用的命令列表),用于监视 Redis。它通过执行禁用命令,例如 (rename-command ZADD "")当我重新启动我的机器人时,如果要禁用的命令列表发生变化
我的任务是为大量听众使用发布/订阅。这是来自 docs 的订阅的简化示例: r = redis.StrictRedis(...) p = r.pubsub() p.subscribe('my-firs
我一直在阅读有关使用 Redis 哨兵进行故障转移的内容。我打算有1个master+1个slave,如果master宕机超过1分钟,就把slave变成master。我知道这在 Sentinel 中是
与仅使用常规 Redis 和创建分片相比,使用 Redis 集群有哪些优势? 在我看来,Redis Cluster 更注重数据安全(让主从架构解决故障)。 最佳答案 我认为当您需要在不丢失任何数据的情
由于 Redis 以被动和主动方式使 key 过期, 有没有办法得到一个 key ,即使它的过期时间已过 (但 在 Redis 中仍然存在 )? 最佳答案 DEBUG OBJECT myKey 将返回
我想用redis lua来实现monitor命令,而不是redis-cli monitor。但我不知道怎么办。 redis.call('monitor') 不起作用。 最佳答案 您不能从 Redis
我读过 https://github.com/redisson/redisson 我发现有几个 Redis 复制设置(包括对 AWS ElastiCache 和 Azure Redis 缓存的支持)
Microsoft.AspNet.SignalR.Redis 和 StackExchange.Redis.Extensions.Core 在同一个项目中使用。前者需要StackExchange.Red
1. 认识 Redis Redis(Remote Dictionary Server)远程词典服务器,是一个基于内存的键值对型 NoSQL 数据库。 特征: 键值(key-value)型,value
1. Redis 数据结构介绍 Redis 是一个 key-value 的数据库,key 一般是 String 类型,但 value 类型多种多样,下面就举了几个例子: value 类型 示例 Str
1. 什么是缓存 缓存(Cache) 就是数据交换的缓冲区,是存贮数据的临时地方,一般读写性能较高。 缓存的作用: 降低后端负载 提高读写效率,降低响应时间 缓存的成本: 数据一致性成本 代码维护成本
我有一份记录 list 。对于我的每条记录,我都需要进行一些繁重的计算,因为我要在Redis中创建反向索引。为了达到到达记录,需要在管道中执行多个redis命令(sadd为100 s + set为1
我有一个三节点Redis和3节点哨兵,一切正常,所有主服务器和从属服务器都经过验证,并且哨兵配置文件已与所有Redis和哨兵节点一起更新,但是问题是当Redis主服务器关闭并且哨兵希望选举失败者时再次
我正在尝试计算Redis中存储的消息之间的响应时间。但是我不知道该怎么做。 首先,我必须像这样存储chat_messages的时间流 ZADD conversation:CONVERSATION_ID
我是一名优秀的程序员,十分优秀!