node.js - 无法从我的 Node.js 应用程序连接到 Cassandra Docker 容器

标签 node.js docker cassandra cassandra-3.0

我通过运行以下命令设置 Cassandra 容器:

这将从 docker hub 中提取 cassandra docker 镜像并使用 cassandra 启动一个容器

docker run --name cassandraDb -d --publish-all=true cassandra:3.11

我可以通过运行以下命令来查看它的设置:

docker images
docker ps -a
docker exec -i -t cassandraDb sh -c 'nodetool status'

这是我的 Node.js 路由的代码,当我点击它时,我收到了错误:

res.send(client.connect()
        .then(() => {
            console.log('Connected');
            console.log(Object.keys(client.metadata.keyspaces));
            return client.shutdown();
        })
        /* tslint:disable-next-line */
        .catch((err): any => {
            console.error('There was an error when connecting', err);
            return client.shutdown();
        }));

错误:

There was an error when connecting { [Error: All host(s) tried for query failed. First host tried, 172.17.0.2:9042: Error: Connection timeout. See innerErrors.]
  innerErrors:
   { '172.17.0.2:9042':
      { [Error: Connection timeout]
        message: 'Connection timeout',
        info: 'Cassandra Driver Error' } },
  info: 'Represents an error when a query cannot be performed because no host is available or could be reached by the driver.',
  message: 'All host(s) tried for query failed. First host tried, 172.17.0.2:9042: Error: Connection timeout. See innerErrors.' }

我对 Cassandra 或 Docker 没有太多经验,所以我不确定为什么我的应用程序没有连接到数据库,也许是端口没有对传入请求开放,但我不知道如何我会检查或更改它。

最佳答案

我在这里看到两个问题:

1) documentation说 --publish-all=true|false .. 是一个毯子操作,它通过镜像的 Dockerfile 中的 EXPOSE 行或 --expose 命令行标志来标识每个端口,并将其映射到临时端口范围内某处的主机端口

相反,--publish-all将映射到随机端口,请执行docker run --name cassandraDb -d -p 7199:7199 -p 7000:7000 -p 9042: 9042 -p 9160:9160 -p7001:7001 Cassandra :3.11。您可以在 docker ps 输出中看到差异:

$ docker run --name cassandraDb -d -p 7199:7199 -p 7000:7000 -p 9042:9042 -p 
   9160:9160 -p7001:7001 cassandra:3.11 
$ docker ps
  ... PORTS   
      0.0.0.0:7000-7001->7000-7001/tcp, 0.0.0.0:7199->7199/tcp, 
      0.0.0.0:9042->9042/tcp, 0.0.0.0:9160->9160/tcp   cassandraDb

$ docker run --name cassandraDb -d --publish-all=true cassandra:3.11 
$ docker ps
... PORTS                                                                                                                         
    0.0.0.0:32782->7000/tcp, 0.0.0.0:32781->7001/tcp, 
    0.0.0.0:32780->7199/tcp, 0.0.0.0:32779->9042/tcp, 0.0.0.0:32778->9160/tcp 

2) Docker IP 可能不是 172.17.0.2。它是 localhost 或尝试 docker-machine ip

关于node.js - 无法从我的 Node.js 应用程序连接到 Cassandra Docker 容器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45124300/

相关文章:

node.js - 如何通过键获取 mongo 集合的子元素?

node.js - 如何使用nodejs将pdfkit对象转换为缓冲区

php - 无法更新 Docker 容器中的 php.ini 文件

git - 使 Docker 容器保持最新

javascript - 如何在nodejs中列出ftp文件?

Node.JS 请求 - 无效的 URI "/"

azure - 无法通过 docker 登录到 azure 容器注册表

python - Cassandra 。默认列值

Cassandra 时间戳限制子句(timeuuid)

cassandra - 如何计算 ByteOrderedPartitioner 的 token