MasterComponent.cs 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. using System.Collections.Generic;
  2. using System.Threading.Tasks;
  3. using Base;
  4. namespace Model
  5. {
  6. public class LockInfo
  7. {
  8. public string Address;
  9. public TaskCompletionSource<bool> Tcs;
  10. public LockInfo(string address, TaskCompletionSource<bool> tcs)
  11. {
  12. this.Address = address;
  13. this.Tcs = tcs;
  14. }
  15. }
  16. public class MasterComponent : Component
  17. {
  18. /// 镜像的地址
  19. private readonly List<string> ghostsAddress = new List<string>();
  20. /// 当前获取锁的进程地址
  21. private string lockedAddress = "";
  22. /// 请求锁的队列
  23. private readonly Queue<LockInfo> queue = new Queue<LockInfo>();
  24. public void AddGhost(string address)
  25. {
  26. this.ghostsAddress.Add(address);
  27. }
  28. public void RemoveGhost(string address)
  29. {
  30. this.ghostsAddress.Remove(address);
  31. }
  32. public Task<bool> Lock(string address)
  33. {
  34. TaskCompletionSource<bool> tcs = new TaskCompletionSource<bool>();
  35. if (this.lockedAddress == "")
  36. {
  37. this.lockedAddress = address;
  38. tcs.SetResult(true);
  39. }
  40. else
  41. {
  42. LockInfo lockInfo = new LockInfo(address, tcs);
  43. this.queue.Enqueue(lockInfo);
  44. }
  45. return tcs.Task;
  46. }
  47. public void Release(string address)
  48. {
  49. if (this.lockedAddress != address)
  50. {
  51. Log.Error($"解锁地址与锁地址不匹配! {this.lockedAddress} {address}");
  52. return;
  53. }
  54. if (this.queue.Count == 0)
  55. {
  56. this.lockedAddress = "";
  57. return;
  58. }
  59. LockInfo lockInfo = this.queue.Dequeue();
  60. this.lockedAddress = lockInfo.Address;
  61. lockInfo.Tcs.SetResult(true);
  62. }
  63. }
  64. }