Cache-Aufschlüsselung
Anders als die Cache-Penetration bezieht sich die Cache-Aufschlüsselung auf heiße Daten, die sich nicht im Cache, sondern in der Datenbank befinden.
Zum Beispiel: Heiße Nachrichten auf der Homepage, heiße Daten mit einer sehr großen Anzahl gleichzeitiger Besuche. Wenn der Cache abläuft und ausfällt, fragt der Server zu diesem Zeitpunkt die Datenbank ab Wenn gleichzeitig Anfragen an die Datenbank gestellt werden, kann es sein, dass diese sofort überlastet ist.
Zeichne ein einfaches Diagramm, wie unten gezeigt:
Lösung: DB-Abfrage plus verteilte Sperre #🎜 🎜#.
Entsperrte SituationBevor Sie das Problem lösen, werfen Sie zunächst einen Blick auf den unverarbeiteten Code und die Funktionsweise.Produktdetailcode basierend auf der Produkt-ID abfragen
Wir gehen davon aus, dass die Datenbank nur einmal abgefragt wird. und die nächsten vier Abfragen werden aus dem Redis-Cache abgerufen, aber das Ergebnis ist: Es wird auch keine verteilte Sperre hinzugefügt, aber dieser Container wird gesetzt Großer Druck auf die DB.
Wenn es sich um einen einzelnen Server handelt, verwenden Sie einfach direkt die Synchronisierungssperre von Java
Redis verteilte Sperre behebt Cache-Ausfälle
Die in Java integrierte Sperre kann nur auf einer einzelnen Maschine angewendet und nicht verteilt werden,
Das können Sie Verwenden Sie Redis, um verteilte Sperren zu implementieren.
Code nach dem Hinzufügen einer verteilten Sperre//根据ID查询商品
@GetMapping("/{id}")
public R id(@PathVariable String id){
//先查Redis缓存
Object o = redisTemplate.opsForValue().get(id);
if (o != null) {
//命中缓存
System.err.println("id:"+id+",命中redis缓存...");
return R.success(o);
}
//缓存未命中 查询数据库
String lockKey = "lock" + id;
//加锁,10s后过期
for (;;) {
if (redisTemplate.opsForValue().setIfAbsent(lockKey, System.currentTimeMillis(), 10L, TimeUnit.SECONDS)) {
//加锁成功的线程,再次检查
o = redisTemplate.opsForValue().get(id);
if (o != null) {
//命中缓存
System.err.println("Thread:" + Thread.currentThread().getName() + ",id:"+id+",命中redis缓存...");
//释放锁
redisTemplate.delete(lockKey);
return R.success(o);
}
//仍未命中
System.err.println("Thread:" + Thread.currentThread().getName() + ",id:" + id + ",查询DB...");
Goods goods = goodsMapper.selectById(id);
//结果存入Redis
redisTemplate.opsForValue().set(id, goods);
//释放锁
redisTemplate.delete(lockKey);
return R.success(goods);
}
//竞争不到锁,暂时让出CPU资源
Thread.yield();
}
}
Das obige ist der detaillierte Inhalt vonWie die verteilte Redis-Sperre einen Cache-Ausfall verhindert. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

RedisoffersSuperiorSpeedfordataoperationsbutRequiressignificantramandinvolvestrade-offSindatapersistensCalability.1) Itsiein-MemorynatureProvidesultra-Fastread/Writeoperations, Idealforreal-TimeApplikationen.2)

RedisoutPerformStraditionaldatabaseSinspeedforRead/WriteoperationsDuetoitsin-Memorynatur, whileTraditionaldatabasexcelcomplexqueriesanddataintegrity.1) Redisissidealforreal-Timalytics und Offeringphenomenalperformance.2) TraditionaldataSticaStics und Offeringphenomenalperformance

UsedisinSteadofatitionaldatabaseWenyourApplicationRequiresspeedandreal-Timedataprocessing, Suchasforcaching, SessionManagement, Orreal-Timalytics.Rectisexcelsin: 1) Caching, ReducingloadonPimarydatabase;

Redis geht aufgrund seiner hohen Leistung und Flexibilität über die SQL -Datenbanken hinaus. 1) Redis erreicht extrem schnelle Lesen und Schreiben von Geschwindigkeit über Speicherspeicher. 2) Es unterstützt eine Vielzahl von Datenstrukturen wie Listen und Sammlungen, die für die komplexe Datenverarbeitung geeignet sind. 3) Einfach-Thread-Modell vereinfacht die Entwicklung, aber eine hohe Parallelität kann zu einem Engpass werden.

Redis ist traditionellen Datenbanken in hoher Parallelitäts- und Latenz -Szenarien überlegen, ist jedoch nicht für komplexe Abfragen und Transaktionsverarbeitung geeignet. 1.Redis verwendet Speicherspeicher-, Schnelllese- und Schreibgeschwindigkeit, geeignet für Anforderungen an eine hohe Parallelität und niedrige Latenz. 2. Traditionelle Datenbanken basieren auf Festplatten, unterstützen komplexe Abfragen und Transaktionsverarbeitung und haben eine starke Datenkonsistenz und -dauer. 3.. Redis ist als Ergänzung oder Ersatz für herkömmliche Datenbanken geeignet, muss jedoch nach bestimmten Geschäftsbedürfnissen ausgewählt werden.

Redisisahigh-Performancein-MemoryDatastructurestorethatexcelsinSpeedandversatility.1) IssupportsvariousDatastructureslikestrings, Listen und Sets

Redis ist in erster Linie eine Datenbank, aber mehr als nur eine Datenbank. 1. Als Datenbank unterstützt Wiedererlangung die Persistenz und eignet sich für leistungsstarke Bedürfnisse. 2. Als Cache verbessert Redis die Reaktionsgeschwindigkeit der Anwendung. 3. Als Message Broker unterstützt Redis den Veröffentlichungs-Subscribe-Modus, der für die Echtzeitkommunikation geeignet ist.

RedisisamultifacetedtoolthatervesaSadatabase, Server, und More.itfunctionsasanin-MemoryDatastructurestore, SupportSVariousDatastructures und Canbusesedasacache, MessageBroker, SessionStorage und ForforbutedLocking.


Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

Sicherer Prüfungsbrowser
Safe Exam Browser ist eine sichere Browserumgebung für die sichere Teilnahme an Online-Prüfungen. Diese Software verwandelt jeden Computer in einen sicheren Arbeitsplatz. Es kontrolliert den Zugriff auf alle Dienstprogramme und verhindert, dass Schüler nicht autorisierte Ressourcen nutzen.

WebStorm-Mac-Version
Nützliche JavaScript-Entwicklungstools

Dreamweaver CS6
Visuelle Webentwicklungstools

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

MantisBT
Mantis ist ein einfach zu implementierendes webbasiertes Tool zur Fehlerverfolgung, das die Fehlerverfolgung von Produkten unterstützen soll. Es erfordert PHP, MySQL und einen Webserver. Schauen Sie sich unsere Demo- und Hosting-Services an.
