我的问题归结为标题:坚固的存储库实例(旨在)是线程安全的吗?
当我这样做时,我可能能够解决一个我一直有更长的问题:在使用不同的 Repository 实例时,是否使用坚固的(打算是)线程安全的来访问 git 存储库?
语境
我正在使用 Rugged 访问一个 git 存储库,该存储库存储多个用户的文档,这些用户可以通过共享的 Web 前端访问该存储库。到目前为止,我为每个访问创建了一个新的 Repository 实例,因为它表现得足够好并且似乎是安全的(我无法在文档中找到保证或从使用 libgit2 的方式确定明显的安全性,但没有测试发现问题,我'我假设 libgit2 本身是安全的)。
但是,我遇到了一个问题,它限制了您可以几乎同时打开的存储库实例的数量,这会导致一些脚本出现问题,这些脚本重用了为每个 git 存储库访问创建存储库实例的一些代码。一个简单的解决方案是在所有用户之间共享存储库实例。但是,如果存储库实例不是线程安全的,这将导致问题。我是否需要使用 Mutex 来保护所有这些共享实例,或者我可以不使用 Mutex,因为坚固/libgit2 已经为我解决了这个问题?