Go:客户端断开连接

Go: client is disconnected

我加入 Gophers 团队已经几周了。到目前为止,一切都很好。 我开始了一个新项目,使用 fiber 网络框架来构建后端 API。

我正在使用 MongoDB 作为我的数据库。

database/db.go

package database

import (
    "context"
    "log"
    "time"

    "go.mongodb.org/mongo-driver/mongo"
    "go.mongodb.org/mongo-driver/mongo/options"
    "go.mongodb.org/mongo-driver/mongo/readpref"
)

var DB *mongo.Database

// InitMongo : Initialize mongodb...
func connectToMongo() {
    log.Printf("Initializing database")

    client, err := mongo.NewClient(options.Client().ApplyURI("mongodb://localhost:27017"))
    if err != nil {
        log.Fatal("Could not able to connect to the database, Reason:", err)
    }
    ctx, cancel := context.WithTimeout(context.Background(), 10*time.Second)

    err = client.Connect(ctx)
    if err != nil {
        log.Fatal("Context error, mongoDB:", err)
    }

    //Cancel context to avoid memory leak
    defer cancel()

    defer client.Disconnect(ctx)

    // Ping our db connection
    err = client.Ping(context.Background(), readpref.Primary())
    if err != nil {
        log.Fatal("Ping, mongoDB:", err)
    }

    log.Printf("Database connected!")

    // Create a database
    DB = client.Database("golang-test")

    return
}

// In Golang, init() functions always initialize whenever the package is called.
// So, whenever DB variable called, the init() function initialized
func init() {
    connectToMongo()
}

controllers/mongo.controller/mongo.controller.go

package mongocontroller

import (
    "log"

    "github.com/gofiber/fiber/v2"
    service "gitlab.com/.../services/mongoservice"
)

// GetPersons godoc
// @Summary Get persons.
// @Description Get persons
// @Tags persons
// @Produce json
// @Success 200 {object} []service.Person
// @Failure 400 {object} httputil.HTTPError
// @Failure 404 {object} httputil.HTTPError
// @Failure 500 {object} httputil.HTTPError
// @Router /v1/persons [get]
func GetPersons(c *fiber.Ctx) error {
    res, err := service.GetPersons()
    if err != nil {
        log.Fatal("ERROR: in controller...", err)
    }

    return c.JSON(res)
}

services/mongoservice/mongo.service.go

package mongoservice

import (
    "context"
    "log"

    database "gitlab.com/.../database"
    "go.mongodb.org/mongo-driver/bson"
    "go.mongodb.org/mongo-driver/bson/primitive"
)

// Person : ...
type Person struct {
    ID   primitive.ObjectID `bson:"_id,omitempty" json:"_id,omitempty"`
    Name string             `bson:"name,omitempty" json:"name,omitempty"`
    Age  int                `bson:"age,omitempty" json:"age,omitempty"`
}


func GetPersons() ([]Person, error) {

    ctx := context.Background()

    persons := []Person{}

    log.Printf("mongo data...", ctx)

    cur, err := database.DB.Collection("persons").Find(ctx, bson.M{})
    if err != nil {
        log.Fatal(err)
    }

    // Iterate through the returned cursor.
    for cur.Next(ctx) {
        var person Person
        cur.Decode(&person)
        persons = append(persons, person)
    }

    defer cur.Close(ctx)

    return persons, err
}

这是我存储在数据库中的数据:

问题是,行 cur, err := database.DB.Collection("persons").Find(ctx, bson.M{}) 从服务总是抛出 Client is disconnected.

感谢任何帮助!

谢谢。

您在创建连接 (connectToMongo ) 的同一函数中调用 defer client.Disconnect(ctx),因此它将在调用该函数后关闭连接。您应该 return 连接并在完成任务后关闭。我的意思是这些部分: defer cancel() defer client.Disconnect(ctx)