


Wie kann eine HTTP-Anfrage bei hoher Parallelität die absolute Anzahl der aktuellen Anfrage zurückgeben?
Zum Beispiel hat meine erste Zugriffsanfrage json zurückgegeben: {"n": 1}
Meine 100. Zugriffsanfrage gibt json zurück: {"n": 100}
Die herkömmliche Methode, in die Datenbank zu schreiben und dann die Datenbank zu überprüfen, um die Ergebnisse zurückzugeben, scheint nicht garantiert zu sein, wenn die Parallelität groß ist. Was soll ich tun? Dies sollte die einfachste Frage sein
Antwortinhalt:
Zum Beispiel hat meine erste Zugriffsanfrage json zurückgegeben: {"n": 1}
Meine 100. Zugriffsanfrage gibt json zurück: {"n": 100}
Die herkömmliche Methode, in die Datenbank zu schreiben und dann die Datenbank zu überprüfen, um die Ergebnisse zurückzugeben, scheint nicht garantiert zu sein, wenn die Parallelität groß ist. Was soll ich tun? Dies sollte die einfachste Frage sein
Die einfachste Methode besteht darin, eine MySQL-Tabelle mit einem automatisch inkrementierten Primärschlüssel der ID zu erstellen, dann für jede Anfrage einen Datensatz einzufügen und dann den Datensatz zu lesen. Die gelesene ID ist der gewünschte Wert.
Dann können Sie Szenarien mit hoher Parallelität basierend auf dem ID-Wert problemlos bewältigen. Beispielsweise kann [Instant Kill] die Regel verwenden, dass die ID kleiner als 300 und durch 6 teilbar ist, um den Instant Kill als erfolgreich zu betrachten. kann die Regel verwenden, dass die ID kleiner als 300 ist und durch 6 teilbar ist, um den sofortigen Kill als erfolgreich zu betrachten;
Wenn Sie es selbst implementieren, ist es nichts weiter als eine Single-Threaded-Endlosschleife, die Socket-Anfragen verarbeitet und eine globale Variable verwaltet. Es ist nicht so bequem und zuverlässig wie die Verwendung von vorgefertigtem MySQL.
Wenn es java
ist, kann ein globaler AtomicLong
Ihre Anforderungen erfüllen, getAndIncrement
atomare Operation plus volatile
Modifikation. Wenn es sich um andere Sprachen handelt, ist es ähnlich
Mit setnx(id) in Redis garantiert der einzelne Thread jedes Mal eine Inkrementierung um 1, und es handelt sich außerdem um eine In-Memory-Datenbank, die superschnell ist.
Lesevorgang: Cache verwenden
Schreibvorgang: asynchrones Schreiben mithilfe der Warteschlange
In reinem Java können Sie das Zählerobjekt zu einem Singleton machen und alle Anfragen abfangen, den Rechner bis filter
um 1 zu erhöhen (erfordert Synchronisierung). Ich weiß nicht, was Sie mit Datenbank meinen. {n : 100}
, n
stammen aus der Datenbank?
Eigentlich möchten Sie eine speicherresidente Warteschlange erstellen, die entsprechend der Anforderung in die Warteschlange gestellt wird.
Auf einem einzelnen Computer können Sie versuchen, SQLite in /dev/shm in der Linux-Speicherdatei zu lesen und zu schreiben System (tmpfs).
Das Lesen von Dateien erfordert nicht den Umweg über das Netzwerk, und es besteht keine Notwendigkeit, speicherresidente, Sperren, automatische Inkrementierung und eindeutige Einschränkungen zu implementieren
<code><?php header('Content-Type: text/plain; charset=utf-8'); // sudo mkdir -m 777 /dev/shm/app $file = '/dev/shm/app/data.db3'; $ddl = " BEGIN; CREATE TABLE IF NOT EXISTS queue ( id INTEGER PRIMARY KEY AUTOINCREMENT, user_id INTEGER ); CREATE UNIQUE INDEX IF NOT EXISTS queue_user_id_idx ON queue(user_id); COMMIT; "; if(!file_exists($file)) { //多核下多进程并发时可能都会进入到这个判断分支,所以DDL中要用IF NOT EXISTS $db = new PDO('sqlite:'.$file); $db->exec($ddl); // pdo_sqlite 的 query 和 prepare 不支持一次执行多条SQL语句 } else { $db = new PDO('sqlite:'.$file); } $stmt = $db->prepare('INSERT INTO queue(user_id) VALUES(?)'); $stmt->execute(array(time())); //time()换成你的用户ID echo $stmt->rowCount()."\n"; //查询中受影响(改动)的行数,插入失败时为0 echo $db->lastInsertId(); //插入的自增ID,插入失败时为0 // php -S 127.0.0.1:8080 -t /home/eechen/www >/dev/null 2>&1 & // ab -c100 -n1000 http://127.0.0.1:8080/</code>
Am einfachsten ist es, das Zset von Redis für die automatische Inkrementierung zu verwenden, was effizient und einfach ist. Wenn Sie eine einzelne Maschine verwenden, können Sie auch die Verwendung von atomiclong in Betracht ziehen (es wird nach dem Herunterfahren und Neustarten ungültig)

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

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

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)

Heiße Themen



MySQL ist für Anfänger geeignet, da es einfach zu installieren, leistungsfähig und einfach zu verwalten ist. 1. Einfache Installation und Konfiguration, geeignet für eine Vielzahl von Betriebssystemen. 2. Unterstützung grundlegender Vorgänge wie Erstellen von Datenbanken und Tabellen, Einfügen, Abfragen, Aktualisieren und Löschen von Daten. 3. Bereitstellung fortgeschrittener Funktionen wie Join Operations und Unterabfragen. 4. Die Leistung kann durch Indexierung, Abfrageoptimierung und Tabellenpartitionierung verbessert werden. 5. Backup-, Wiederherstellungs- und Sicherheitsmaßnahmen unterstützen, um die Datensicherheit und -konsistenz zu gewährleisten.

Navicat selbst speichert das Datenbankkennwort nicht und kann das verschlüsselte Passwort nur abrufen. Lösung: 1. Überprüfen Sie den Passwort -Manager. 2. Überprüfen Sie Navicats "Messnot Password" -Funktion; 3.. Setzen Sie das Datenbankkennwort zurück; 4. Kontaktieren Sie den Datenbankadministrator.

Erstellen Sie eine Datenbank mit Navicat Premium: Stellen Sie eine Verbindung zum Datenbankserver her und geben Sie die Verbindungsparameter ein. Klicken Sie mit der rechten Maustaste auf den Server und wählen Sie Datenbank erstellen. Geben Sie den Namen der neuen Datenbank und den angegebenen Zeichensatz und die angegebene Kollektion ein. Stellen Sie eine Verbindung zur neuen Datenbank her und erstellen Sie die Tabelle im Objektbrowser. Klicken Sie mit der rechten Maustaste auf die Tabelle und wählen Sie Daten einfügen, um die Daten einzufügen.

Navicat für MariADB kann das Datenbankkennwort nicht direkt anzeigen, da das Passwort in verschlüsselter Form gespeichert ist. Um die Datenbanksicherheit zu gewährleisten, gibt es drei Möglichkeiten, Ihr Passwort zurückzusetzen: Setzen Sie Ihr Passwort über Navicat zurück und legen Sie ein komplexes Kennwort fest. Zeigen Sie die Konfigurationsdatei an (nicht empfohlen, ein hohes Risiko). Verwenden Sie Systembefehlsleitungs -Tools (nicht empfohlen, Sie müssen die Befehlszeilen -Tools beherrschen).

Sie können eine neue MySQL -Verbindung in Navicat erstellen, indem Sie den Schritten folgen: Öffnen Sie die Anwendung und wählen Sie eine neue Verbindung (Strg N). Wählen Sie "MySQL" als Verbindungstyp. Geben Sie die Hostname/IP -Adresse, den Port, den Benutzernamen und das Passwort ein. (Optional) Konfigurieren Sie erweiterte Optionen. Speichern Sie die Verbindung und geben Sie den Verbindungsnamen ein.

Häufige Gründe, warum Navicat keine Verbindung zur Datenbank und ihren Lösungen herstellen kann: 1. Überprüfen Sie den laufenden Status des Servers. 2. Überprüfen Sie die Verbindungsinformationen; 3. Passen Sie die Firewall -Einstellungen ein; 4. Konfigurieren Sie den Remote -Zugriff; 5. Fehlerbehebung mit Netzwerkproblemen; 6. Berechtigungen überprüfen; 7. Sicherheitskompatibilität sicherstellen; 8. Fehlerbehebung bei anderen Möglichkeiten.

Häufige Fehler und Lösungen beim Anschließen mit Datenbanken: Benutzername oder Kennwort (Fehler 1045) Firewall -Blocks -Verbindungsverbindung (Fehler 2003) Timeout (Fehler 10060) Die Verwendung von Socket -Verbindung kann nicht verwendet werden (Fehler 1042).

Schritte zur Durchführung von SQL in Navicat: Verbindung zur Datenbank herstellen. Erstellen Sie ein SQL -Editorfenster. Schreiben Sie SQL -Abfragen oder Skripte. Klicken Sie auf die Schaltfläche Ausführen, um eine Abfrage oder ein Skript auszuführen. Zeigen Sie die Ergebnisse an (wenn die Abfrage ausgeführt wird).
