gpt4 book ai didi

ruby - 坚固的 Repository 实例是线程安全的吗?

转载 作者:太空宇宙 更新时间:2023-11-03 16:23:45 31 4
gpt4 key购买 nike

我的问题归结为标题:are rugged存储库实例(旨在)线程安全?

当我在做的时候,我也许能够解决一个我一直在思考的问题:在使用不同的 Repository 实例时,是否可以使用坚固的(旨在)线程安全的方式访问 git 存储库?

上下文

我正在使用 Rugged 访问一个 git 存储库,该存储库为多个用户存储文档,这些用户可以通过共享的 Web 前端访问该存储库。到目前为止,我为每次访问创建了一个新的 Repository 实例,因为它执行得足够好并且似乎是安全的(我无法在文档中找到保证或从使用 libgit2 的方式确定明显的安全性,但没有测试发现问题并且我'假设 libgit2 本身是安全的)。

但是,我遇到了一个 issue ,这限制了您可以几乎同时打开的存储库实例的数量,这会导致某些脚本出现问题,这些脚本会重用为每个 git 存储库访问创建存储库实例的某些代码。一个简单的解决方案是在所有用户之间共享存储库实例。但是,如果存储库实例不是线程安全的,那将导致问题。我是否需要使用 Mutex 来保护所有这些共享实例,或者我可以不用,因为 rugged/libgit2 已经为我解决了这个问题?

最佳答案

是的,libgit2(因此也很坚固)应该是线程安全的,只要您不跨不同线程使用相同的存储库实例(或从 libgit2 创建的任何其他对象)。

但是正如问题的第二部分所示,您实际上想在不同的线程中使用相同的存储库实例。在这里,答案是视情况而定。大多数(但不是全部)libgit2 提供的函数应该是线程安全的,但我不能给你一个明确的列表。参见 https://github.com/libgit2/libgit2/issues/2491了解更多信息。

关于ruby - 坚固的 Repository 实例是线程安全的吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29250745/

31 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com