当前位置: 首页 > 知识库问答 >
问题:

维持mgo会议的最佳实践

岳意蕴
2023-03-14

我目前正在使用带有mgo lib的mongoDB作为Web应用程序,但我不确定我使用它的方式是否是好的。

package db

import (
    "gopkg.in/mgo.v2"
)

const (
    MongoServerAddr = "192.168.0.104"
    RedisServerAddr = "192.168.0.104"
)

var (
    MongoSession, err = mgo.Dial(MongoServerAddr)

    MDB  = MongoSession.DB("message")
    MCol = MDB.C("new")
    MSav = MDB.C("save")

    UDB  = MongoSession.DB("account")
    UCol = UDB.C("user")
)

我初始化db会话并创建获取集合和文档值的变量,因此当我需要查询集合时,我使用该变量进行查询。

像这样:

func UserExist(username string) bool {
    user := Users{}
    err := db.UCol.Find(bson.M{"username": username}).One(&user)
    if err != nil {
        return false
    } else {
        return true
    }
}

那么,有没有一个最佳实践,或者这一个很好。。?谢谢

共有3个答案

司空丰
2023-03-14

使用go 1.7,在Web服务器上处理mongo会话的最惯用方法是使用新的标准库包context编写一个中间件,可以附加延迟会话。每当调用请求上下文Done()时关闭()。所以你不需要记住关闭

AttachDeviceCollection = func(next http.Handler) http.Handler {
        return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
            db, err := infra.Cloner()
            if err != nil {
                http.Error(w, err.Error(), http.StatusInternalServerError)
                return
            }
            collection, err := NewDeviceCollection(db)

            if err != nil {
                db.Session.Close()
                http.Error(w, err.Error(), http.StatusInternalServerError)
                return
            }
            ctx := context.WithValue(r.Context(), DeviceRepoKey, collection)
            go func() {
                select {
                case <-ctx.Done():
                    collection.Session.Close()
                }
            }()

            next.ServeHTTP(w, r.WithContext(ctx))
        })
    }

燕超
2023-03-14

虽然没有直接回答您的问题,但关于mgo会话检查,您必须使用延迟/恢复,因为mgo调用(甚至mgo.session.ping)恐慌。据我所知,没有其他方法可以检查mgo会话状态(mgo godocs)。您可以使用Gustavo Niemeyer的建议并在您的DataStore类型上添加一个方法。

func (d *DataStore) EnsureConnected() {
    defer func() {
        if r := recover(); r != nil {
            //Your reconnect logic here.
        }
    }()

    //Ping panics if session is closed. (see mgo.Session.Panic())  
    d.Ping()
}
汪兴为
2023-03-14

我建议不要使用这样的全球会议。相反,您可以创建一个负责所有数据库交互的类型。例如:

type DataStore struct {
    session *mgo.Session
}

func (ds *DataStore) ucol() *mgo.Collection { ... }

func (ds *DataStore) UserExist(user string) bool { ... }

这种设计有很多好处。重要的一点是,它允许您同时运行多个会话,因此,例如,如果您有一个http处理程序,您可以创建一个本地会话,该会话由一个独立的会话支持,仅用于该请求:

func (s *WebSite) dataStore() *DataStore {
    return &DataStore{s.session.Copy()}
}    

func (s *WebSite) HandleRequest(...) {
    ds := s.dataStore()
    defer ds.Close()
    ...
}

在这种情况下,mgo驱动程序表现良好,因为会话是在内部缓存和重用/维护的。在使用过程中,每个会话还将由一个独立的套接字支持,可以配置独立的设置,也可以进行独立的错误处理。如果使用单个全局会话,这些问题最终将不得不解决。

 类似资料:
  • 问题内容: 我目前正在将带有mgo lib的mongodb用于Web应用程序,但是我不确定我使用它的方式是否很好。 我初始化db会话并创建获取集合和文档值的变量,因此当我需要查询集合时,我使用变量来实现它。 像那样 : 那么,有没有最佳实践呢?谢谢 问题答案: 我建议不要使用这样的全局会话。相反,您可以创建负责所有数据库交互的类型。例如: 该设计有很多好处。一个重要的方面是,它允许您同时运行多个会

  • 开发 PWA 项目过程中,为了能够开发出高性能的代码,我们需要对自己的代码进行一系列的规范约定。在本篇教程中列出一些编写高性能可维护代码的实践建议,供大家参考。 代码规范 首先参照规范写出的代码在可维护性和代码性能方面是非常有效的方法,我们在这里推荐大家参照百度前端编码规范: JavaScript 代码规范: https://github.com/ecomfe/spec/blob/master/j

  • 问题内容: 我有如下内容: 我对基本图片有2个问题: 1.如何获取标签? 通常,我是从dockerhub获得的,也就是说,我可以从dockerhub的openjdk存储库中获得。 如果我可以从任何本地docker命令获取所有标签,那么我不需要访问Web来获取标签,效率真的有点低吗? 2.基本图像安全吗? 我的意思是说我的基本形象是否一直存在? 查看上面的openjdk回购,这是一个官方回购。 我发

  • 我有一个类似于以下内容: 我有2个关于基本图像的问题: 通常,我从dockerhub获取它,比如说,我可以从dockerhub的openjdk存储库中获取它。 如果我可以从任何本地docker命令获取所有标签,那么我就不需要访问web来获取标签,真的有点低效率吗? 我是说如果我的基本形象一直在那里? 看看上面的openjdk repo,它是一个官方的repo。 我发现只有供我选择。但我认为在这个过

  • 问题内容: Go没有工会。但是工会在很多地方都是必要的。XML过度使用联合或选择类型。我试图找出答案,这是解决缺少的工会的首选方法。作为一个例子,我试图写Go代码对于非终端在XML标准,其可以是一个注释,一个处理指令或白空间。 为这三种基本类型编写代码非常简单。它们映射到字符数组和结构。 但是,当我完成联合的代码时,它变得with肿了许多冗余功能。显然必须有一个容器结构。 为了确保容器仅包含三个允

  • 让我们假设我有一个酒店索引,就像ElesticSearch网站上的示例一样。除了得到与给定短语匹配的酒店之外,我还想检查用户是否被允许看到“建议”。像只为某一客户服务的旅馆之类的东西。我添加了一个用于保存组/权限的新字段,作为一个简单的字符串用于测试。我想完成的是按组过滤。 映射如下所示: 并附上下列文件: 在https://github.com/elasticsearch/elasticsear