viernes, mayo 02, 2014

El ¿auto deadlock?

¡Últimamente me pasan unas cosas muy curiosas!

¿Qué puede causar que una sesión aparezca en la vista DBA_WAITERS como bloqueadora y como en espera? Fernando García sabe la respuesta, pues él "estaba allí" cuando sucedió.

Se trata de la sesión 80 y, como podéis ver, los bloqueos son todos sobre el objeto 524308 (una tabla).

Se admiten apuestas!!! La base de datos es una Oracle12c y hay tres sesiones en el juego.
PISTA: No hay, ni hubo, ni habrá en este ejemplo un deadlock ORA-00060.



PDB1@ORCL> select * from dba_waiters;

WAITING_SESSION HOLDING_SESSION LOCK_TYPE
--------------- --------------- --------------------------
MODE_HELD
----------------------------------------
MODE_REQUESTED   LOCK_ID1   LOCK_ID2
---------------------------------------- ---------- ----------
    80     44 Transaction
Exclusive
Exclusive     524308  2374

    72     44 Transaction
Exclusive
Share     524308  2374

    80     80 Transaction
None
Exclusive     524308  2374

    72     80 Transaction
None
Share     524308  2374

10 comentarios:

Javier Morales dijo...

PISTA: parece que los tipos de bloqueos no son la clave...

PDB1@ORCL> select * from dba_waiters;

WAITING_SESSION HOLDING_SESSION LOCK_TYPE
--------------- --------------- --------------------------
MODE_HELD
----------------------------------------
MODE_REQUESTED LOCK_ID1 LOCK_ID2
---------------------------------------- ---------- ----------
80 44 Transaction
Exclusive
Exclusive 393235 2397

72 44 Transaction
Exclusive
Share 393235 2397

80 72 Transaction
None
Exclusive 393235 2397

72 72 Transaction
None
Share 393235 2397


Unknown dijo...

Foreing keys y tablas vacías?

Javier Morales dijo...

Frío, frío....... :-P

Pedro Marco Ortega dijo...

¿Intentos de Conexión? ¿La tabla 393235 es la v$_user?

Javier Morales dijo...

Frío Fríoooo...

La tabla tiene una fila.
Una sesión hace UPDATE sobre esa fila.
Otra sesión hace un DELETE sobre esa fila (waiting).
Una tercera sesión hace un ALTER TABLE ADD column.

Curioso, no??? :))))))

bukerleon dijo...

EL UNDO ESTA GARANTIZADO TARDARÁ EL TIEMPO NECESARIO

bukerleon dijo...
Este comentario ha sido eliminado por el autor.
bukerleon dijo...
Este comentario ha sido eliminado por el autor.
bukerleon dijo...
Este comentario ha sido eliminado por el autor.
bukerleon dijo...
Este comentario ha sido eliminado por el autor.