Heim > Datenbank > Redis > Hauptteil

Wie Redis den Lastausgleich implementiert

silencement
Freigeben: 2019-06-06 16:44:20
Original
8790 Leute haben es durchsucht

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);
        }
    }

}
Nach dem Login kopieren

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!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!