0

任务如下:编写将与 ScyllaDB 一起使用的 node.js 服务器,该服务器将放置在 Docker 容器上。我早些时候这样做了,但是在 Ubuntu 上,它工作正常,现在我应该在 Windows 10 上这样做。

我安装了 Docker Toolbox for Windows 并运行来自 scylladb 文档的命令。

$ docker run --name some-scylla -d scylladb/scylla
af51fa65627303db16a3de85003be8a165a64f37cf6ae29c0b4e887d64342ad2\

$ docker exec -it some-scylla cqlsh
Connected to  at 172.17.0.2:9042.
[cqlsh 5.0.1 | Cassandra 3.0.8 | CQL spec 3.3.1 | Native protocol v4]
Use HELP for help.
cqlsh> CREATE KEYSPACE nodeTask WITH replication = {'class': 'SimpleStrategy', 'replication_factor': 3};

在我的 Node.js 服务器上之后,我可以设置连接:

const cassandra = require("cassandra-driver")
const client = new cassandra.Client({
 contactPoints: ["127.0.0.1"],
  localDataCenter: "datacenter1",
  keyspace: "nodetask"
})

正如我所说,它在具有此 IP 的 Ubuntu 上工作正常 - 127.0.0.1,BeaverDB(GUI)默认使用 9042 端口连接到此 IP,但在 Windows 上它不起作用。现在不可能在 Ubuntu 上工作。

抱歉这个问题很糟糕,也许还有一些信息,但我是新手,根本不知道我到底需要说什么

4

1 回答 1

0

127.0.0.1是环回地址,因此您的 Node.js 容器会一直 ping 自身而不是主机(您的笔记本电脑)。您可以创建自己的桥接网络并将两个容器附加到该桥接网络

docker network create scylla-net

现在运行 ScyllaDB 容器如下

docker run --name some-scylla -d --net=scylla-net scylladb/scylla

在您的 Node.js 脚本中,将 更改127.0.0.1some-scylla(您的 ScyllaDB 容器的名称)。用户定义的桥接网络很酷的一点是,它们让您的容器通过它们的名称相互通信。因此,该名称some-scylla将解析为some-scylla容器当时使用的任何 IP 地址。

现在,当您运行 Node.js 服务器时,请务必传递 --net=scylla-net标志,否则它将无法解析 name some-scylla。希望这可以帮助!

于 2019-03-18T18:59:13.597 回答