MySQL - PHP-Parallelit?tsverarbeitung?
Aug 04, 2016 am 09:20 AM
Ich m?chte eine Zahlungsschnittstelle für Drittanbieter erstellen, befürchte jedoch, dass es bei der Auftragserteilung zu Parallelit?t kommen k?nnte.
<code><?php $fp = fopen('test.txt', 'r'); $try = 10; do{ $lock = flock($fp,LOCK_EX);//獨(dú)占鎖 //沒(méi)有獲得鎖釋放cpu重新獲取 if(!lock){ usleep(50000); //0.05 } }while(!$lock && --$try > 0); if($lock){ /***********拿到鎖的用戶執(zhí)行********/ //在這里生成訂單號(hào),寫入數(shù)據(jù)庫(kù), 跳轉(zhuǎn)到支付頁(yè)面..... flock($fp,LOCK_UN); fclose($fp); }else{ fclose($fp); die("系統(tǒng)繁忙,稍后再試"); }</code>
Ich habe den obigen Code im Internet gefunden und ihn ge?ndert. Ich habe immer das Gefühl, dass er etwas schwach ist. Ich wei? nicht, ob er funktionieren wird oder ob Sie bessere Vorschl?ge haben?
Antwortinhalt:
Ich m?chte eine Zahlungsschnittstelle für Drittanbieter erstellen, befürchte jedoch, dass es bei der Auftragserteilung zu Parallelit?t kommen k?nnte.
<code><?php $fp = fopen('test.txt', 'r'); $try = 10; do{ $lock = flock($fp,LOCK_EX);//獨(dú)占鎖 //沒(méi)有獲得鎖釋放cpu重新獲取 if(!lock){ usleep(50000); //0.05 } }while(!$lock && --$try > 0); if($lock){ /***********拿到鎖的用戶執(zhí)行********/ //在這里生成訂單號(hào),寫入數(shù)據(jù)庫(kù), 跳轉(zhuǎn)到支付頁(yè)面..... flock($fp,LOCK_UN); fclose($fp); }else{ fclose($fp); die("系統(tǒng)繁忙,稍后再試"); }</code>
Ich habe den obigen Code im Internet gefunden und ihn ge?ndert. Ich habe immer das Gefühl, dass er etwas schwach ist. Ich wei? nicht, ob er funktionieren wird oder ob Sie bessere Vorschl?ge haben?
Sie k?nnen die atomare Zeilenoperation von Redis verwenden, um das Sperren zu implementieren und einen Schlüssel als Markierung festzulegen.
Sie k?nnen dazu nmq verwenden.
Das Poster fügt eine exklusive Sperre über eine Datei hinzu. Bedeutet dies, dass bei jeder Bestellung zuerst die Sperre abgerufen und dann die Bestellung erstellt wird? Bei einer Serienoperation kann das TPS für die Bestellung erb?rmlich sein
Der Autor erw?hnte die Parallelit?t, weil der Benutzer zweimal auf die Bestellschaltfl?che geklickt hat, was zu wiederholten Bestellungen führte. Wenn ja, gibt es viele L?sungen für dieses Szenario? Welche garantierte Idempotenz kann Ihr Problem sein? gel?st werden durch
requestId/token
Es ist nicht erforderlich, eine Sperre im Programm festzulegen. Erstellen Sie einfach einen eindeutigen Index in der Datenbank, damit die Leistung optimal ist.
Redis-Sperre verwenden
swoole mysql

Hei?e KI -Werkzeuge

Undress AI Tool
Ausziehbilder kostenlos

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

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

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

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

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Vermeiden Sie N 1 Abfrageprobleme, reduzieren Sie die Anzahl der Datenbankabfragen, indem Sie die zugeh?rigen Daten im Voraus laden. 2. W?hlen Sie nur die erforderlichen Felder aus, um das Laden vollst?ndiger Entit?ten zu vermeiden, um Speicher und Bandbreite zu sparen. 3.. Verwenden Sie Cache-Strategien vernünftigerweise, z. 4. Optimieren Sie den Lebenszyklus der Entit?t und rufen Sie Clear () regelm??ig an, um den Speicher freizugeben, um den Speicherüberlauf zu verhindern. 5. Stellen Sie sicher, dass der Datenbankindex die generierten SQL -Anweisungen existiert und analysiert, um ineffiziente Abfragen zu vermeiden. 6. Deaktivieren Sie die automatische ?nderungsverfolgung in Szenarien, in denen ?nderungen nicht erforderlich sind, und verwenden Sie Arrays oder Leichtgewichtsmodi, um die Leistung zu verbessern. Die korrekte Verwendung von ORM erfordert die Kombination der SQL -überwachung, -gespeicherung, der Stapelverarbeitung und der geeigneten Optimierung, um die Anwendungsleistung zu gew?hrleisten und gleichzeitig die Entwicklungseffizienz beizubehalten.

Die Datei "Settings.JSON" befindet sich auf dem Pfad auf Benutzerebene oder Arbeitsbereichsebene und wird verwendet, um die VSCODE-Einstellungen anzupassen. 1. Benutzer-Level-Pfad: Windows ist C: \ Benutzer \\ AppData \ Roaming \ Code \ User \ Settings.json, MacOS is /users//library/applicationsupport/code/user/settings.json, Linux is /home/.config/code/usser/setings.json; 2. Pfad auf Arbeitsbereichsebene: .VSCODE/Einstellungen im Projekt Root Directory

Der Müllsammlung von PHP basiert auf der Referenzz?hlung, aber kreisf?rmige Referenzen müssen von einem periodischen kreisf?rmigen Müllsammler verarbeitet werden. 1. Die Referenzzahl gibt den Speicher sofort frei, wenn keine Referenz auf die Variable vorhanden ist. 2. Referenzreferenz bewirkt, dass Speicher nicht automatisch freigegeben werden kann, und es h?ngt davon ab, dass GC ihn erfasst und reinigt. 3.. GC wird ausgel?st, wenn das "m?gliche Wurzel" den Schwellenwert erreicht oder manuell gc_collect_cycles () aufruft; 4. Langzeit laufende PHP-Anwendungen sollten gc_status () überwachen und rechtzeitig gc_collect () aufrufen, um Speicherleckage zu vermeiden. 5. Zu den Best Practices geh?rt die Vermeidung von kreisf?rmigen Referenzen, die Verwendung von gc_disable () zur Optimierung der Leistungsschlüsselbereiche und Dereference -Objekte über die Clear () -Methode des ORM.

Mit Bref erm?glicht es PHP-Entwicklern, skalierbare, kostengünstige Anwendungen zu erstellen, ohne Server zu verwalten. 1.Bref bringt Php nach AWSLambda, indem er eine optimierte PHP -Laufzeitschicht bereitstellt, Php8.3 und andere Versionen unterstützt und sich nahtlos in Frameworks wie Laravel und Symfony integriert. 2.. 3. Führen Sie den Befehl ServerlessDeploy aus, um die Bereitstellung abzuschlie?en, apiCateway automatisch zu konfigurieren und Zugriffs -URLs zu generieren. 4. Für Lambda -Beschr?nkungen bietet BREF L?sungen.

ReadOmpropertiesinphp8.2canonlyBeSignedoncinstructororatDeklarationandCannotBemodifiedAfterward, durchsetzungsvermutbarkeitatheluagelevel.2.ToachedevimmiMmutability, WrapMutabletypesLikearrayObjecustomimmutablecollections

Verwenden Sie zun?chst JavaScript, um die Einstellungen für Benutzersysteme und lokal gespeicherte Themeneinstellungen zu erhalten und das Seitenthema zu initialisieren. 1. Die HTML -Struktur enth?lt eine Schaltfl?che zum Ausl?sen von Themenwechsel. 2. CSS verwendet: root, um helle Themenvariablen zu definieren, .Dark-Mode-Klasse definiert dunkle Themenvariablen und wendet diese Variablen über var () an. 3.. JavaScript erkennt bevorzuge-farbige Scheme und liest LocalStorage, um das ursprüngliche Thema zu bestimmen. 4. Schalten Sie die Dark-Mode-Klasse im HTML-Element beim Klicken auf die Schaltfl?che und speichern Sie den aktuellen Status vor LocalStorage. 5. Alle Farb?nderungen werden mit einer übergangsanimation von 0,3 Sekunden begleitet, um den Benutzer zu verbessern

Verwenden Sie Leistungsanalyse-Tools, um Engp?sse zu lokalisieren, VisualVM oder JProfiler in der Entwicklung und Testphase zu verwenden und Async-Profiler in der Produktionsumgebung Priorit?t zu geben. 2. Reduzieren Sie die Objekterstellung, verwenden Sie Objekte wieder, verwenden Sie StringBuilder, um String -Splei?en zu ersetzen und entsprechende GC -Strategien auszuw?hlen. 3.. Optimieren Sie die Auswahl der Sammlung, w?hlen Sie die Anfangskapazit?t gem?? der Szene aus; V. 5. Tune JVM-Parameter, festlegen, angemessene Haufengr??e und Müllsammler mit geringer Latenz einstellen und GC-Protokolle aktivieren; 6. Vermeiden Sie die Reflexion auf Codeebene, ersetzen Sie Wrapper -Klassen durch Grundtypen, Verz?gerungsinitialisierung und verwenden Sie endgültige und statische. 7. Kontinuierliche Leistungstest und überwachung, kombiniert mit JMH

UseGuzzleForrobUtttprequestswithheaderStimeouts.2.ParsehtmleffictionLyWithSymfonydomcrawleruSusectors.3.HandlejavaScript-HeavysitesByintegratingPuppeteerviaPexec () torenderpages.4.respactroboBoBoBoBoThoter- und addDelays, addDelays, rotdelayents, rotateuseragents und rotateuseragents und ushEdelays, usaDelays, rot
