配置与扩展
1、配置文件
通过文件可以配置多个分布式锁,通过更换 default 的值即可实现无缝切换。配置文件如下:
- .Net Framework 下的 app.config 或 web.config 文件
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<configSections>
<sectionGroup name="fireasy">
<section name="lockers" type="Fireasy.Common.Threading.Configuration.LockerConfigurationSectionHandler, Fireasy.Common" />
</sectionGroup>
</configSections>
<fireasy>
<lockers default="redis">
<locker name="redis" type="Fireasy.Redis.RedisLocker, Fireasy.Redis" />
<locker name="demo" type="demo.DistributeLocker, demo" />
</lockers>
</fireasy>
</configuration>
- .Net Core 下的 appsettings.json 文件
{
"fireasy": {
"lockers": {
"default": "redis",
"settings": {
"redis": {
"type": "Fireasy.Redis.RedisLocker, Fireasy.Redis"
},
"demo": {
"type": "demo.DistributeLocker, demo"
}
}
}
}
}
DistributedLockerFactory
工厂类可以根据配置创建一个 IDistributedLocker
实例。如下所示:
[TestMethod]
public void TestCreateLocker()
{
var locker1 = DistributedLockerFactory.CreateLocker();
Assert.IsNotNull(locker1); // Redis
var locker2 = DistributedLockerFactory.CreateLocker("demo");
Assert.IsNotNull(locker2); // demo
}
在使用 IOC
的环境中,通过构造注入或属性注入得到的 IDistributedLocker
的实例对应的是指向 default 的配置项。