enq:TX-rowlockcontention故障处理一则
一个很简单的问题,之所以让我对这个问题进行总结,一是因为没我想象的简单,在处理的过程中遇到了一些磕磕碰碰,甚至绕了一些弯路,二是引发了我对故障处理时的一些思考。 6月19日,下午5点左右,数据库出现了大量的enq: TX - row lock contention等待事件,
一个很简单的问题,之所以让我对这个问题进行总结,一是因为没我想象的简单,在处理的过程中遇到了一些磕磕碰碰,甚至绕了一些弯路,二是引发了我对故障处理时的一些思考。6月19日,下午5点左右,数据库出现了大量的enq: TX - row lock contention等待事件,按照以往的经验,这类等待一般与业务逻辑有关,DBA能够做的事情,一般就是将锁等待着的连接信息,等待锁的SQL语句,甚至等待的具体数据行,还有就是锁持有者的连接信息,造成锁等待的SQL语句等一些基本信息提交给开发人员,修改业务逻辑。
注意 很多情况下,修改业务逻辑不是一时半会能够立即解决的事,有时候如果锁持有或者锁等待业务不是特别重要,可以与应用维护人员协商,先停掉这部分业务,让其它业务正常运行很多时候,数据库只有一个锁持有者,并且这个锁持有的连接也没有活动,可以与应用维护人员协商,尝试kill锁持有者,看看后续锁等待能否自动解决。这种情况一般是一个单独的连接出现僵死导致,kill掉持有者以后,问题自然就解决了另外一种情况就是,前天晚上上线后,平时运行好好的业务,也没出现锁等待,有一天出现了这类问题,而且kill掉锁持有者以后,问题无法得到解决(业务逻辑问题,kill掉以后,后续还会发生),这一般是前天晚上上线引起。 本来觉得数据库层提供信息很简单,结果与想象的有点区别,来看一下具体的过程 (1)查询锁信息,如下
SESS | LMODE | LMODE | REQUEST | TYPE | EVENT | SQL_TEXT |
Holder: 4266 | exclusive | 6 | 0 | TX | SQL*Net message from client | |
Waiter: 3136 | none | 0 | 4 | TX | enq: TX - row lock contention | insert into xxxxx(ID,xxx,xxxx,xxx,….) values(seq_xxx.nextval,:"SYS_B_0",:"SYS_B_1",:"SYS_B_2",:"SYS_B_3",:"SYS_B_4",:"SYS_B_5") |
Holder: 2276 | exclusive | 6 | 0 | TX | SQL*Net message from client | |
Waiter: 1716 | none | 0 | 4 | TX | enq: TX - row lock contention | insert into xxxxx(ID,xxx,xxxx,xxx,….) values(seq_xxx.nextval,:"SYS_B_0",:"SYS_B_1",:"SYS_B_2",:"SYS_B_3",:"SYS_B_4",:"SYS_B_5") |
Holder: 1288 | exclusive | 6 | 0 | TX | SQL*Net message from client | |
Waiter: 1565 | none | 0 | 4 | TX | enq: TX - row lock contention | insert into xxxxx(ID,xxx,xxxx,xxx,….) values(seq_xxx.nextval,:"SYS_B_0",:"SYS_B_1",:"SYS_B_2",:"SYS_B_3",:"SYS_B_4",:"SYS_B_5") |
Holder: 1000 | exclusive | 6 | 0 | TX | SQL*Net message from client | |
Waiter: 1147 | none | 0 | 4 | TX | enq: TX - row lock contention | insert into xxxxx(ID,xxx,xxxx,xxx,….) values(seq_xxx.nextval,:"SYS_B_0",:"SYS_B_1",:"SYS_B_2",:"SYS_B_3",:"SYS_B_4",:"SYS_B_5") |
Holder: 2989 | exclusive | 6 | 0 | TX | SQL*Net message from client | |
Waiter: 862 | none | 0 | 4 | TX | enq: TX - row lock contention | insert into xxxxx(ID,xxx,xxxx,xxx,….) values(seq_xxx.nextval,:"SYS_B_0",:"SYS_B_1",:"SYS_B_2",:"SYS_B_3",:"SYS_B_4",:"SYS_B_5") |
问题总结 其实这个问题本身不难,值得思考的是,为什么一个这么简单的问题,无法立即找到原因。说到底,很多时候都是经验束缚了我们,在遇到这类问题时,我们需要抛开已有的那些经验,通过数据库的原理来发现根本原因。因此,理论知识再怎么强调都不过分,它真的很重要,理解了原理,你才可以举一反三,游刃有余,而不是每次一碰到没见过的问题都战战兢兢!

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



1. Tout d'abord, nous cliquons avec le bouton droit sur l'espace vide de la barre des tâches et sélectionnons l'option [Gestionnaire des tâches], ou cliquons avec le bouton droit sur le logo de démarrage, puis sélectionnons l'option [Gestionnaire des tâches]. 2. Dans l'interface du Gestionnaire des tâches ouverte, nous cliquons sur l'onglet [Services] à l'extrême droite. 3. Dans l'onglet [Service] ouvert, cliquez sur l'option [Ouvrir le service] ci-dessous. 4. Dans la fenêtre [Services] qui s'ouvre, cliquez avec le bouton droit sur le service [InternetConnectionSharing(ICS)], puis sélectionnez l'option [Propriétés]. 5. Dans la fenêtre des propriétés qui s'ouvre, remplacez [Ouvrir avec] par [Désactivé], cliquez sur [Appliquer] puis cliquez sur [OK]. 6. Cliquez sur le logo Démarrer, puis cliquez sur le bouton d'arrêt, sélectionnez [Redémarrer] et terminez le redémarrage de l'ordinateur.

Que dois-je faire si mon téléphone Black Shark ne peut pas être allumé ? Apprenez-vous à vous sauver ! Dans notre vie quotidienne, les téléphones portables sont devenus un élément indispensable de nous. Pour de nombreuses personnes, le téléphone mobile Black Shark est un téléphone de jeu apprécié. Mais il est inévitable que vous rencontriez divers problèmes, dont l’impossibilité d’allumer le téléphone. Lorsque vous rencontrez une telle situation, ne paniquez pas. Voici quelques solutions, j'espère qu'elles pourront vous aider. Tout d'abord, lorsque le téléphone Black Shark ne peut pas être allumé, vérifiez d'abord si le téléphone est suffisamment alimenté. Il se peut que le téléphone ne puisse pas être allumé en raison d'une batterie épuisée.

Qu’est-ce que l’échec 0x0000004e ? L’échec est un problème courant dans les systèmes informatiques. Lorsqu'un ordinateur rencontre une panne, le système s'arrête généralement, plante ou affiche des messages d'erreur car il ne peut pas fonctionner correctement. Dans les systèmes Windows, il existe un code d'erreur spécifique 0x0000004e, qui est un code d'erreur sur écran bleu indiquant que le système a rencontré une erreur grave. L'erreur d'écran bleu 0x0000004e est causée par des problèmes de noyau ou de pilote du système. Cette erreur provoque généralement le système informatique

Apprenez rapidement à ouvrir et traiter des fichiers au format CSV Avec le développement continu de l'analyse et du traitement des données, le format CSV est devenu l'un des formats de fichiers les plus utilisés. Un fichier CSV est un fichier texte simple et facile à lire avec différents champs de données séparés par des virgules. Que ce soit dans la recherche académique, l'analyse commerciale ou le traitement de données, nous rencontrons souvent des situations où nous devons ouvrir et traiter des fichiers CSV. Le guide suivant vous montrera comment apprendre rapidement à ouvrir et traiter des fichiers au format CSV. Étape 1 : Comprendre le format de fichier CSV. Tout d'abord,

Que faire à propos de l'écran bleu 0x00000001 ? Le problème de l'écran bleu est un casse-tête que de nombreux utilisateurs d'ordinateurs rencontrent souvent. Lorsque notre ordinateur rencontre un écran bleu, il s'arrête soudainement de fonctionner et affiche une interface à écran bleu avec un code d'erreur. Parmi eux, 0x00000001 est un code d’erreur d’écran bleu courant. Les problèmes d'écran bleu peuvent être causés par diverses raisons, notamment des erreurs logicielles, des pannes matérielles, des problèmes de pilotes, etc. Même si ce problème peut être frustrant, nous pouvons prendre certaines mesures pour le résoudre. Ci-dessous, je présenterai quelques solutions à l'écran bleu

Dans le processus de développement PHP, la gestion des caractères spéciaux est un problème courant, en particulier dans le traitement des chaînes, les caractères spéciaux sont souvent échappés. Parmi eux, la conversion de caractères spéciaux en guillemets simples est une exigence relativement courante, car en PHP, les guillemets simples sont un moyen courant d'encapsuler des chaînes. Dans cet article, nous expliquerons comment gérer les guillemets simples de conversion de caractères spéciaux en PHP et fournirons des exemples de code spécifiques. En PHP, les caractères spéciaux incluent, sans s'y limiter, les guillemets simples ('), les guillemets doubles ("), la barre oblique inverse (), etc. Dans les chaînes

De nombreux amis viennent d'acheter une nouvelle carte graphique. Après l'avoir installée pendant quelques jours, le ventilateur a soudainement cessé de tourner. Quelle est la raison ? Cela doit être un problème. les câbles mémoire et disque dur sont connectés et il n'y a pas d'alimentation. Est-ce normal ? Y a-t-il une instabilité de tension ? Voyons les raisons spécifiques avec l'éditeur. Réponses aux raisons pour lesquelles le ventilateur de la carte graphique ne tourne pas : 1. Une alimentation électrique insuffisante empêche le ventilateur de tourner. L'une des raisons les plus courantes est que lorsque l'énergie fournie par votre alimentation ne peut pas répondre aux exigences de la carte graphique, afin de maintenir le fonctionnement normal du programme informatique. les cartes graphiques arrêteront leurs ventilateurs de refroidissement pour garantir que le cœur du GPU puisse continuer à effectuer des calculs. Lorsque vous rencontrez cette situation, ne blâmez pas la carte graphique de ne pas être puissante ! C'est évidemment très prévenant, d'accord ?

Black Shark est une marque de smartphones connue pour ses performances puissantes et son excellente expérience de jeu. Elle est appréciée des joueurs et des passionnés de technologie. Cependant, tout comme les autres smartphones, les téléphones Black Shark rencontreront divers problèmes, parmi lesquels les pannes de charge sont courantes. Une panne de charge affectera non seulement l'utilisation normale du téléphone mobile, mais peut également causer des problèmes plus graves. Il est donc très important de résoudre le problème de charge à temps. Cet article commencera par les causes courantes des échecs de chargement des téléphones mobiles Black Shark et présentera des méthodes pour dépanner et résoudre les problèmes de charge. J'espère qu'il pourra aider les lecteurs à résoudre les problèmes de chargement des téléphones Black Shark.
