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 时出错的详细内容,更多请关注每日运维网(www.mryunwei.com)其它相关文章!