最近发现不少小伙伴都对Golang很感兴趣,所以今天继续给大家介绍Golang相关的知识,本文《mongodb客户端驱动并发安全吗?》主要内容涉及到等等知识点,希望能帮到你!当然如果阅读本文时存在不同想法,可以在评论中表达,但是请勿使用过激的措辞~
问题内容在以下代码库中,创建了 mongodb 客户端(如下所示):
import (
"context"
"time"
"go.mongodb.org/mongo-driver/mongo"
"go.mongodb.org/mongo-driver/mongo/options"
"go.mongodb.org/mongo-driver/mongo/readpref"
)
ctx, cancel := context.withtimeout(context.background(), 10*time.second)
defer cancel()
client, err := mongo.connect(ctx, options.client().applyuri("mongodb://localhost:27017"))
在我们的场景中:
goroutine 1 使用 collection1
进行读写操作:
collection1 := client.database("testing").collection("collectionone")
go-routine 2 同时使用 collection1
和 collection2
进行读写操作:
collection2 := client.Database("testing").Collection("collectiontwo")
client
并发在多个 go 例程中使用安全吗?
正确答案
mongo.Database
的文档明确指出:
Database 是 MongoDB 数据库的句柄。 多个 goroutine 并发使用是安全的。
mongo.Client
:
Client 是一个句柄,代表 MongoDB 部署的连接池。 多个 goroutine 并发使用是安全的。
还有mongo.Collection
:
Collection 是 MongoDB 集合的句柄。 多个 goroutine 并发使用是安全的。
参见相关内容:goroutine create multiple mongodb connection
根据 mongoDB 文档 - 游标不是 goroutine 安全的。不要同时在多个 goroutine 中使用同一个游标。
到这里,我们也就讲完了《mongodb客户端驱动并发安全吗?》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注编程网公众号,带你了解更多关于的知识点!