php小编百草在使用golang连接到rethinkDB时遇到了问题。无法连接到rethinkDB服务器的错误提示让他困惑不已。针对这个问题,他进行了一系列的排查和调试,并最终找到了解决方案。在这篇文章中,我们将一起探讨从golang连接到rethinkDB时可能出现的问题以及解决方法。
我使用 rethinkdb 运行 docker 容器,然后运行 go file 以连接到数据库,但连接时出现错误。
大家好。我需要 rethinkdb 方面的帮助,我运行了 docker 容器:
docker run --name rth -p 8100:8080 -d rethinkdb
然后访问http://localhost:8100并且有rethinkdb的主页,所以everythink都很好。但是当我尝试从 golang 连接到数据库时,我遇到了一些错误:
package main import ( r "gopkg.in/rethinkdb/rethinkdb-go.v6" "log" "fmt" ) func main() { _, err := r.connect(r.connectopts{ address: "localhost:28015", database: "test", }) if err != nil { fmt.println(err) log.fatal("could not connect") } }
运行 go run main.go
后出现此错误:
rethinkdb: dial tcp 127.0.0.1:28015: connect: connection refused 2023/05/18 01:38:39 could not connect exit status 1
感谢发生这种情况的原因是端口不正确(28015),但是如果我更改它,除了端口 = 8100 之外,我还会遇到同样的问题。如果我输入 8100 而不是 28015 并出现此错误:
rethinkdb: Unexpected EOF: HTTP/ 400 Bad Request 2023/05/18 01:38:52 Could not connect exit status 1
可能有人知道如何解决这个问题)
-p 8100:8080
将容器中的端口 8080
映射到主机上的端口 8100
。您没有映射任何其他端口,因此,当您尝试访问 8100
以外的任何端口(例如 127.0.0.1:28015
)时,您的请求将无法到达容器。主机上的其他东西可能正在侦听该端口,或者可能没有任何侦听。
您提到您可以访问 上的管理界面http://localhost:8100
;如果您检查日志,您会注意到类似以下内容:
listening for administrative http connections on port 8080 listening for client driver connections on port 28015
因此服务器正在侦听多个端口上的连接。端口 8080
(映射到 8100
)是管理 http 接口,28015
用于驱动程序连接(这在 文档)。您的代码正在尝试连接到端口 28015
(这是正确的),但您没有映射该端口,因此在主机上无法访问它;解决这个问题:
docker run --name rth -p 8100:8080 -p 28015:28015 -d rethinkdb
这会将容器中的端口 28015
映射到主机上的端口 28015
(如果需要,您可以使用不同的主机端口;只需记住更新代码)。我们现在可以成功连接如下内容:
package main import ( "fmt" "log" r "gopkg.in/rethinkdb/rethinkdb-go.v6" ) func main() { _, err := r.Connect(r.ConnectOpts{ Address: "localhost:28015", Database: "test", }) if err != nil { fmt.Println(err) log.Fatal("Could not connect") } fmt.Println("Connected") }
以上是从 golang 连接到 rethinkDB 时出错的详细内容。更多信息请关注PHP中文网其他相关文章!