Bonjour,
J’ai un problème assez aléatoire avec le rebuild des index sur une BD sur un serveur abonnés . L’étape se plante de temps en temps avec le message suivant
« L'exécution de la requête « ALTER INDEX XXXX ] ON [dbo].[X... » a échoué avec l'erreur suivante : « La transaction (ID de processus 61) a été bloquée sur les ressources verrou par un autre processus et a été choisie comme victime »
J’ai donc essayé, ds mon plan de maintenance de récupérer des infos avec les requêtes suivantes :
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21
| SELECT L.request_session_id AS SPID, DB_NAME(L.resource_database_id) AS DatabaseName,
O.Name AS LockedObjectName,
P.object_id AS LockedObjectId,
L.resource_type AS LockedResource,
L.request_mode AS LockType,
ST.text AS SqlStatementText,
ES.login_name AS LoginName,
ES.host_name AS HostName,
TST.is_user_transaction as IsUserTransaction,
AT.name as TransactionName,
CN.auth_scheme as AuthenticationMethod
FROM sys.dm_tran_locks L
JOIN sys.partitions P ON P.hobt_id = L.resource_associated_entity_id
JOIN sys.objects O ON O.object_id = P.object_id
JOIN sys.dm_exec_sessions ES ON ES.session_id = L.request_session_id
JOIN sys.dm_tran_session_transactions TST ON ES.session_id = TST.session_id
JOIN sys.dm_tran_active_transactions AT ON TST.transaction_id = AT.transaction_id
JOIN sys.dm_exec_connections CN ON CN.session_id = ES.session_id
CROSS APPLY sys.dm_exec_sql_text(CN.most_recent_sql_handle) AS ST
WHERE resource_database_id = db_id()
ORDER BY L.request_session_id |
et
select session_id, blocking_session_id from sys.dm_exec_requests where blocking_session_id != 0
(Après avoir activer les traces)
mais ça ne me revoie rien :/
D’ailleurs cette tâche a-t-elle un réel intérêt si elle s’effectue auparavant sur le distributeur ? il me semble que les index sont aussi répliqué ? Non ?
Cordialement,
Partager