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!