Die Parallelitätskontrollstrategie im PHP-Flash-Sale-System erfordert spezifische Codebeispiele
Mit der rasanten Entwicklung des Internets und des E-Commerce sind Flash-Sale-Aktivitäten zu einem der wichtigsten Mittel für große Plattformen geworden, um Benutzer anzulocken. Der hohe gleichzeitige Zugriff auf Flash-Verkaufsaktivitäten stellt jedoch eine große Herausforderung dar, da bei Flash-Verkaufsaktivitäten die Anzahl der Produkte begrenzt ist, aber viele Benutzer am Eilkauf teilnehmen. Wenn die Parallelität zu groß ist, kann das System leicht abstürzen, was dazu führt, dass Benutzer nicht in der Lage sind, reibungslos an Aktivitäten teilzunehmen. In diesem Fall ist die Steuerung der Parallelität und die Gewährleistung eines stabilen Betriebs des Systems zu einer Kerntechnologie des PHP-Flash-Killing-Systems geworden.
Im PHP-Flash-Sale-System können gängige Parallelitätskontrollstrategien in zwei Typen unterteilt werden: Eine ist eine datenbankbasierte pessimistische Sperr- und Parallelitätskontrollstrategie, die andere ist eine Cache-basierte optimistische Sperr- und Parallelitätskontrollstrategie.
<?php $db = new PDO('mysql:host=localhost;dbname=test', 'root', ''); // 开始事务 $db->beginTransaction(); try { $stmt = $db->prepare('SELECT * FROM goods WHERE id = 1 FOR UPDATE'); $stmt->execute(); $result = $stmt->fetch(PDO::FETCH_ASSOC); if ($result['stock'] > 0) { $stmt = $db->prepare('UPDATE goods SET stock = stock - 1 WHERE id = 1'); $stmt->execute(); // 提交事务 $db->commit(); echo '秒杀成功!'; } else { echo '商品已售罄!'; } } catch (Exception $e) { // 回滚事务 $db->rollBack(); echo '秒杀失败!'; } ?>
-Anweisung zum Sperren und Abfragen des Produktbestands verwendet. Wenn der Lagerbestand größer als 0 ist, führen Sie den Vorgang zur Lagerbestandsreduzierung durch und senden Sie die Transaktion ab. Andernfalls wird die Transaktion zurückgesetzt, was darauf hinweist, dass der Flash-Sale fehlgeschlagen ist. SELECT...FOR UPDATE
<?php $redis = new Redis(); $redis->connect('localhost', 6379); $stock = $redis->get('goods_stock'); if ($stock > 0) { $redis->multi(); $redis->decr('goods_stock'); $result = $redis->exec(); if ($result) { echo '秒杀成功!'; } else { echo '秒杀失败!'; } } else { echo '商品已售罄!'; } ?>
Das obige ist der detaillierte Inhalt vonParallelitätskontrollstrategie im PHP-Flash-Kill-System. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!