diff --git a/src/Proto.Cluster/Member/MemberList.cs b/src/Proto.Cluster/Member/MemberList.cs index 32b32550c7..87acf8e922 100644 --- a/src/Proto.Cluster/Member/MemberList.cs +++ b/src/Proto.Cluster/Member/MemberList.cs @@ -183,6 +183,8 @@ public void UpdateClusterTopology(IReadOnlyCollection members) return; } + activeMembers = RemoveDuplicateAddresses(activeMembers); + // Cancel any work based on the previous topology _currentTopologyTokenSource?.Cancel(); _currentTopologyTokenSource = new CancellationTokenSource(); @@ -303,6 +305,21 @@ void MemberJoin(Member newMember) } } + private static ImmutableMemberSet RemoveDuplicateAddresses(ImmutableMemberSet activeMembers) + { + var duplicateAddresses = activeMembers.Members.ToLookup(m => m.Address); + foreach (var dup in duplicateAddresses.Where(d => d.Count() > 1)) + { + var youngest = dup.OrderByDescending(m => m.Age).First(); + var rest = dup.Where(m => m.Id != youngest.Id).Select(m => m.Id).ToArray(); + + Logger.LogWarning("Duplicate address {Address} found, removing {Rest}", dup.Key, rest); + activeMembers = activeMembers.Except(rest); + } + + return activeMembers; + } + private void SelfBlocked() { // If already shutting down, nothing to do.