配置与扩展


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 的配置项。


2、第三方适配