Error connecting to rethinkDB from golang

WBOY
Release: 2024-02-12 10:45:08
forward
572 people have browsed it

从 golang 连接到 rethinkDB 时出错

php editor Baicao encountered a problem when using golang to connect to rethinkDB. The error message that he could not connect to the rethinkDB server confused him. In response to this problem, he conducted a series of troubleshooting and debugging, and finally found a solution. In this article, we will discuss possible problems and solutions when connecting to rethinkDB from golang.

Question content

I use rethinkdb to run the docker container, and then run go file to connect to the database, but an error occurs when connecting.

Hello everyone. I need help with rethinkdb, I ran the docker container:

docker run --name rth -p 8100:8080 -d rethinkdb
Copy after login

Then visit http://localhost:8100 and there is the homepage of rethinkdb, so everythink is fine. But when I try to connect to the database from golang, I get some errors:

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")
    }
}
Copy after login

This error occurs after running 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
Copy after login

Thanks The reason this is happening is that the port is incorrect (28015), but if I change it, except port = 8100, I get the same problem. If I enter 8100 instead of 28015 and get this error:

rethinkdb: Unexpected EOF: HTTP/ 400 Bad Request

2023/05/18 01:38:52 Could not connect
exit status 1
Copy after login

Maybe someone knows how to solve this problem)

Workaround

-p 8100:8080 Map the port 8080 in the container to Port 8100 on the host. You are not mapping any other ports, so when you try to access any port other than 8100 (for example, 127.0.0.1:28015), your request will not reach the container. Something else on the host might be listening on that port, or there might not be anything listening.

You mentioned that you can access the admin interface at http://localhost:8100; if you check the logs you will notice something like:

listening for administrative http connections on port 8080
listening for client driver connections on port 28015
Copy after login

So the server is listening for connections on multiple ports. Port 8080 (mapped to 8100) is the management http interface, 28015 is used for driver connections (this is in the documentation). Your code is trying to connect to port 28015 (which is correct), but you have not mapped that port, so it is not accessible on the host; fix this:

docker run --name rth -p 8100:8080 -p 28015:28015 -d rethinkdb
Copy after login

This will map port 28015 in the container to port 28015 on the host (you can use a different host port if needed; just remember to update the code). We can now successfully connect to the following:

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")
}
Copy after login

The above is the detailed content of Error connecting to rethinkDB from golang. For more information, please follow other related articles on the PHP Chinese website!

source:stackoverflow.com
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template