使用 gopkg.in/mgo.v2 进行 MongoDB 时的并发注意事项
使用 gopkg.in/mgo 将 MongoDB 集成到 Go Web 应用程序时.v2,必须考虑并发最佳实践以获得最佳性能和资源利用率。本文解决了以下问题:
单个 mgo.Session 是否可以在 Web 应用程序中同时使用,例如在 http.Handler 中,或者应该使用 Session.Copy 和 Session.Close创建会话池
解释:
与最初的假设相反,mgo.Session 确实可以安全地并发使用。正如官方文档中所述,“所有 Session 方法都是并发安全的,并且可以从多个 Goroutine 调用。”
但是,这并不意味着在并发设置中仅使用一个 mgo.Session 是有利的。会话自动管理连接池,但使用单个会话会限制同时利用多个连接的能力,并且可能会跨服务器节点分布(如果可用)。
为每个请求创建新会话,必要时复制它们,然后关闭正确地使用它们(使用 Session.Close 和 defer)可以实现最佳的资源利用率。通过管理多个连接,系统可以同时使用更多连接和服务器节点,从而为数据库和最终用户提供更快的响应时间。
Session.Close 不会终止与服务器的底层连接,但而是将其返回到池中,使其可供其他会话拾取。
有关进一步的见解,请参阅有关会话性能的相关讨论:mgo - 查询性能似乎始终很慢(500-650 毫秒)。
以上是单个 mgo.Session 足以在 Go Web 应用程序中并发使用吗?的详细内容。更多信息请关注PHP中文网其他相关文章!