MasterComponent.cs 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  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. if (this.lockedAddress == "")
  35. {
  36. this.lockedAddress = address;
  37. return Task.FromResult(true);
  38. }
  39. TaskCompletionSource<bool> tcs = new TaskCompletionSource<bool>();
  40. LockInfo lockInfo = new LockInfo(address, tcs);
  41. this.queue.Enqueue(lockInfo);
  42. return tcs.Task;
  43. }
  44. public void Release(string address)
  45. {
  46. if (this.lockedAddress != address)
  47. {
  48. Log.Error($"解锁地址与锁地址不匹配! {this.lockedAddress} {address}");
  49. return;
  50. }
  51. if (this.queue.Count == 0)
  52. {
  53. this.lockedAddress = "";
  54. return;
  55. }
  56. LockInfo lockInfo = this.queue.Dequeue();
  57. this.lockedAddress = lockInfo.Address;
  58. lockInfo.Tcs.SetResult(true);
  59. }
  60. }
  61. }