| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970 |
- using System.Collections.Generic;
- using System.Threading.Tasks;
- namespace Model
- {
- public class LockInfo
- {
- public string Address;
- public TaskCompletionSource<bool> Tcs;
- public LockInfo(string address, TaskCompletionSource<bool> tcs)
- {
- this.Address = address;
- this.Tcs = tcs;
- }
- }
-
- public class MasterComponent : Component
- {
- /// 镜像的地址
- private readonly List<string> ghostsAddress = new List<string>();
- /// 当前获取锁的进程地址
- private string lockedAddress = "";
- /// 请求锁的队列
- private readonly EQueue<LockInfo> queue = new EQueue<LockInfo>();
- public void AddGhost(string address)
- {
- this.ghostsAddress.Add(address);
- }
- public void RemoveGhost(string address)
- {
- this.ghostsAddress.Remove(address);
- }
- public Task<bool> Lock(string address)
- {
- if (this.lockedAddress == "")
- {
- this.lockedAddress = address;
- return Task.FromResult(true);
- }
- TaskCompletionSource<bool> tcs = new TaskCompletionSource<bool>();
- LockInfo lockInfo = new LockInfo(address, tcs);
- this.queue.Enqueue(lockInfo);
- return tcs.Task;
- }
- public void Release(string address)
- {
- if (this.lockedAddress != address)
- {
- Log.Error($"解锁地址与锁地址不匹配! {this.lockedAddress} {address}");
- return;
- }
- if (this.queue.Count == 0)
- {
- this.lockedAddress = "";
- return;
- }
- LockInfo lockInfo = this.queue.Dequeue();
- this.lockedAddress = lockInfo.Address;
- lockInfo.Tcs.SetResult(true);
- }
- }
- }
|