mirror of
				https://github.com/opennetworkinglab/onos.git
				synced 2025-10-25 22:31:07 +02:00 
			
		
		
		
	Remove from leader board immediately on leader election withdraw.
This prevents some of the churn in the intent partitions due to partition manager working off inaccurate state. Change-Id: Ia324ea0273bc5d5858e378c05b45bafce6bda7e9
This commit is contained in:
		
							parent
							
								
									2216bdb555
								
							
						
					
					
						commit
						e649c750d2
					
				| @ -1,18 +1,8 @@ | |||||||
| package org.onosproject.store.consistent.impl; | package org.onosproject.store.consistent.impl; | ||||||
| 
 | 
 | ||||||
| import static org.onlab.util.Tools.groupedThreads; | import com.google.common.collect.ImmutableMap; | ||||||
| import static org.slf4j.LoggerFactory.getLogger; | import com.google.common.collect.Maps; | ||||||
| import static com.google.common.base.Preconditions.checkArgument; | import com.google.common.collect.Sets; | ||||||
| 
 |  | ||||||
| import java.util.Map; |  | ||||||
| import java.util.Map.Entry; |  | ||||||
| import java.util.Set; |  | ||||||
| import java.util.concurrent.ExecutorService; |  | ||||||
| import java.util.concurrent.Executors; |  | ||||||
| import java.util.concurrent.ScheduledExecutorService; |  | ||||||
| import java.util.concurrent.TimeUnit; |  | ||||||
| import java.util.stream.Collectors; |  | ||||||
| 
 |  | ||||||
| import org.apache.felix.scr.annotations.Activate; | import org.apache.felix.scr.annotations.Activate; | ||||||
| import org.apache.felix.scr.annotations.Component; | import org.apache.felix.scr.annotations.Component; | ||||||
| import org.apache.felix.scr.annotations.Deactivate; | import org.apache.felix.scr.annotations.Deactivate; | ||||||
| @ -41,9 +31,19 @@ import org.onosproject.store.service.StorageService; | |||||||
| import org.onosproject.store.service.Versioned; | import org.onosproject.store.service.Versioned; | ||||||
| import org.slf4j.Logger; | import org.slf4j.Logger; | ||||||
| 
 | 
 | ||||||
| import com.google.common.collect.ImmutableMap; | import java.util.Map; | ||||||
| import com.google.common.collect.Maps; | import java.util.Map.Entry; | ||||||
| import com.google.common.collect.Sets; | import java.util.Objects; | ||||||
|  | import java.util.Set; | ||||||
|  | import java.util.concurrent.ExecutorService; | ||||||
|  | import java.util.concurrent.Executors; | ||||||
|  | import java.util.concurrent.ScheduledExecutorService; | ||||||
|  | import java.util.concurrent.TimeUnit; | ||||||
|  | import java.util.stream.Collectors; | ||||||
|  | 
 | ||||||
|  | import static com.google.common.base.Preconditions.checkArgument; | ||||||
|  | import static org.onlab.util.Tools.groupedThreads; | ||||||
|  | import static org.slf4j.LoggerFactory.getLogger; | ||||||
| 
 | 
 | ||||||
| /** | /** | ||||||
|  * Distributed Lock Manager implemented on top of ConsistentMap. |  * Distributed Lock Manager implemented on top of ConsistentMap. | ||||||
| @ -199,8 +199,12 @@ public class DistributedLeadershipManager implements LeadershipService { | |||||||
|     public void withdraw(String path) { |     public void withdraw(String path) { | ||||||
|         activeTopics.remove(path); |         activeTopics.remove(path); | ||||||
|         try { |         try { | ||||||
|             if (lockMap.remove(path, localNodeId)) { |             Versioned<NodeId> leader = lockMap.get(path); | ||||||
|                 log.info("Gave up leadership for {}", path); |             if (Objects.equals(leader.value(), localNodeId)) { | ||||||
|  |                 if (lockMap.remove(path, leader.version())) { | ||||||
|  |                     log.info("Gave up leadership for {}", path); | ||||||
|  |                     notifyRemovedLeader(path, localNodeId, leader.version(), leader.creationTime()); | ||||||
|  |                 } | ||||||
|             } |             } | ||||||
|             // else we are not the current owner. |             // else we are not the current owner. | ||||||
|         } catch (Exception e) { |         } catch (Exception e) { | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user