com.netflix.dyno.connectionpool.TokenPoolTopology Maven / Gradle / Ivy
/**
* Copyright 2016 Netflix, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.netflix.dyno.connectionpool;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import java.util.concurrent.ConcurrentHashMap;
public class TokenPoolTopology {
private final ConcurrentHashMap> map = new ConcurrentHashMap>();
private final int replicationFactor;
public TokenPoolTopology (int replicationFactor) {
this.replicationFactor = replicationFactor;
}
public void addToken(String rack, Long token, HostConnectionPool> hostPool) {
List list = map.get(rack);
if (list == null) {
list = new ArrayList();
map.put(rack, list);
}
list.add(new TokenStatus(token, hostPool));
}
public ConcurrentHashMap> getAllTokens() {
return map;
}
public int getReplicationFactor() {
return replicationFactor;
}
public List getTokensForRack(String rack) {
if (rack != null && map.containsKey(rack)) {
return map.get(rack);
}
return null;
}
public String toString() {
ArrayList keyList = new ArrayList(map.keySet());
Collections.sort(keyList);
StringBuilder sb = new StringBuilder();
sb.append("TokenPoolTopology\n");
for (String key : keyList) {
sb.append("\nRack: " + key + "\n");
List list = map.get(key);
Collections.sort(list);
for (TokenStatus token : list) {
sb.append(token.toString()).append("\n");
}
}
return sb.toString();
}
public static class TokenStatus implements Comparable {
private Long token;
private HostConnectionPool> hostPool;
private TokenStatus(Long t, HostConnectionPool> pool) {
token = t;
hostPool = pool;
}
public Long getToken() {
return token;
}
public HostConnectionPool> getHostPool() {
return hostPool;
}
@Override
public int compareTo(TokenStatus o) {
return this.token.compareTo(o.token);
}
public String toString() {
return token + " ==> " + hostPool.toString();
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy