登录
首页 >  Golang >  Go问答

同时建立多个goroutine与mongodb连接

来源:stackoverflow

时间:2024-03-28 19:00:28 117浏览 收藏

小伙伴们有没有觉得学习Golang很有意思?有意思就对了!今天就给大家带来《同时建立多个goroutine与mongodb连接》,以下内容将会涉及到,若是在学习中对其中部分知识点有疑问,或许看了本文就能帮到你!

问题内容

如何在golang中管理超过100000个goroutine的MongoDB连接。

我创建了一个 *mongo.Client 实例,然后使用同一客户端,但它创建了多个连接。


正确答案


mongo.Client 管理内部连接池。您不必担心这一点。 mongo.client 可以安全地并发使用。

如果您想限制内部池,您可以在连接时使用 ClientOptions 进行限制。例如:

clientOpts := options.Client().ApplyURI("").
    SetMaxPoolSize(100) // Allow no more than 100 connections

client, err := mongo.Connect(context.TODO(), clientOpts)
if err != nil {
    log.Fatal(err)
}

引用自ClientOptions.SetMaxPoolSize()

setmaxpoolsize 指定驱动程序连接池中允许到每个服务器的最大连接数。如果达到此最大值,对服务器的请求将被阻止。也可以通过“maxpoolsize”uri 选项(例如“maxpoolsize=100”)进行设置。默认值为 100。如果为 0,则将设置为 math.maxint64。

clientoptions 还具有用于设置 maxconnidletimeminpoolsize 属性的方法。

但要知道这不会加快速度。如果您有十万个 goroutine 都与 mongodb 交互,那么 mongodb 可能会成为您的瓶颈。

今天关于《同时建立多个goroutine与mongodb连接》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>