Heim Backend-Entwicklung PHP-Tutorial Vollständige Aufzeichnung des DB2-Deadlock-Auflösungsprozesses

Vollständige Aufzeichnung des DB2-Deadlock-Auflösungsprozesses

Mar 06, 2018 pm 05:43 PM
死锁 解决 记录

DB2 wird hauptsächlich in großen Anwendungssystemen verwendet. Es verfügt über eine gute Skalierbarkeit und kann alles von Mainframe- bis hin zu Einzelbenutzerumgebungen unterstützen. DB2 bietet Datennutzung, Integrität, Sicherheit und Wiederherstellbarkeit auf hohem Niveau. In diesem Artikel wird hauptsächlich die vollständige Aufzeichnung des Deadlock-Auflösungsprozesses in diesem Artikel vorgestellt. Der Verarbeitungsprozess ist ziemlich schwierig 🎜> in der Produktionsumgebung wird DB2 verwendet. Allerdings ist in letzter Zeit häufig ein seltsames Deadlock-Phänomen aufgetreten: Eine bestimmte Select-SQL-Anweisung führt immer zu einem Deadlock.
Nach bisherigen Erfahrungen führen Update-SQL-Anweisungen wie „Update/Delete“ normalerweise zu Deadlock-Problemen. Und diese Select-SQL-Anweisung ist eine ganz normale SQL-Anweisung ohne große Datenverarbeitung.

Wenn man diesen Stillstand analysiert, gibt es viele Dinge, die schwer zu bewältigen sind.

1. Aufgrund der großen Datenmenge in der Produktionsumgebung können wir die Daten der Zuordnungstabelle in der Produktionsumgebung nicht in die Testumgebung importieren. Das heißt, die Datenmenge kann nicht simuliert werden.

2. Es erfolgt keine Protokollausgabe. Weil die Protokollausgabestufe der Produktionsumgebung FEHLER ist.

3. Es kann nicht in der Produktionsumgebung getestet werden, da der Kunde dies nicht zulässt.

4. Die Datenbank in der Produktionsumgebung kann keine Snapshots und andere Funktionen ermöglichen. Weil es die Leistung beeinträchtigt.


Wie Sie sich vorstellen können, kann die Deadlock-Analyse ohne Funktionen wie Snapshots nur auf der Code-Analyse beruhen. Dieser Prozess ist jedoch sehr kompliziert und allein durch die Analyse des Codes erhält man keinen Hinweis.

Stufe 1: Wir vermuten, dass es an der Datenmenge liegt



Aufgrund der extrem großen Datenmenge in der Produktionsumgebung beinhaltet dieser Prozess auch die Verarbeitung von vielen anderen Tischen. Wir fragen uns also, ob die große Datenmenge zu einer Überlastung des Systems und damit zu einem Deadlock geführt hat? Also haben wir die Auslastungsinformationen von CPU, Festplatte, Netzwerk usw. erhalten, als der Deadlock auftrat. Es wurden keine Hinweise gefunden.

Phase 2: Erstellen Sie ein Testprogramm und verwenden Sie Multithreading, um mehrere Benutzer in der Testumgebung zu simulieren, um diese Verarbeitung durchzuführen.


Um diesen Deadlock in der Entwicklungsumgebung zu reproduzieren, haben wir ein Multithread-Testprogramm erstellt, um den Mehrbenutzerbetrieb zu simulieren. Leider wurde es immer noch nicht reproduziert.
Phase 3: Analysieren Sie den Unterschied zwischen der Testumgebungsdatenbank und der Produktionsumgebungsdatenbank

Zu diesem Zeitpunkt vermuten wir, dass das Problem immer noch durch die Datenmenge verursacht wird. Deshalb haben wir unser Bestes gegeben, um in der Entwicklungsumgebung genauso viele Daten wie in der Produktionsumgebung zu haben.
Nachdem der Test ausgeführt wurde, konnte er immer noch nicht reproduziert werden.


Stufe 4: Analysieren Sie das Betriebsprotokoll des Benutzers


Da es keine andere Lösung gibt, müssen wir das Betriebsprotokoll des Benutzers analysieren, in der Hoffnung, einige Hinweise zu finden. Harte Arbeit zahlt sich aus, und wir haben festgestellt, dass es grundsätzlich zu einem Deadlock kommt, wenn zwei Personen diesen Vorgang gleichzeitig ausführen. Daher gehen wir davon aus, dass das Problem dadurch verursacht wird, dass zwei Personen gleichzeitig arbeiten. Warum simuliert die Entwicklungsumgebung jedoch die Vorgänge
vieler Personen, ohne dass ein Deadlock auftritt?


Phase 5: Erkennen von Datenbankeinstellungsproblemen


Wir haben das Testprogramm geändert, um die Anzahl der simulierten Benutzer zu erhöhen, aber leider wurde das Problem nicht reproduziert. An dieser Stelle ist uns aufgefallen: Unterscheiden sich die Datenbankeinstellungen der Entwicklungsumgebung von denen der Produktionsumgebung? Wir verglichen die Einstellungen der beiden Datenbanken und stellten fest, dass viele Parameter unterschiedlich waren. Wir haben uns jedoch nur auf die sperrbezogenen Einstellungen
konzentriert, also auf die Einstellungen, die das Schlüsselwort LOCK enthalten.


Stufe 6: Halten Sie die Einstellungen der Testumgebungsdatenbank und der Produktionsumgebungsdatenbank konsistent


Wir haben alle sperrenbezogenen Einstellungen geändert, um sie mit der Produktionsumgebung konsistent zu machen. Der Deadlock wird jedoch immer noch nicht reproduziert. Schließlich entdeckte jemand, dass die Einstellung „cur_commit“ anders war. Also habe ich die Dokumentation abgefragt und die Eigenschaften von cur_commit entdeckt.
Wenn cur_commit = false, führt die folgende Situation zu einem Deadlock:
Thread 1 fügt Daten A ein und dann fügt Thread 2 Daten B ein.
Bevor Thread 2 die Transaktion übermittelt hat, fragt Thread 1 Daten A ab, was zu einem Deadlock führt.
In der Entwicklungsumgebung ist cur_commit = true, daher konnten wir dieses Phänomen nie simulieren.
Also haben wir cur_commit in false geändert.


Phase 7: Verwenden Sie das Testprogramm zur Simulation


Wir haben das Testprogramm geändert, um die Vorgänge der beiden oben genannten Threads zu simulieren, und den Deadlock erfolgreich reproduziert. Die Fehlerprotokollinformationen stimmen auch mit der Produktionsumgebung überein.
Stufe 8: Verwenden Sie Bildschirmoperationen zur Simulation


Dann haben wir das Programm geändert, Bildschirmoperationen verwendet und den Deadlock erfolgreich reproduziert.
Lösung:

Die Lösung ist sehr einfach: Fügen Sie die Bedingungen in der Abfrageanweisung als Indizes hinzu, damit kein Deadlock auftritt.
Da das Datenvolumen dieser Tabelle nicht groß ist, gibt es nahezu keine Auswirkungen auf die Leistung.



Verwandte Empfehlungen:

Detaillierte Erläuterung der Methode der Offline-Installation von db2 mit dem Python-Modul ibm_db

Python Verbindung zur DB2-Datenbank

Fünf Möglichkeiten, PHP zum Betrieb von DB2 Express C (1) zu verwenden_PHP-Tutorial

Das obige ist der detaillierte Inhalt vonVollständige Aufzeichnung des DB2-Deadlock-Auflösungsprozesses. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Lösung für das Problem, dass das chinesische Sprachpaket nicht auf einem Win11-System installiert werden kann Lösung für das Problem, dass das chinesische Sprachpaket nicht auf einem Win11-System installiert werden kann Mar 09, 2024 am 09:48 AM

Lösung für das Problem, dass das Win11-System das chinesische Sprachpaket nicht installieren kann. Mit der Einführung des Windows 11-Systems begannen viele Benutzer, ihr Betriebssystem zu aktualisieren, um neue Funktionen und Schnittstellen zu nutzen. Einige Benutzer stellten jedoch fest, dass sie das chinesische Sprachpaket nach dem Upgrade nicht installieren konnten, was ihre Erfahrung beeinträchtigte. In diesem Artikel besprechen wir die Gründe, warum das Win11-System das chinesische Sprachpaket nicht installieren kann, und stellen einige Lösungen bereit, die Benutzern bei der Lösung dieses Problems helfen. Ursachenanalyse Lassen Sie uns zunächst die Unfähigkeit des Win11-Systems analysieren

Fünf Tipps, die Ihnen zeigen, wie Sie das Problem lösen können, dass sich das Black Shark-Telefon nicht einschaltet! Fünf Tipps, die Ihnen zeigen, wie Sie das Problem lösen können, dass sich das Black Shark-Telefon nicht einschaltet! Mar 24, 2024 pm 12:27 PM

Da sich die Smartphone-Technologie ständig weiterentwickelt, spielen Mobiltelefone eine immer wichtigere Rolle in unserem täglichen Leben. Als Flaggschiff-Telefon mit Schwerpunkt auf Spieleleistung erfreut sich das Black Shark-Telefon bei Spielern großer Beliebtheit. Manchmal sind wir jedoch auch mit der Situation konfrontiert, dass das Black Shark-Telefon nicht eingeschaltet werden kann. Zu diesem Zeitpunkt müssen wir einige Maßnahmen ergreifen, um dieses Problem zu lösen. Als Nächstes geben wir Ihnen fünf Tipps, wie Sie das Problem lösen können, dass sich das Black Shark-Telefon nicht einschaltet: Schritt 1: Überprüfen Sie zunächst die Akkuleistung. Stellen Sie zunächst sicher, dass Ihr Black Shark-Telefon über genügend Strom verfügt. Möglicherweise ist der Akku des Telefons leer

Der Treiber kann auf diesem Gerät nicht geladen werden. (Persönlich getestet und gültig) Der Treiber kann auf diesem Gerät nicht geladen werden. (Persönlich getestet und gültig) Mar 14, 2024 pm 09:00 PM

Jeder weiß, dass das Gerät möglicherweise nicht richtig funktioniert oder nicht richtig mit dem Computer interagiert, wenn der Computer den Treiber nicht laden kann. Wie lösen wir also das Problem, wenn auf dem Computer eine Meldung angezeigt wird, dass der Treiber auf diesem Gerät nicht geladen werden kann? Der unten stehende Editor zeigt Ihnen zwei Möglichkeiten, wie Sie das Problem einfach lösen können. Der Treiber kann auf diesem Gerät nicht geladen werden. Lösung 1. Suchen Sie im Startmenü nach „Kernel Isolation“. 2. Deaktivieren Sie die Speicherintegrität. Die Meldung oben lautet: „Die Speicherintegrität wurde deaktiviert. Ihr Gerät ist möglicherweise anfällig.“ Klicken Sie einfach darauf und ignorieren Sie es. 3. Das Problem kann nach einem Neustart der Maschine behoben werden.

Wie kann das Problem des automatischen Speicherns von Bildern beim Veröffentlichen auf Xiaohongshu gelöst werden? Wo ist das beim Posten automatisch gespeicherte Bild? Wie kann das Problem des automatischen Speicherns von Bildern beim Veröffentlichen auf Xiaohongshu gelöst werden? Wo ist das beim Posten automatisch gespeicherte Bild? Mar 22, 2024 am 08:06 AM

Durch die kontinuierliche Entwicklung der sozialen Medien ist Xiaohongshu zu einer Plattform für immer mehr junge Menschen geworden, auf der sie ihr Leben teilen und schöne Dinge entdecken können. Viele Benutzer haben beim Posten von Bildern Probleme mit der automatischen Speicherung. Wie kann man dieses Problem lösen? 1. Wie kann das Problem des automatischen Speicherns von Bildern beim Veröffentlichen auf Xiaohongshu gelöst werden? 1. Cache leeren Zuerst können wir versuchen, die Cache-Daten von Xiaohongshu zu löschen. Die Schritte sind wie folgt: (1) Öffnen Sie Xiaohongshu und klicken Sie auf die Schaltfläche „Mein“ in der unteren rechten Ecke. (2) Suchen Sie auf der persönlichen Center-Seite nach „Einstellungen“ und klicken Sie darauf. (3) Scrollen Sie nach unten und suchen Sie nach „; Option „Cache löschen“. Klicken Sie auf „OK“. Nachdem Sie den Cache geleert haben, geben Sie Xiaohongshu erneut ein und versuchen Sie, Bilder zu posten, um zu sehen, ob das Problem mit dem automatischen Speichern behoben ist. 2. Aktualisieren Sie die Xiaohongshu-Version, um sicherzustellen, dass Ihr Xiaohongshu

Wo kann ich die Aufzeichnungen der Dinge einsehen, die ich auf Pinduoduo gekauft habe? Wie kann ich die Aufzeichnungen der gekauften Produkte einsehen? Wo kann ich die Aufzeichnungen der Dinge einsehen, die ich auf Pinduoduo gekauft habe? Wie kann ich die Aufzeichnungen der gekauften Produkte einsehen? Mar 12, 2024 pm 07:20 PM

Die Pinduoduo-Software bietet viele gute Produkte, die Sie jederzeit und überall kaufen können. Die Qualität jedes Produkts wird streng kontrolliert, jedes Produkt ist echt und es gibt viele Vorzugsrabatte beim Einkaufen, sodass jeder online einkaufen kann. Ich kann einfach nicht aufhören. Geben Sie Ihre Mobiltelefonnummer ein, um sich online anzumelden, fügen Sie online mehrere Lieferadressen und Kontaktinformationen hinzu und prüfen Sie jederzeit die neuesten Logistiktrends. Suchen Sie nach oben und unten, um zu kaufen und eine Bestellung aufzugeben. Sie können den Komfort genießen, ohne das Haus zu verlassen. Mit dem Online-Einkaufsservice können Sie auch alle Einkaufsunterlagen, einschließlich der von Ihnen gekauften Waren, einsehen und erhalten Dutzende von roten Einkaufsumschlägen und Gutscheinen kostenlos Detaillierte Online-Methode zum Anzeigen gekaufter Produktdatensätze. 1. Öffnen Sie Ihr Telefon und klicken Sie auf das Pinduoduo-Symbol.

So lösen Sie verstümmelte chinesische Zeichen unter Linux So lösen Sie verstümmelte chinesische Zeichen unter Linux Feb 21, 2024 am 10:48 AM

Das verstümmelte Linux-Chinesisch-Problem ist ein häufiges Problem bei der Verwendung chinesischer Zeichensätze und Kodierungen. Verstümmelte Zeichen können durch falsche Dateikodierungseinstellungen, nicht installiertes oder eingestelltes Systemgebietsschema, Konfigurationsfehler bei der Terminalanzeige usw. verursacht werden. In diesem Artikel werden mehrere gängige Problemumgehungen vorgestellt und spezifische Codebeispiele bereitgestellt. 1. Überprüfen Sie die Dateikodierungseinstellung. Verwenden Sie den Dateibefehl im Terminal, um die Kodierung der Datei anzuzeigen: file-ifilename

So lösen Sie das Problem, dass das Standard-Gateway automatisch verschwindet So lösen Sie das Problem, dass das Standard-Gateway automatisch verschwindet Feb 24, 2024 pm 04:18 PM

So lösen Sie das Problem, dass das Standard-Gateway automatisch verschwindet. In der modernen Gesellschaft ist das Internet zu einem unverzichtbaren Bestandteil des Lebens der Menschen geworden. Ob bei der Arbeit oder zur Unterhaltung, wir alle benötigen stabile Netzwerkverbindungen, um verschiedene Aufgaben zu erledigen. Das Standard-Gateway ist eines der Schlüsselelemente, die das lokale Netzwerk mit dem externen Internet verbinden. Allerdings kann es manchmal vorkommen, dass das Standard-Gateway automatisch verschwindet, was dazu führt, dass kein Zugriff auf das Internet mehr möglich ist. Wie sollen wir also dieses Problem lösen, wenn das Standard-Gateway verschwindet? Zunächst sollten wir das Konzept des Standard-Gateways klären. Das Standard-Gateway ist eine Netzwerkroute

Teilen Sie die Methode zur Lösung des Problems, dass PyCharm nicht geöffnet werden kann Teilen Sie die Methode zur Lösung des Problems, dass PyCharm nicht geöffnet werden kann Feb 22, 2024 am 09:03 AM

Titel: So lösen Sie das Problem, dass PyCharm nicht geöffnet werden kann. PyCharm ist eine leistungsstarke integrierte Python-Entwicklungsumgebung, aber manchmal kann es vorkommen, dass PyCharm nicht geöffnet werden kann. In diesem Artikel stellen wir einige gängige Problemumgehungen vor und stellen spezifische Codebeispiele bereit. Ich hoffe, das hilft denjenigen, die auf dieses Problem stoßen. Methode 1: Cache leeren Manchmal können die Cache-Dateien von PyCharm dazu führen, dass das Programm nicht normal geöffnet wird. Wir können versuchen, den Cache zu leeren, um dieses Problem zu lösen. Werkzeug

See all articles