Heim  >  Artikel  >  Datenbank  >  Wie Redis den Lastausgleich implementiert

Wie Redis den Lastausgleich implementiert

silencement
silencementOriginal
2019-06-06 16:44:208729Durchsuche

Wie Redis den Lastausgleich implementiert

Redis-Lastausgleich

Wenn in Webprojekten eine hohe Parallelität auftritt, kann dies durch den Lastausgleichsmechanismus von Redis gehandhabt werden Ein Lastausgleichsmodus

Redis-Slot-Zuweisungsmechanismus:

In der offiziellen Cluster-Lösung von Redis werden Daten nach Slots zugewiesen und der Schlüssel jeder Daten wird einem Slot zugeordnet Die Hash-Funktion sieht insgesamt 16384 Slots vor. Dies kann natürlich nach den Vorlieben des Benutzers konfiguriert werden. Wenn der Benutzer Daten einfügt oder abruft, sucht er zuerst nach dem Slot, der den Daten entspricht, sucht dann nach dem entsprechenden Knoten und fügt dann die Daten in den Knoten ein. Auf diese Weise werden die Daten gleichmäßig auf jeden Knoten im Cluster verteilt, wodurch ein Lastausgleich auf jedem Knoten erreicht wird und die Leistung des Clusters voll ausgenutzt wird. (Redis-Tutorial)

public static void main(String[] args) {
        List<JedisShardInfo> shards = new ArrayList<JedisShardInfo>();
        shards.add(new JedisShardInfo("127.0.0.1", 6379));
        shards.add(new JedisShardInfo("127.0.0.1", 6380));

        ShardedJedisPool sjp = new ShardedJedisPool(new JedisPoolConfig(), shards);
        ShardedJedis shardClient = sjp.getResource();
        try {
            shardClient.set("A", "123");
            shardClient.set("B", "234");
            shardClient.set("C", "345");

            try {
                System.out.println(shardClient.get("A"));
            } catch (Exception e) {
                e.printStackTrace();
            }

            try {
                System.out.println(shardClient.get("B"));
            } catch (Exception e) {
                e.printStackTrace();
            }

            try {
                System.out.println(shardClient.get("C"));
            } catch (Exception e) {
                e.printStackTrace();
            }
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            sjp.returnResource(shardClient);
        }
    }

}

Das obige ist der detaillierte Inhalt vonWie Redis den Lastausgleich implementiert. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn