Skip to content

Commit

Permalink
Merge pull request #5 from AzisabaNetwork/fix/change-redis-leader
Browse files Browse the repository at this point in the history
🐛 Fixed a bug that occurred when changing leaders.
  • Loading branch information
siloneco authored Mar 23, 2022
2 parents bdda7f4 + 267cd0d commit 1a881c9
Show file tree
Hide file tree
Showing 5 changed files with 64 additions and 5 deletions.
2 changes: 1 addition & 1 deletion pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@

<groupId>net.azisaba</groupId>
<artifactId>Kuvel</artifactId>
<version>1.0.0</version>
<version>1.0.1</version>
<packaging>jar</packaging>

<name>${project.artifactId}</name>
Expand Down
4 changes: 4 additions & 0 deletions src/main/java/net/azisaba/kuvel/Kuvel.java
Original file line number Diff line number Diff line change
Expand Up @@ -72,8 +72,11 @@ public void onProxyInitialization(ProxyInitializeEvent event) {
kuvelConfig.getProxyGroupName());
proxyIdProvider.runTask(proxy, this);

logger.info("This proxy's id is: " + proxyIdProvider.getId());

redisConnectionLeader =
new RedisConnectionLeader(
this,
kuvelConfig.getRedisConnectionData().createJedisPool(),
kuvelConfig.getProxyGroupName(),
proxyIdProvider.getId());
Expand All @@ -82,6 +85,7 @@ public void onProxyInitialization(ProxyInitializeEvent event) {
if (redisConnectionLeader.isLeader()) {
logger.info("This proxy is selected as leader.");
}

kuvelServiceHandler.setAndRunLoadBalancerDiscovery(
new RedisLoadBalancerDiscovery(
client,
Expand Down
47 changes: 47 additions & 0 deletions src/main/java/net/azisaba/kuvel/redis/RedisConnectionLeader.java
Original file line number Diff line number Diff line change
Expand Up @@ -2,12 +2,16 @@

import java.util.Objects;
import lombok.RequiredArgsConstructor;
import net.azisaba.kuvel.Kuvel;
import net.azisaba.kuvel.discovery.impl.RedisLoadBalancerDiscovery;
import net.azisaba.kuvel.discovery.impl.RedisServerDiscovery;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;

@RequiredArgsConstructor
public class RedisConnectionLeader {

private final Kuvel plugin;
private final JedisPool jedisPool;
private final String groupName;
private final String proxyId;
Expand All @@ -31,13 +35,22 @@ public boolean trySwitch() {
jedis.expire(key, 600);
leader = true;
leaderExpireAt = System.currentTimeMillis() + (600 * 1000);

plugin.getLogger().info("This proxy was selected as a new leader.");
jedis.publish(RedisKeys.LEADER_CHANGED_NOTIFY_PREFIX.getKey() + groupName, proxyId);
runDiscoveryTask();
return true;
} else {
String currentLeader = jedis.get(RedisKeys.LEADER_PREFIX.getKey() + groupName);
if (Objects.equals(proxyId, currentLeader)) {
leader = true;
return true;
}

if (leader) {
stopDiscoveryTask();
}
leader = false;
return false;
}
}
Expand All @@ -62,6 +75,7 @@ public void leaveLeader() {
}

jedis.del(RedisKeys.LEADER_PREFIX.getKey() + groupName);
jedis.publish(RedisKeys.LEADER_LEAVE_NOTIFY_PREFIX.getKey() + groupName, proxyId);
}
}

Expand Down Expand Up @@ -92,4 +106,37 @@ public void publishDeletedServer(String podUid) {
jedis.publish(RedisKeys.POD_DELETED_NOTIFY_PREFIX.getKey() + groupName, podUid);
}
}

private void runDiscoveryTask() {
if (plugin.getKuvelConfig().getRedisConnectionData() == null) {
return;
}

plugin
.getKuvelServiceHandler()
.setAndRunLoadBalancerDiscovery(
new RedisLoadBalancerDiscovery(
plugin.getClient(),
plugin,
plugin.getKuvelConfig().getRedisConnectionData().createJedisPool(),
plugin.getKuvelConfig().getProxyGroupName(),
this,
plugin.getKuvelServiceHandler()));

plugin
.getKuvelServiceHandler()
.setAndRunServerDiscovery(
new RedisServerDiscovery(
plugin.getClient(),
plugin,
plugin.getKuvelConfig().getRedisConnectionData().createJedisPool(),
plugin.getKuvelConfig().getProxyGroupName(),
this,
plugin.getKuvelServiceHandler()));
}

private void stopDiscoveryTask() {
plugin.getKuvelServiceHandler().setAndRunLoadBalancerDiscovery(null);
plugin.getKuvelServiceHandler().setAndRunServerDiscovery(null);
}
}
4 changes: 3 additions & 1 deletion src/main/java/net/azisaba/kuvel/redis/RedisKeys.java
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,9 @@ public enum RedisKeys {
POD_ADDED_NOTIFY_PREFIX("kuvel:notify:add:pod:"),
LOAD_BALANCER_ADDED_NOTIFY_PREFIX("kuvel:notify:add:lb:"),
POD_DELETED_NOTIFY_PREFIX("kuvel:notify:del:pod:"),
LOAD_BALANCER_DELETED_NOTIFY_PREFIX("kuvel:notify:del:lb:");
LOAD_BALANCER_DELETED_NOTIFY_PREFIX("kuvel:notify:del:lb:"),
LEADER_LEAVE_NOTIFY_PREFIX("kuvel:notify:leader-leave:"),
LEADER_CHANGED_NOTIFY_PREFIX("kuvel:notify:leader-changed:");

private final String key;

Expand Down
12 changes: 9 additions & 3 deletions src/main/java/net/azisaba/kuvel/redis/RedisSubscriber.java
Original file line number Diff line number Diff line change
Expand Up @@ -32,12 +32,18 @@ public void subscribe() {
new JedisPubSub() {
@Override
public void onPMessage(String pattern, String channel, String message) {
if (redisConnectionLeader.isLeader()) {
String receivedGroupName = channel.split(":")[channel.split(":").length - 1];
if (!receivedGroupName.equalsIgnoreCase(groupName)) {
return;
}

String receivedGroupName = channel.split(":")[channel.split(":").length - 1];
if (!receivedGroupName.equalsIgnoreCase(groupName)) {
if (channel.startsWith(RedisKeys.LEADER_CHANGED_NOTIFY_PREFIX.getKey())
|| channel.startsWith(RedisKeys.LEADER_LEAVE_NOTIFY_PREFIX.getKey())) {
redisConnectionLeader.trySwitch();
return;
}

if (redisConnectionLeader.isLeader()) {
return;
}

Expand Down

0 comments on commit 1a881c9

Please # to comment.