Analyse des MySQL-Serververbindungsprozesses
Mysqld ist der Hauptprozess des MySQL-Servers. Man kann sagen, dass MySQL der eigentliche Kern von MySQL ist und alle Arbeiten rund um den MySQL-Prozess ausgeführt werden. Um also den Giganten MySQL zu analysieren, ist der Code von MySQL der beste Durchbruch.
Alles beginnt mit der bekannten main()-Funktion. Tatsächlich beginnt es mit der mysqld_main()-Funktion. Diese Codes befinden sich alle in mysqld.cc. mysqld_main() ruft dann win_main)() auf. Die Funktion win_main() übernimmt hauptsächlich einige Initialisierungsarbeiten.
Nach Abschluss der Initialisierungsarbeiten ist MySQL bereit, Verbindungen anzunehmen. Dann erscheint die Funktion Handle_connections_methods() unseres Protagonisten. Die Hauptaufgabe dieser Funktion besteht darin, drei neue Unterprozesse zu erstellen, die Verbindungen auf drei Arten akzeptieren: TCP/IP, Named Pipes und Shared Memory. Unter normalen Umständen verwenden Kunden TCP/IP (Socket), um eine Verbindung zum MySQL-Server herzustellen, was die flexibelste Kommunikationsmethode darstellt. In der Anwendungsumgebung eingebetteter Software müssen jedoch die beiden letztgenannten Kommunikationsmethoden verwendet werden.
Vereinfachte Funktion handle_connectins_methods():
static void handle_connections_methods() { mysql_mutex_lock(&LOCK_thread_count); mysql_cond_init(key_COND_handler_count, &COND_handler_count, NULL); handler_count=0; handler_count++; mysql_thread_create(key_thread_handle_con_namedpipes, &hThread, &connection_attrib, handle_connections_namedpipes, 0)); handler_count++; mysql_thread_create(key_thread_handle_con_sockets, &hThread, &connection_attrib, handle_connections_sockets_thread, 0)); handler_count++; mysql_thread_create(key_thread_handle_con_sharedmem, &hThread, &connection_attrib, handle_connections_shared_memory, 0)) while (handler_count > 0) mysql_cond_wait(&COND_handler_count, &LOCK_thread_count); mysql_mutex_unlock(&LOCK_thread_count); }
Nach dem Erstellen von 3 neuen Threads tritt die Funktion handle_connectins_methods() in eine lange Schleife ein, bis Alle drei Verbindungsthreads werden beendet. Hier schaue ich mir hauptsächlich den Socket-Verbindungsthread an. Unser Forschungsobjekt ist dieser handle_connections_sockets_thread. Nachdem sich dieser Thread initialisiert hat, ruft er direkt handle_connections_sockets();
handle_connections_sockets() auf. Die Funktion handle_connections_sockets() ruft mithilfe von select() den Überwachungsport von mysqld auf und wartet dann auf die Clientverbindung. Nachdem ein Client eine Verbindung hergestellt hat, wird in dieser Funktion eine Variable vom Typ THD erstellt. Diese Variable ist ein „sozialer Schmetterling“, angefangen beim Verbindungsaufbau bis hin zur SQL-Syntaxanalyse, der Abfrageausführung, der Ergebnisrückgabe usw. Diese Variable ist immer vorhanden und kurz gesagt eine sehr wichtige Variable.
Es gibt auch die Struktur struct st_vio, die eine Übergabestation für Befehle darstellt. Eine Vio-Typ-Struktur ist auch im THD „Social Butterfly“ definiert. Die Funktion dieser Struktur besteht darin, den Kommunikationsinhalt aus dem Socket zu lesen und seinen Wert dann der vio-Variablen von THD zuzuweisen. Der VIO-Typ beschreibt eine Anfrage im Detail, einschließlich des Inhalts der Anfrage, der Uhrzeit, der Socket-Adresse der Anfrage usw. Als nächstes wird dieser „soziale Schmetterling“ an den Service-Thread übergeben und create_thread_to_handle_connection() implementiert diese Funktion.
Das Folgende ist der gelöschte Code
void create_thread_to_handle_connection(THD *thd) { if (cached_thread_count > wake_thread) { mysql_cond_signal(&COND_thread_cache); } else { mysql_thread_create(key_thread_one_connection, &thd->real_id, &connection_attrib, handle_one_connection, (void*) thd))); } }
Diese Funktion prüft, ob inaktive Cache-Threads vorhanden sind (MySQL unterbricht den Dienst nicht Thread wird nach dem Öffnen der Verbindung sofort zerstört und stattdessen zwischengespeichert. Wenn nicht, erstellen Sie einen neuen Thread, um die Verbindung bereitzustellen. Zu diesem Zeitpunkt ist eine Verbindung in den Service-Thread eingetreten, und der Verbindungs-Thread kehrt zurück und wartet weiterhin auf die Verbindung.
Die folgenden Inhalte sind alle im Service-Thread implementiert. Es gibt einen sehr detaillierten Code-Trace in „Ausführliches Verständnis von MySQL“. Ich habe die Funktionsaufrufsequenz als Referenz angehängt.
handle_one_connection() mysql_thread_create() handle_one_connection() do_handle_one_connection() init_new_connection_thread() init_new_connection_handler_thread() do_command() dispatch_command() mysql_parse() mysql_execuate_command()
Das Obige ist die Analyse des MySQL-Serververbindungsprozesses. Weitere verwandte Inhalte finden Sie auf der chinesischen PHP-Website (www.php.cn).

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 ein Open Source Relational Database Management System. 1) Datenbank und Tabellen erstellen: Verwenden Sie die Befehle erstellte und creatEtable. 2) Grundlegende Vorgänge: Einfügen, aktualisieren, löschen und auswählen. 3) Fortgeschrittene Operationen: Join-, Unterabfrage- und Transaktionsverarbeitung. 4) Debugging -Fähigkeiten: Syntax, Datentyp und Berechtigungen überprüfen. 5) Optimierungsvorschläge: Verwenden Sie Indizes, vermeiden Sie ausgewählt* und verwenden Sie Transaktionen.

Sie können PhpMyAdmin in den folgenden Schritten öffnen: 1. Melden Sie sich beim Website -Bedienfeld an; 2. Finden und klicken Sie auf das Symbol phpmyadmin. 3. Geben Sie MySQL -Anmeldeinformationen ein; 4. Klicken Sie auf "Login".

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.

MySQL ist ein Open Source Relational Database Management -System, das hauptsächlich zum schnellen und zuverlässigen Speicher und Abrufen von Daten verwendet wird. Sein Arbeitsprinzip umfasst Kundenanfragen, Abfragebedingungen, Ausführung von Abfragen und Rückgabergebnissen. Beispiele für die Nutzung sind das Erstellen von Tabellen, das Einsetzen und Abfragen von Daten sowie erweiterte Funktionen wie Join -Operationen. Häufige Fehler umfassen SQL -Syntax, Datentypen und Berechtigungen sowie Optimierungsvorschläge umfassen die Verwendung von Indizes, optimierte Abfragen und die Partitionierung von Tabellen.

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.

MySQL wird für seine Leistung, Zuverlässigkeit, Benutzerfreundlichkeit und Unterstützung der Gemeinschaft ausgewählt. 1.MYSQL bietet effiziente Datenspeicher- und Abruffunktionen, die mehrere Datentypen und erweiterte Abfragevorgänge unterstützen. 2. Übernehmen Sie die Architektur der Client-Server und mehrere Speichermotoren, um die Transaktion und die Abfrageoptimierung zu unterstützen. 3. Einfach zu bedienend unterstützt eine Vielzahl von Betriebssystemen und Programmiersprachen. V.

Redis verwendet eine einzelne Gewindearchitektur, um hohe Leistung, Einfachheit und Konsistenz zu bieten. Es wird E/A-Multiplexing, Ereignisschleifen, nicht blockierende E/A und gemeinsame Speicher verwendet, um die Parallelität zu verbessern, jedoch mit Einschränkungen von Gleichzeitbeschränkungen, einem einzelnen Ausfallpunkt und ungeeigneter Schreib-intensiver Workloads.

Das Wiederherstellen von gelöschten Zeilen direkt aus der Datenbank ist normalerweise unmöglich, es sei denn, es gibt einen Backup- oder Transaktions -Rollback -Mechanismus. Schlüsselpunkt: Transaktionsrollback: Führen Sie einen Rollback aus, bevor die Transaktion Daten wiederherstellt. Sicherung: Regelmäßige Sicherung der Datenbank kann verwendet werden, um Daten schnell wiederherzustellen. Datenbank-Snapshot: Sie können eine schreibgeschützte Kopie der Datenbank erstellen und die Daten wiederherstellen, nachdem die Daten versehentlich gelöscht wurden. Verwenden Sie eine Löschanweisung mit Vorsicht: Überprüfen Sie die Bedingungen sorgfältig, um das Verhandlich von Daten zu vermeiden. Verwenden Sie die WHERE -Klausel: Geben Sie die zu löschenden Daten explizit an. Verwenden Sie die Testumgebung: Testen Sie, bevor Sie einen Löschvorgang ausführen.
