EasilyNET.MongoDistributedLock 1.8.4

There is a newer version of this package available.
See the version list below for details.
dotnet add package EasilyNET.MongoDistributedLock --version 1.8.4
                    
NuGet\Install-Package EasilyNET.MongoDistributedLock -Version 1.8.4
                    
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="EasilyNET.MongoDistributedLock" Version="1.8.4" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="EasilyNET.MongoDistributedLock" Version="1.8.4" />
                    
Directory.Packages.props
<PackageReference Include="EasilyNET.MongoDistributedLock" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add EasilyNET.MongoDistributedLock --version 1.8.4
                    
#r "nuget: EasilyNET.MongoDistributedLock, 1.8.4"
                    
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#addin nuget:?package=EasilyNET.MongoDistributedLock&version=1.8.4
                    
Install EasilyNET.MongoDistributedLock as a Cake Addin
#tool nuget:?package=EasilyNET.MongoDistributedLock&version=1.8.4
                    
Install EasilyNET.MongoDistributedLock as a Cake Tool
EasilyNET.MongoDistributedLock
使用方法
// 使用MongoDB驱动创建一个链接
var setting = new MongoClientSettings
{
    Servers = new List<MongoServerAddress> { new("127.0.0.1", 27018) },
    Credential = MongoCredential.CreateCredential("admin", "guest", "guest"),
    LinqProvider = LinqProvider.V3
};
var client = new MongoClient(setting);
var db = client.GetDatabase("locks");
try
{
    // 由于使用到一些特性.需要将这个集合设置成 上限集合
    db.CreateCollection("release.signal", new()
    {
        // 这个数量理论上可以决定同时系统能有多少个锁.
        MaxDocuments = 100,
        MaxSize = 4096,
        Capped = true
    });
}
catch
{
    // ignored
}
IMongoCollection<LockAcquire> _locks = db.GetCollection<LockAcquire>("lock.acquire");
IMongoCollection<ReleaseSignal> _signals = db.GetCollection<ReleaseSignal>("release.signal");

// 获取锁
// 这里使用一个随机的ID作为锁ID,相当于其他锁中的Key.用来区分不同的业务的锁,也可以将不同的业务类型放到MongoDB中存起来,然后再使用的时候再取获取这个id
const string lockId = "64d44afde4473b85a177084c";

var mongoLock = DistributedLock.GenerateNew(_locks, _signals, ObjectId.Parse(lockId));
var acq = await mongoLock.AcquireAsync(TimeSpan.FromSeconds(5), TimeSpan.FromSeconds(0));

// 释放锁 也可以等超时释放
await mongoLock.ReleaseAsync(acq1);
  • 实际用的时候大概是这样.
try
{
    if (acq.Acquired)
    {
        // 关键部分,它不能一次由任何服务器上的多个线程执行
        // ...
        // ...
    }
    else
    {
        // 超时!也许另一个线程没有释放锁...我们可以再试一次或抛出例外
    }
}
finally
{
    // 如果(acq.Acquired)无需手动操作
    await mongoLock.ReleaseAsync(acq);
}
  • 注意事项和工作原理
  1. 当您尝试获取锁时,具有指定 lockId 的文档将添加到锁集合中,或者更新(如果存在).
  2. 释放锁时,将更新文档,并将新文档添加到信号上限集合中
  3. 当锁定正在等待时,将使用服务器端等待的可尾游标.详细信息
  4. 生存期是锁有效的时间段.在此时间之后,锁将自动“释放”,并且可以再次获取.它可以防止死锁.
  5. 不要使用长时间的超时,这可能会引发 MongoDB 驱动程序的异常.正常超时不超过 1-2 分钟!
Product Compatible and additional computed target framework versions.
.NET net6.0 is compatible.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 is compatible.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 is compatible.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (1)

Showing the top 1 NuGet packages that depend on EasilyNET.MongoDistributedLock:

Package Downloads
EasilyNET.MongoDistributedLock.AspNetCore

MongoDB分布式锁方案

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
3.24.1113.100 120 6 months ago
3.24.1112.125 102 6 months ago
3.24.1107.140 99 6 months ago
3.24.1107.54 97 6 months ago
3.24.1107.34 107 6 months ago
3.24.1105.111 108 6 months ago
3.24.1103.31 114 6 months ago
3.24.1103 109 6 months ago
3.24.1031.135 104 6 months ago
3.24.1031.112 104 6 months ago
3.24.1031.104 102 6 months ago
3.24.1029.142 102 6 months ago
3.24.1025.30 109 6 months ago
3.24.1022.142 84 6 months ago
3.24.1018.204 155 6 months ago
3.24.1018.175 154 6 months ago
3.24.1018.166 146 6 months ago
3.24.1018.93 152 6 months ago
3.24.1017.42 103 6 months ago
3.24.1016.161 103 6 months ago
3.24.1015.231 99 7 months ago
3.24.1015.14 105 7 months ago
3.24.1012.114 100 7 months ago
3.24.1009.115 106 7 months ago
3.24.1008.160 95 7 months ago
3.24.1008.133 103 7 months ago
3.24.1007.185 99 7 months ago
3.24.1003.33 112 7 months ago
3.24.1002.162 115 7 months ago
3.24.929.143 112 7 months ago
3.24.929.141 106 7 months ago
3.24.929.131 107 7 months ago
3.24.929.122 96 7 months ago
3.24.926.184 111 7 months ago
3.24.926.182 109 7 months ago
3.24.926.175 109 7 months ago
3.24.924.160 101 7 months ago
3.24.924.133 105 7 months ago
3.24.924.124 99 7 months ago
3.24.924.10 113 7 months ago
3.24.924.1 106 7 months ago
3.24.923.234 95 7 months ago
3.24.923.232 101 7 months ago
3.24.923.155 112 7 months ago
3.24.919.92 106 7 months ago
3.24.914.125 134 8 months ago
3.24.914.115 121 8 months ago
3.24.914.111 129 8 months ago
3.24.911.95 120 8 months ago
3.24.908.215 110 8 months ago
3.24.904.200 115 8 months ago
3.24.828.163 141 8 months ago
3.24.820.173 136 8 months ago
3.24.814.92 139 9 months ago
3.24.812.115 136 9 months ago
3.24.802.100 100 9 months ago
3.24.801.162 117 9 months ago
3.24.801.160 112 9 months ago
3.24.801.155 109 9 months ago
3.24.730.164 79 9 months ago
3.24.730.91 82 9 months ago
3.24.724.91 102 9 months ago
3.24.718.105 130 9 months ago
3.24.716.95 111 10 months ago
3.24.712.94 106 10 months ago
3.24.710.14 128 10 months ago
3.24.709.105 114 10 months ago
3.24.704.94 133 10 months ago
3.24.701.90 126 10 months ago
3.24.628.114 123 6/28/2024
3.24.627.145 114 6/27/2024
3.24.620.160 121 6/20/2024
3.24.613.115 111 6/13/2024
3.24.612.95 113 6/12/2024
3.24.528.90 117 5/28/2024
3.24.522.84 123 5/22/2024
3.24.512.213 111 5/12/2024
3.24.508.112 139 5/8/2024
2.2024.428.71 139 4/28/2024
2.2024.427.1128 136 4/27/2024
2.2.72 132 4/14/2024
2.2.71 121 4/12/2024
2.2.8 120 4/26/2024
2.2.6 120 4/10/2024
2.2.5 117 3/26/2024
2.2.4 123 3/25/2024
2.2.3 119 3/24/2024
2.2.2 140 3/21/2024
2.2.1 154 3/20/2024
2.2.0 144 3/13/2024
2.1.9 147 2/21/2024
2.1.8 125 2/18/2024
2.1.7 147 2/16/2024
2.1.6 127 2/14/2024
2.1.5 129 2/14/2024
2.1.4 150 2/9/2024
2.1.3 154 2/8/2024
2.1.2 130 2/5/2024
2.1.1.2 201 12/26/2023
2.1.1.1 144 12/26/2023
2.1.1 148 12/25/2023
2.1.0 164 12/17/2023
2.0.11 162 12/6/2023
2.0.1 189 11/15/2023
2.0.0 172 11/14/2023
1.9.1 161 11/1/2023
1.9.0 146 10/19/2023
1.9.0-preview2 119 10/12/2023
1.9.0-preview1 139 10/12/2023
1.8.9 161 10/11/2023
1.8.8 169 10/11/2023
1.8.7-rc2 112 9/21/2023
1.8.7-rc1 123 9/12/2023
1.8.6 175 8/31/2023
1.8.5 166 8/25/2023
1.8.4 163 8/24/2023
1.8.3 187 8/23/2023
1.8.2 169 8/22/2023
1.8.1 161 8/18/2023
1.8.0 182 8/15/2023
1.7.9 179 8/11/2023
1.7.8 180 8/11/2023
1.7.7 177 8/10/2023
1.7.6 168 8/9/2023
1.7.5 183 8/9/2023
1.7.4 185 8/3/2023
1.7.3 186 8/1/2023
1.7.2 186 7/31/2023
1.7.1 178 7/27/2023
1.7.0 196 7/27/2023