Maison base de données tutoriel mysql 擦亮自己的眼睛去看SQL Server之谈谈锁机制

擦亮自己的眼睛去看SQL Server之谈谈锁机制

Jun 07, 2016 pm 04:17 PM
server 机制 Œil propre

在谈谈SQL Server的锁机制之前,来思考以下这个场景:当你在酷暑的时候骑着自己的小车往目的地行走时,路上连续遇到几个时间很长的红灯,是不是很郁闷?有时候 你可能实在受不了闯了个红灯,其实在大部分情况下问题不大,如果通行的汽车很多那就不好说了。因

在谈谈SQL Server的锁机制之前,来思考以下这个场景:当你在酷暑的时候骑着自己的小车往目的地行走时,路上连续遇到几个时间很长的红灯,是不是很郁闷?有时候 你可能实在受不了闯了个红灯,其实在大部分情况下问题不大,如果通行的汽车很多那就不好说了。因为不遵守规则的人太多,都为了达到目的去走捷径,,不愿意等 待。这样才有了交警。交警的作用就是维护这些红绿灯的规则。这些红绿灯就像锁一样,锁住或延长你去目的地的时间。但是如果没有交警大家又不自由遵守红绿灯 规则会导致什么呢?大家想想都知道。

这个系列的一篇文章中提供的事务管理器中有个锁管理器就是这里的交警。它维护着SQLServer中的锁。前段提到的大部分情况指的就是在系统事务 量不大的时候,这时候的锁永远不会是什么大问题。除非你知道你的系统永远就给几个人用,否则考虑到避免系统以后的并发量上升引起数据安全与效率问题,那你 得深入了解锁机制。在研究锁之前,假定你已经了解事务的ACID概念,它是整个SQL Server的精髓所在。如果没有事务那就不用谈锁了,除了事务需要锁以外其他任何东西都需要这个让SQL不自由的机制。说到底锁是一个平衡并发与数据安 全的机制,如果没有锁,任何SQL都能覆盖其他SQL执行的数据,那么数据会出现不一致的情况。如果锁得太狠,那将影响数据库系统的并发性以及效率(包括 锁本身带来的额外开销)。这时候就需要去权衡,SQLServer锁管理器就充当权衡这两者关系的角色,如下图所示:

擦亮自己的眼睛去看SQL Server之谈谈锁机制

SQL Server中锁的知识点实在太多,比如锁从模式上分为:共享锁(S)、更新锁(U)、排他锁(X)、架构锁(Sch-S、Sch-M)、意向锁(IS、 IU、IX)、转换锁(SIX、SIU、UIX)、大容量更新锁(BU);锁从粒度上分为:数据库锁、文件锁、表锁、堆锁、索引锁、页锁、键锁、区锁、行 锁、应用程序锁、元数据锁;锁之间存在兼容性问题;锁会根据情况进行升级;锁控制不好会出现死锁;悲观锁的隔离性:未提交读、已提交读、可重复读、可序列 化;乐观锁的隔离性:读提交快照隔离、快照隔离;闩(shuan)锁。。。随便列下就一大堆问题要说清楚需要花很大篇幅。还是抱着与前几篇文章的风格,仔 细分析一个具体的问题——锁升级。

1、准备

有一个动态管理视图可以查看所有锁:sys.dm_tran_locks,还有一个动态管理视图可以查看哪些请求正在阻塞其他的请求:sys.dm_os_waiting_tasks

2、什么是锁升级

锁升级是指锁的粒度由细向粗转换。如:由行锁转成表锁。

3、需要锁升级吗?

一般来说,锁的粒度越小,并发性越好但是如果去锁定的东西多就需要的锁越多,这样会消耗SQLServer的cpu与内存。一个锁占用内存约为96 字节,你算算如果用行锁去锁定百万千万的表需要多少内存。而且管理锁(创建锁、维护锁、销毁锁等)也是有代价的,会消耗cpu。 如果用一个大点的锁就将这些百万千万的锁合并成一个锁了,管理起来也方便消耗资源也小。

4、什么时候出现锁升级

SQLServer意识到锁定的页面或行数过大的时候发生。怎么意识到过大呢?由两种方法识别:请求用于的锁的数目超过锁数目临界值;锁管理器为单 独一个查询消耗过多的内存超过内存临界值。有其他一个超过临界值,SQLServer就会试图升级。注意这里说的锁数据以及内存是值由同一个查询发生的, 而不是总共的。这里说的临界值并不是固定的,SQLServer采用启发式算法去动态调整。

5、控制锁升级

SQLServer提供一些可以让我们控制锁升级的入口。在SQLServer2008中可以通过:

alter table test

set (lock_escalation = auto|table|disable)

我们还可以通过在代码中显示指定pagelock、tablock提示,会强制SQLServer使用更粗的锁。不过这个设置不合理的话会导致并发降低。建议一般情况下不用,除非你很清楚这样带来的影响。

6、举例说明

6.1建库建表:

create database Test

create table test

ID identity(1,1) primary key,

[Name] varchar(50) not null default ‘’,

CreatedTime datetime not null default getdate();

查看当前锁情况:

默认某个连接对整个数据库有个共享锁。

6.2循环插入几十万条记录:

while 1 = 1

insert into test(Name) values (‘kk’)

插入时的锁快照 :

擦亮自己的眼睛去看SQL Server之谈谈锁机制

从上图中看出这个快照中有:三个数据库共享锁、一个页级意向排他锁、一个表级意向排他锁、两个行级排他锁。

三个数据库共享锁:前面已经提过,默认某个连接对整个数据库有个共享锁;

一个页级意向排他锁、一个表级意向排他锁:在页以及表级表示资源的一部分实际已经有锁进行保护,这样的好处允许其他请求锁在表页级别上进行检查,减 少不必要的更细的锁请求,提高性能。比如在这种情况下,如果允许alter操作那么这个操作就会等待因为这里有表级排他锁,它提示alter操作该表有活 动。

6.3 跟踪Lock:Escalation事件

在profiler中设置只跟踪Lock:Escalation事件,锁升级事件。

6.4更新表中记录:

update test set name = ‘name’ where name = ‘kk’

在profiler中看到了Lock:Escalation事件被触发:

擦亮自己的眼睛去看SQL Server之谈谈锁机制

更新时的快照为(按顺序):

擦亮自己的眼睛去看SQL Server之谈谈锁机制

如上图:此时update操作以排他锁定它更新的行。

擦亮自己的眼睛去看SQL Server之谈谈锁机制

如上图:此时update操作以排他锁锁定了整个表,以架构稳定锁(Sch-S)锁定它相关的元数据表。

擦亮自己的眼睛去看SQL Server之谈谈锁机制

如上图:此时释放了对元数据表的架构稳定锁(Sch-S)锁,剩下对整个表的排他锁。

从上面的分析中,发现SQLServer锁机制是有点复杂的,不过也是很有意思的。研究后,你会发现它真的很智能。今天分析就到此结束,文中如有描述不当的地方,欢迎指出。共同进步才是硬道理。(来源:博客园)

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comment installer, désinstaller et réinitialiser la sauvegarde du serveur Windows Comment installer, désinstaller et réinitialiser la sauvegarde du serveur Windows Mar 06, 2024 am 10:37 AM

WindowsServerBackup est une fonction fournie avec le système d'exploitation WindowsServer, conçue pour aider les utilisateurs à protéger les données importantes et les configurations système, et à fournir des solutions complètes de sauvegarde et de récupération pour les petites, moyennes et grandes entreprises. Seuls les utilisateurs exécutant Server2022 et versions ultérieures peuvent utiliser cette fonctionnalité. Dans cet article, nous expliquerons comment installer, désinstaller ou réinitialiser WindowsServerBackup. Comment réinitialiser la sauvegarde de Windows Server Si vous rencontrez des problèmes avec la sauvegarde de votre serveur, si la sauvegarde prend trop de temps ou si vous ne parvenez pas à accéder aux fichiers stockés, vous pouvez envisager de réinitialiser vos paramètres de sauvegarde de Windows Server. Pour réinitialiser Windows

La version préliminaire de Windows Server 2025 accueille la mise à jour, Microsoft améliore l'expérience de test Insiders La version préliminaire de Windows Server 2025 accueille la mise à jour, Microsoft améliore l'expérience de test Insiders Feb 19, 2024 pm 02:36 PM

A l'occasion de la sortie de la version build 26040 de Windows Server, Microsoft a annoncé le nom officiel du produit : Windows Server 2025. La version build26040 de Windows11WindowsInsiderCanaryChannel est également lancée. Certains amis se souviennent peut-être encore qu'il y a de nombreuses années, quelqu'un a réussi à convertir Windows NT du mode poste de travail au mode serveur, montrant ainsi les points communs entre les différentes versions des systèmes d'exploitation Microsoft. Bien qu'il existe des différences évidentes entre la version actuelle du système d'exploitation serveur de Microsoft et Windows 11, ceux qui prêtent attention aux détails peuvent être curieux : pourquoi Windows Server a mis à jour la marque,

Comment modifier le nom de la version Nginx pour masquer n'importe quel serveur Web Comment modifier le nom de la version Nginx pour masquer n'importe quel serveur Web May 14, 2023 pm 09:19 PM

Comment modifier le nom par défaut de nginx, vous pouvez le déguiser un peu, ou vous pouvez l'installer Astuce : Généralement, les modifications sont apportées avant la compilation de nginx. Après modification, le code doit être recompilé comme suit : scr/core/nginx.conf#definenginx_version"1.4.7"#definenginx_ver"nginx/"n.

Compréhension approfondie des mécanismes de recalcul et de rendu de la mise en page CSS Compréhension approfondie des mécanismes de recalcul et de rendu de la mise en page CSS Jan 26, 2024 am 09:11 AM

La redistribution et le repaint CSS sont des concepts très importants dans l'optimisation des performances des pages Web. Lors du développement de pages Web, comprendre le fonctionnement de ces deux concepts peut nous aider à améliorer la vitesse de réponse et l'expérience utilisateur de la page Web. Cet article approfondira les mécanismes de redistribution et de repeinture CSS et fournira des exemples de code spécifiques. 1. Qu'est-ce que la redistribution CSS ? Lorsque la visibilité, la taille ou la position des éléments dans la structure DOM change, le navigateur doit recalculer et appliquer les styles CSS, puis réorganiser

Microsoft publie la version préliminaire 25335 de Windows Server vNext Microsoft publie la version préliminaire 25335 de Windows Server vNext Jan 10, 2024 am 08:49 AM

Alors que Microsoft a publié la mise à jour préliminaire de Win11 pour le bureau, il a également publié aujourd'hui la version préliminaire 25335 de Windows Server Long Term Service Channel (LTSC). Comme d'habitude, Microsoft n'a pas publié de journal complet des modifications, ni même fourni d'article de blog correspondant. Microsoft a ajusté le journal de mise à jour de la version préliminaire de Windows Server pour qu'il soit identique à la version Canary Channel. Si aucun nouveau contenu n'est introduit, le billet de blog officiel ne sera pas publié. Remarque d'IT Home : La marque du serveur n'a pas été mise à jour et est toujours Windows Server 2022 dans la version d'aperçu. De plus, Microsoft appelle ces versions Windows Server vNext au lieu de la version Windows Server 2019 déjà disponible sur le marché.

Mécanisme de chargement automatique en PHP Mécanisme de chargement automatique en PHP Jun 18, 2023 pm 01:11 PM

À mesure que le langage PHP devient de plus en plus populaire, les développeurs doivent utiliser de plus en plus de classes et de fonctions. Lorsqu'un projet grandit, l'introduction manuelle de toutes les dépendances devient peu pratique. À l’heure actuelle, un mécanisme de chargement automatique est nécessaire pour simplifier le processus de développement et de maintenance du code. Le mécanisme de chargement automatique est une fonctionnalité du langage PHP qui peut charger automatiquement les classes et interfaces requises au moment de l'exécution et réduire l'introduction manuelle des fichiers de classe. De cette façon, les programmeurs peuvent se concentrer sur le développement du code et réduire les erreurs et la perte de temps causées par une introduction manuelle fastidieuse aux cours. En PHP, généralement

Microsoft publie la mise à jour préliminaire de Windows Server 26080 : corrige l'échec du Feedback Hub Microsoft publie la mise à jour préliminaire de Windows Server 26080 : corrige l'échec du Feedback Hub Mar 14, 2024 pm 07:11 PM

IT House a rapporté le 14 mars qu'en plus de la mise à jour préliminaire de Windows 11 Build 26080 pour le bureau, Microsoft a également lancé aujourd'hui la mise à jour préliminaire de Windows Server Build 26080. En tant que dernière version préliminaire du prochain Windows Server Long Term Servicing Channel (LTSC), Windows Server Build 26080 fournit Data Center Edition et Standard Edition, et les utilisateurs peuvent choisir l'expérience de bureau et les options d'installation de Server Core. Cette version comprend également un pass annuel pour les hôtes de conteneurs et une version Azure spécifiquement pour l'évaluation des machines virtuelles. IT House interroge les médias sociaux X. Les commentaires des utilisateurs cliquent sur le bouton Copilot dans le coin inférieur droit.

Quelle est la logique de correspondance du serveur et de l'emplacement dans Nginx ? Quelle est la logique de correspondance du serveur et de l'emplacement dans Nginx ? May 12, 2023 am 11:10 AM

La logique de correspondance du serveur. Lorsque nginx détermine quel bloc de serveur exécuter la requête, il se concentre principalement sur les champs d'écoute et nom_serveur dans le bloc de serveur. Le champ d'écoute de la commande d'écoute définit l'adresse IP et le port de la réponse du serveur. Le champ n'est pas explicitement configuré, il écoutera par défaut 0.0.0.0:80 (root) ou 0.0.0.0:8080 (non-root) l'écoute peut être configurée comme : une combinaison d'adresse IP et de port, une seule adresse IP, en écoute. port 80 par défaut, un seul port et écoute sur toutes les interfaces IP par défaut Un chemin unixsocket où la dernière entrée n'est généralement utilisée que dans différents

See all articles