Table des matières
回复内容:
Maison développement back-end tutoriel php 秒杀场景下 如何保证数据准确

秒杀场景下 如何保证数据准确

Jun 06, 2016 pm 08:30 PM
php 并发 秒杀

秒杀时 商品价格递增,比如第一个买的两百,第二个买的三百,第三个四百以此类推,同时修改库存等其他表

在更新的时候防止超卖等问题我用的是行锁,插入的时候为了确保数据准确使用了唯一索引 但是带来的问题是秒杀成功率低

请问在插入或者更新的时候如何保证数据的准确性与完整性和相对较高的处理效率,因为之前没做过类似应用 希望大家能给出思路

回复内容:

秒杀时 商品价格递增,比如第一个买的两百,第二个买的三百,第三个四百以此类推,同时修改库存等其他表

在更新的时候防止超卖等问题我用的是行锁,插入的时候为了确保数据准确使用了唯一索引 但是带来的问题是秒杀成功率低

请问在插入或者更新的时候如何保证数据的准确性与完整性和相对较高的处理效率,因为之前没做过类似应用 希望大家能给出思路

秒杀自古只有一个问题:

机器与程序性能是否能支撑住秒杀业务。

能撑住就随便玩,撑不住,那就使用各种【优化】:

1.秒杀前,对参与秒杀的用户进行登记,不登记的无法秒杀。
登记的作用是,筛选出参与秒杀的用户,一般这个量比较少,把他们的数据放入专用表里,可以提高检索速度。

2.使用C或C++写的高速队列来为后端数据库减压,同时也容易保证数据的正确性。

3.使用分时算法,也就是5秒内,数据库以日志的形式,写入所有人的秒杀数据,此时数据库不能进行其他任何操作,比如查结果。5秒后,关闭写入,此时对日志进行去重、合法性判断等操作,这个过程中数据库同样不能进行其他任何操作,比如写入秒杀日志。这些操作进行完毕后,向客户端返回秒杀结果。接着,再进行5秒钟的秒杀日志写入操作。这种方法,在参与人数远远大于商品数量的时候,特别有效。

可以适当修改秒杀流程,分成两部分:
1、只插入秒杀数据,并在一定时间后停止秒杀(也可能有比实际库存多的记录进来)。该流程只告诉用户提交成功,但是不告诉其准确结果;
2、有一个后台进程,根据秒杀记录及库存来评判其是否成功,以及对应的价格,并更新库存。该流程结束后,用户在秒杀记录里边可以查看最后的结果。

这样做的好处是,不会引发并发问题,能保证数据准确性,用户也能在较短时间内获知到秒杀结果。

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Où trouver la courte de la grue à atomide atomique
1 Il y a quelques semaines By DDD

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Configuration du projet CakePHP Configuration du projet CakePHP Sep 10, 2024 pm 05:25 PM

Dans ce chapitre, nous comprendrons les variables d'environnement, la configuration générale, la configuration de la base de données et la configuration de la messagerie dans CakePHP.

Guide d'installation et de mise à niveau de PHP 8.4 pour Ubuntu et Debian Guide d'installation et de mise à niveau de PHP 8.4 pour Ubuntu et Debian Dec 24, 2024 pm 04:42 PM

PHP 8.4 apporte plusieurs nouvelles fonctionnalités, améliorations de sécurité et de performances avec une bonne quantité de dépréciations et de suppressions de fonctionnalités. Ce guide explique comment installer PHP 8.4 ou mettre à niveau vers PHP 8.4 sur Ubuntu, Debian ou leurs dérivés. Bien qu'il soit possible de compiler PHP à partir des sources, son installation à partir d'un référentiel APT comme expliqué ci-dessous est souvent plus rapide et plus sécurisée car ces référentiels fourniront les dernières corrections de bogues et mises à jour de sécurité à l'avenir.

Date et heure de CakePHP Date et heure de CakePHP Sep 10, 2024 pm 05:27 PM

Pour travailler avec la date et l'heure dans cakephp4, nous allons utiliser la classe FrozenTime disponible.

CakePHP travaillant avec la base de données CakePHP travaillant avec la base de données Sep 10, 2024 pm 05:25 PM

Travailler avec la base de données dans CakePHP est très simple. Nous comprendrons les opérations CRUD (Créer, Lire, Mettre à jour, Supprimer) dans ce chapitre.

Téléchargement de fichiers CakePHP Téléchargement de fichiers CakePHP Sep 10, 2024 pm 05:27 PM

Pour travailler sur le téléchargement de fichiers, nous allons utiliser l'assistant de formulaire. Voici un exemple de téléchargement de fichiers.

Routage CakePHP Routage CakePHP Sep 10, 2024 pm 05:25 PM

Dans ce chapitre, nous allons apprendre les sujets suivants liés au routage ?

Discuter de CakePHP Discuter de CakePHP Sep 10, 2024 pm 05:28 PM

CakePHP est un framework open source pour PHP. Il vise à faciliter grandement le développement, le déploiement et la maintenance d'applications. CakePHP est basé sur une architecture de type MVC à la fois puissante et facile à appréhender. Modèles, vues et contrôleurs gu

CakePHP créant des validateurs CakePHP créant des validateurs Sep 10, 2024 pm 05:26 PM

Le validateur peut être créé en ajoutant les deux lignes suivantes dans le contrôleur.

See all articles