


Méthodes de traitement de l'idempotence des messages et de la déduplication des données de la technologie de file d'attente dans PHP et MySQL
Méthodes d'idempotence des messages et de déduplication des données à l'aide de la technologie de file d'attente dans PHP et MySQL
Introduction :
Avec le développement rapide d'Internet, le nombre de sites Web et d'applications simultanés continue d'augmenter, ainsi que pour le stockage et le traitement des données. Les exigences en matière d'efficacité sont également de plus en plus élevées. La technologie de file d'attente est devenue l'un des outils importants pour résoudre les problèmes de traitement des données dans des scénarios à forte concurrence. Cet article présentera comment utiliser la technologie de file d'attente pour implémenter l'idempotence des messages et la déduplication des données dans PHP et MySQL, et fournira des exemples de code correspondants.
1. Introduction à la technologie des files d'attente
La file d'attente est une structure de données commune qui suit le principe du premier entré, premier sorti (FIFO). Dans les applications, les files d'attente sont utilisées pour résoudre des problèmes tels que le traitement asynchrone et la planification des tâches. Les technologies de file d'attente courantes incluent la file d'attente de messages, la file d'attente de tâches, etc.
2. Comment gérer l'idempotence des messages
Dans les scénarios à forte concurrence, le même message peut être traité plusieurs fois. Afin de garantir l'exactitude des données, l'idempotence du message doit être assurée. L'idempotence signifie que peu importe le nombre de fois où la même opération est effectuée, le résultat est le même.
- Générer un identifiant unique
UUID (Universally Unique Identifier) peut être utilisé en PHP pour générer des identifiants uniques. L'UUID fait référence à un numéro généré sur une machine et est unique au monde.
function generateUniqueId(){ if (function_exists('uuid_create')) { $objUuid = uuid_create(UUID_TYPE_RANDOM); $strUuid = uuid_export($objUuid); } else { $strUuid = sprintf('%04x%04x-%04x-%04x-%04x-%04x%04x%04x', mt_rand(0, 0xffff), mt_rand(0, 0xffff), mt_rand(0, 0xffff), mt_rand(0, 0x0fff) | 0x4000, mt_rand(0, 0x3fff) | 0x8000, mt_rand(0, 0xffff), mt_rand(0, 0xffff), mt_rand(0, 0xffff) ); } return $strUuid; }
- Déduplication du message
Avant de traiter le message, vous pouvez réaliser la déduplication du message en stockant l'identifiant unique du message dans une table MySQL et en définissant un index unique. Vous trouverez ci-dessous un exemple de structure de table MySQL.
CREATE TABLE `message_table` ( `id` int(11) NOT NULL AUTO_INCREMENT, `message_id` varchar(255) NOT NULL, `payload` text NOT NULL, PRIMARY KEY (`id`), UNIQUE KEY `uniq_index` (`message_id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
Avant de traiter le message, interrogez d'abord la table MySQL pour déterminer si le message existe déjà. S'il n'existe pas, effectuez le traitement des données. S'il existe déjà, renvoyez directement le succès.
$strMessageId = generateUniqueId(); $objDb = new PDO('mysql:host=localhost;dbname=test', 'username', 'password'); $strQuery = "INSERT IGNORE INTO message_table (message_id, payload) VALUES (:message_id, :payload)"; $objStmt = $objDb->prepare($strQuery); $objStmt->bindParam(':message_id', $strMessageId, PDO::PARAM_STR); $objStmt->bindParam(':payload', $strPayload, PDO::PARAM_STR); $objStmt->execute(); if ($objStmt->rowCount() == 1) { // 数据处理逻辑 // ... echo "处理成功"; } else { echo "消息已经存在"; }
3. Résumé
Grâce à la technologie de file d'attente, nous pouvons atteindre l'idempotence des messages et la déduplication des données. La génération d'un identifiant unique garantit que le message est globalement unique, tandis que l'utilisation d'un index unique sur la table permet la déduplication. Dans les applications pratiques, il peut être ajusté et optimisé en fonction des besoins spécifiques de l'entreprise.
La longueur de l'article est limitée.Cet article ne présente que brièvement les principes de base de l'idempotence des messages et des méthodes de traitement de déduplication des données de la technologie de file d'attente dans PHP et MySQL, et fournit des exemples de code pertinents. J'espère que cela sera utile aux lecteurs et vous permettra de mieux utiliser la technologie de file d'attente pour résoudre les problèmes de concurrence dans les applications réelles.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

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

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

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

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

Sujets chauds

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.

L'un des changements majeurs introduits dans MySQL 8.4 (la dernière version LTS en 2024) est que le plugin « MySQL Native Password » n'est plus activé par défaut. De plus, MySQL 9.0 supprime complètement ce plugin. Ce changement affecte PHP et d'autres applications

Visual Studio Code, également connu sous le nom de VS Code, est un éditeur de code source gratuit – ou environnement de développement intégré (IDE) – disponible pour tous les principaux systèmes d'exploitation. Avec une large collection d'extensions pour de nombreux langages de programmation, VS Code peut être c

Ce tutoriel montre comment traiter efficacement les documents XML à l'aide de PHP. XML (Language de balisage extensible) est un langage de balisage basé sur le texte polyvalent conçu à la fois pour la lisibilité humaine et l'analyse de la machine. Il est couramment utilisé pour le stockage de données et

Une chaîne est une séquence de caractères, y compris des lettres, des nombres et des symboles. Ce tutoriel apprendra à calculer le nombre de voyelles dans une chaîne donnée en PHP en utilisant différentes méthodes. Les voyelles en anglais sont a, e, i, o, u, et elles peuvent être en majuscules ou en minuscules. Qu'est-ce qu'une voyelle? Les voyelles sont des caractères alphabétiques qui représentent une prononciation spécifique. Il y a cinq voyelles en anglais, y compris les majuscules et les minuscules: a, e, i, o, u Exemple 1 Entrée: String = "TutorialSpoint" Sortie: 6 expliquer Les voyelles dans la chaîne "TutorialSpoint" sont u, o, i, a, o, i. Il y a 6 yuans au total

Si vous êtes un développeur PHP expérimenté, vous aurez peut-être le sentiment d'y être déjà allé et de l'avoir déjà fait. Vous avez développé un nombre important d'applications, débogué des millions de lignes de code et peaufiné de nombreux scripts pour réaliser des opérations.

CMS signifie Système de gestion de contenu. Il s'agit d'une application logicielle ou d'une plate-forme qui permet aux utilisateurs de créer, gérer et modifier du contenu numérique sans nécessiter de connaissances techniques avancées. Le CMS permet aux utilisateurs de créer et d'organiser facilement du contenu tel que du texte, des images, des vidéos et des documents, et de le publier sur des sites Web ou d'autres plateformes numériques.

Les tableaux sont des structures de données linéaires utilisées pour traiter les données dans la programmation. Parfois, lorsque nous traitons les tableaux, nous devons ajouter de nouveaux éléments au tableau existant. Dans cet article, nous discuterons de plusieurs façons d'ajouter des éléments à la fin d'un tableau en PHP, avec des exemples de code, une sortie et une analyse de complexité du temps et de l'espace pour chaque méthode. Voici les différentes façons d'ajouter des éléments à un tableau: Utilisez des crochets [] En PHP, la façon d'ajouter des éléments à la fin d'un tableau est d'utiliser des crochets []. Cette syntaxe ne fonctionne que dans les cas où nous ne voulons ajouter qu'un seul élément. Ce qui suit est la syntaxe: $ array [] = valeur; Exemple
