PDF de programación - Implementando Transaction Guard ODP NET 12c

Imágen de pdf Implementando Transaction Guard ODP NET 12c

Implementando Transaction Guard ODP NET 12cgráfica de visualizaciones

Actualizado el 21 de Marzo del 2018 (Publicado el 21 de Febrero del 2018)
541 visualizaciones desde el 21 de Febrero del 2018
351,4 KB
9 paginas
Creado hace 10a (11/02/2014)
Implementando Transaction Guard con ODP.NET 12c

Por Francisco Riccio



Introducción

Nuestras aplicaciones transaccionales constantemente envían transacciones a la base de datos, pero
que sucedería si al momento de confirmar las operaciones que componen nuestra transacción se
presenta un problema en la comunicación de red ó una caída en la instancia de base de datos que se
encuentra conectada la aplicación.

Basado en el escenario presentado, podemos tener las siguientes situaciones:



La base de datos confirmó el cambio pero la aplicación no pudo obtener el mensaje de
confirmación.

 El incidente ocurrió antes que se pudiera realizar la confirmación de la transacción.

En ambos puntos, la aplicación tiene la duda si debe volver a relanzar la transacción y si lo hace, se corre
el riesgo de duplicar información.

Para evitar estos escenarios y el programa pueda tener la información necesaria si debe o no relanzar su
transacción nuevamente, se debe implementar Transaction Guard; el cual es un nuevo feature de Oracle
Database 12c y disponible únicamente en edición Enterprise Edition.

Oracle Database 12c introduce un nuevo concepto llamado Logical Transaction Identifier (LTXID), el cual
es un código único generado al inicio de una transacción para una conexión de base de datos específica.
Al generarse un LTXID en el servidor de base de datos, este es devuelto a la aplicación cliente y en caso
de un incidente con la instancia de base de dato donde la aplicación se encuentra conectada, el código
de la aplicación podrá consultar el LTXID después de haber hecho el failover de conexión y saber el
estado de su última transacción. Con dicha información, la aplicación tomará la decisión de replicar de
nuevo la última transacción que estuvo pendiente.

Figura 1



La figura 1 muestra como un LTXID es generado de manera única por conexión de base de datos por
cada transacción que se inicia y automáticamente es enviado a la aplicación cliente para su
conocimiento.



1

(1) Inicio de una Transacción(2) Envío LTXID asignado a la Transacción(3) Operaciones DML Los LTXID generados por la base de datos son almacenados en la tabla SYS. LTXID_TRANS y serán
retenidos durante 24 horas (siendo 30 días la máxima retención) posterior al COMMIT. Esta tabla se
encuentra en el tablespace SYSAUX y se encuentra particionada. La cantidad de particiones que se crean
sobre esta tabla es igual a la cantidad de instancias que forman la base de datos del Oracle RAC. Cuando
añadimos una nueva instancia a nuestra base de datos Oracle RAC se crea una nueva partición sobre la
tabla.

En la implementación que más adelante se detallará, se desarrolló sobre una base de datos Oracle RAC
12c que se conforma de 2 instancias de base de datos. Basado en esta configuración, podremos ver que
la tabla TXID_TRANS tiene 2 particiones:

Podemos mover las particiones a otros tablespace si lo vemos conveniente. Este procedimiento es
completamente válido con el siguiente script.

alter TABLE LTXID_TRANS move partition LTXID_TRANS_# tablespace <nombre_tablespace>;





Transaction Guard soporta los siguientes escenarios:

 Transacciones locales.

 Operaciones DML & DCL.

 Transacciones distribuidas.

 Transacciones remotas.

 Transacciones con paralelismo.

 AUTO-COMMIT configurado en el lado de la aplicación cliente.

 Disponible para los drivers 12c: JDBC Thin, OCI y ODP.NET (Unmanaged driver, más información:

http://docs.oracle.com/cd/E16655_01/win.121/e17732/intro004.htm#ODPNT8147).

Escenarios excluidos:

 Autónomas transacciones (PRAGMA AUTONOMOUS_TRANSACTION).

 Transacciones mediante el estándar XA.



2

 Replicación a GoldenGate y Standby Database Lógicos.

 Active Dataguard con dblinks de escritura/lectura para transacciones de reenvío.



Transaction Guard requiere como requisito que nuestra aplicación sea capaz de recibir eventos Fast
Application Notification (FAN).



Nota 1: Existe un feature de Oracle Database 12c llamado Application Continuity el cual está bien
relacionado con Transaction Guard. Application Continuity permite a una aplicación automáticamente
disparar nuevamente la transacción que fue conocida por la aplicación como fallida gracias a Transaction
Guard.

Nota 2: La versión Oracle Client 12.1 no tiene implementado aún Application Continuity para ODP.NET
posiblemente lo tendremos en la versión Oracle Client 12.2.

Nota 3: La habilitación de Transaction Guard en promedio incrementa el uso del CPU en menos de 1%,
siendo imperceptible.































3

Implementación - Transaction Guard

Nuestra aplicación de ejemplo permitirá registrar productos. Si en caso ocurriera alguna una incidencia
con la instancia de base de datos donde se encuentra conectada nuestra aplicación, esté será capaz de
reenviar nuevamente la operación fallida sin intervención del usuario final.

Nuestra base de datos está en una versión Oracle RAC 12.1 sobre una plataforma Oracle Linux 5.10 x64
bits.



I) Base de Datos

a) Nuestra base de datos debe presentar un servicio con las opciones COMMIT_OUTCOME y
RETENTION.

COMMIT_OUTCOME: Determina si los LTXID serán registrados.

RETENTION: Determina el tiempo que un LTXID será almacenado en la base datos después que su
transacción asociada haya sido confirmada.



Nota 1: No podemos utilizar el servicio por default que está configurado al parámetro DB_NAME o
DB_UNIQUE_NAME.





4

Nota 2: Es importante que el atributo AQ HA Notifications lo tengamos con el valor de true. Este
parámetro vino como configuración en la recepción de eventos FAN, el cual es requerido por
Transaction Guard. En caso no estuviera en true, debemos ejecutar el siguiente comando:

Posteriormente lo siguiente:

execute DBMS_AQADM.GRANT_QUEUE_PRIVILEGE('DEQUEUE','SYS.SYS$SERVICE_METRICS',



'<NOMBRE_USUARIO_BD> '); (cid:13)



b) Garantizamos permisos al usuario de base de datos sobre el paquete DBMS_APP_CONT.

El paquete DBMS_APP_CONT ofrece las interfaces para determinar si una transacción pudo ser
confirmada en la base de datos.



II) Aplicación

a) Creamos la tabla que almacenará los productos registrados por la aplicación.











5

b) Código .NET

b.1) Cadena de Conexión.

<?xml version="1.0" encoding="utf-8" ?>

<configuration>

<appSettings>

<add key="CONEXION" value="Data Source=(DESCRIPTION = (ADDRESS_LIST = (ADDRESS =
(PROTOCOL = TCP)(HOST = srvscan-121.riccio.com)(PORT =
1521)))(FAILOVER=YES)(LOAD_BALANCE=YES)(CONNECT_DATA=(SERVICE_NAME = PROD)(SERVER =
DEDICATED)));User Id=friccio;Password=oracle;Pooling=true;Min Pool Size=1;Max Pool Size=1;HA
Events=true;Validate Connection=true"/>

</appSettings>

</configuration>



Es importante que tengamos definido las propiedades: Pooling y HA Events que permitirán habilitar la
recepción de eventos FAN.

b.2) Interfaz.









6

b.3) Proyecto



b.4) Código

Clase EProducto

Click en el Botón Registrar:











7



<OracleConnection>.LogicalTransactionId, devuelve el LTXID que se compone por un arreglo de enteros.

cn.GetLogicalTransactionStatus(<OracleLogicalTransactionStatus >), devuelve el estado de la última
transacción enviada a la base de datos.

La clase OracleLogicalTransactionStatus tiene 2 propiedades que son de interés para nuestra aplicación
con la finalidad de definir una acción concreta:







8

 Propiedad Committed, devolverá true o false si la instancia de base de datos pudo confirmar la

transacción.

 Propiedad UserCallCompleted, indicará si la aplicación no pudo conseguir un resultado

esperado. Resultados como: bind variables de retorno ó número de filas modificadas, etc.

En nuestro caso hemos tomado la decisión de relanzar la transacción en caso la transacción no se pudo
confirmar en la base de datos.



Conclusiones

Durante versiones previas a Oracle Database 12c, teníamos a disposición para nuestras aplicaciones
mecanismos de failover de conexión de base de datos e inclusive continuidad de nuestras operaciones
SELECT en un escenario de faliover ocasionado por algún incidente que hubiera ocurrido.

Ahora con Transaction Guard podemos dar continuidad a nuestras operaciones DML & DDL & DCL,
permitiendo un continuidad completa a la aplicación sin el temor de duplicar información, evitando
largas líneas de código personalizado de los desarrolladores para obtener el mismo objetivo, donde
dichos códigos generaban un re-trabajo a la base de datos perjudicando su desempeño.



Publicado por Ing. Francisco Riccio. Es un IT Architect en IBM Perú e instructor de cursos oficiales de
certificación Oracle. Está reconocido por Oracle como un Oracle ACE y certificado en productos de
Oracle Application & Base de Datos.

e-mail: [email protected]

web: www.friccio.com



9
  • Links de descarga
http://lwp-l.com/pdf8935

Comentarios de: Implementando Transaction Guard ODP NET 12c (0)


No hay comentarios
 

Comentar...

Nombre
Correo (no se visualiza en la web)
Valoración
Comentarios...
CerrarCerrar
CerrarCerrar
Cerrar

Tienes que ser un usuario registrado para poder insertar imágenes, archivos y/o videos.

Puedes registrarte o validarte desde aquí.

Codigo
Negrita
Subrayado
Tachado
Cursiva
Insertar enlace
Imagen externa
Emoticon
Tabular
Centrar
Titulo
Linea
Disminuir
Aumentar
Vista preliminar
sonreir
dientes
lengua
guiño
enfadado
confundido
llorar
avergonzado
sorprendido
triste
sol
estrella
jarra
camara
taza de cafe
email
beso
bombilla
amor
mal
bien
Es necesario revisar y aceptar las políticas de privacidad