Utiliser la messagerie persistante avec les messages stockés dans un magasin d'objets en nuage
L'ensemble DBMS_PIPE offre des fonctionnalités étendues sur Autonomous AI Database afin de prendre en charge les messages persistants, où les messages sont stockés dans le magasin d'objets en nuage.
À propos de la messagerie persistante avec DBMS_PIPE
La messagerie persistante avec DBMS_PIPE permet à une ou plusieurs sessions de base de données de communiquer dans la même région ou entre régions avec des messages stockés dans le magasin d'objets en nuage.
Messages persistants dans DBMS_PIPE :
-
Permet d'envoyer et de récupérer des messages très volumineux.
-
Prise en charge de l'envoi d'un grand nombre de messages de canal.
-
Prise en charge de l'envoi et de la réception de messages dans une seule base de données, dans plusieurs bases de données et entre des bases de données de différentes régions.
-
Prendre en charge plusieurs canaux à l'aide du même URI d'emplacement du magasin d'objets en nuage.
Les canaux de messagerie persistants peuvent être créés dans n'importe lequel des types DBMS_PIPE pris en charge :
-
Canal implicite : Créé automatiquement lorsqu'un message est envoyé avec un nom de canal inconnu à l'aide de la fonction
DBMS_PIPE.SEND_MESSAGE. -
Canal explicite : Créé à l'aide de la fonction
DBMS_PIPE.CREATE_PIPEavec un nom de canal spécifié par l'utilisateur. -
Public Pipe : Accessible par tout utilisateur disposant de l'autorisation
EXECUTEsur l'ensembleDBMS_PIPE. -
Canal privé : Accessible par des sessions avec le même utilisateur que le créateur du canal.
Note : Oracle recommande de créer un canal explicite avant d'envoyer ou de recevoir des messages avec une messagerie persistante. La création d'un canal explicite avec DBMS_PIPE.CREATE_PIPE garantit que le canal est créé avec les autorisations d'accès voulues, publiques ou privées (en définissant le paramètre private).
Voici le flux de travail général pour DBMS_PIPE avec messagerie persistante :
Description de l'illustration database-pipe-persistent-messaging.svg
Les applications existantes utilisant DBMS_PIPE peuvent continuer à fonctionner avec un minimum de modifications. Vous pouvez configurer des applications existantes qui utilisent DBMS_PIPE avec un objet de données d'identification et un URI d'emplacement à l'aide d'un déclencheur de connexion ou d'un autre sous-programme d'initialisation. Après avoir défini les données d'identification et l'URI d'emplacement DBMS_PIPE, aucune autre modification n'est nécessaire pour utiliser la messagerie persistante. Toute utilisation ultérieure du canal stocke les messages dans le magasin d'objets en nuage plutôt que dans la mémoire de la base de données. Cela vous permet de remplacer la méthode de stockage des messages en mémoire par celle du stockage d'objets en nuage persistant, avec un minimum de modifications.
Présentation et fonctionnalités de la messagerie persistante
Caractéristiques de DBMS_PIPE à l'aide de la messagerie persistante :
-
Les messages peuvent être envoyés et extraits sur plusieurs instances de base de données autonome avec intelligence artificielle dans la même région ou entre des régions.
-
Les messages persistants sont garantis d'être écrits ou lus par un seul processus. Cela évite les incohérences dans le contenu des messages en raison de lectures et d'écritures simultanées.
DBMS_PIPEautorise une seule opération, l'envoi d'un message ou la réception d'un message à être active à un moment donné et ces opérations sont protégées par un mécanisme de verrouillage. Toutefois, si une opération n'est pas possible en raison d'une opération en cours, le processus tente de nouveau périodiquement jusqu'à ce que la valeurtimeoutsoit atteinte. -
DBMS_PIPEutiliseDBMS_CLOUDpour accéder au magasin d'objets en nuage. Les messages peuvent être stockés dans n'importe quel magasin d'objets en nuage pris en charge. Pour plus d'informations, voir Formats d'URI du service de stockage d'objets en nuage. -
DBMS_PIPEutiliseDBMS_CLOUDpour accéder au magasin d'objets en nuage et tous les types de données d'identification pris en charge sont disponibles :DBMS_CLOUD.CREATE_CREDENTIAL: Voir Procédure CREATE_CREDENTIAL pour plus d'informations.
Autorisation et sécurité des privilèges DBMS_PIPE
Les procédures DBMS_PIPE s'exécutent avec les droits de l'appelant. Les canalisations privées appartiennent à l'utilisateur courant et une canalisation privée créée par un utilisateur ne peut être utilisée que par le même utilisateur. Cela s'applique à la fois aux canaux en mémoire et aux canaux de messagerie persistants où les messages sont stockés dans le magasin d'objets en nuage. L'envoi et la réception de messages sont exécutés dans le schéma de l'appelant.
À l'aide de canaux privés, où les messages sont stockés dans le magasin d'objets en nuage, un objet de données d'identification est requis pour l'authentification avec le magasin d'objets en nuage identifié par le paramètre location_uri. L'utilisateur appelant doit disposer du privilège EXECUTE sur l'objet de données d'identification spécifié avec le paramètre credential_name utilisé pour accéder au magasin d'objets.
Pour utiliser un canal public, l'utilisateur, la session de base de données, doit disposer du privilège d'exécution sur DBMS_PIPE. Pour un canal public utilisant une messagerie persistante et stockant des messages dans le magasin d'objets en nuage, l'utilisateur, la session de base de données, doit disposer du privilège d'exécution sur DBMS_CLOUD et du privilège d'exécution sur l'objet de données d'identification (ou vous pouvez créer un objet de données d'identification autorisé à accéder à l'URI d'emplacement qui contient le message).
Limite DBMS_PIPE
L'ensemble DBMS_PIPE ne prend pas en charge l'envoi de messages entre des bases de données qui utilisent des jeux de caractères différents. Par exemple, si vous avez une instance de base de données d'IA autonome qui utilise AL32UTF8 et une autre qui utilise WE8MSWIN1252, vous ne pouvez pas envoyer de messages avec DBMS_PIPE entre ces deux bases de données. Dans ce cas, le système générera l'erreur ORA-12704 si vous tentez d'envoyer des messages avec DBMS_PIPE entre ces deux bases de données.
Pour plus d'informations, voir Sélection de jeux de caractères pour Autonomous AI Database.
Créer un canal persistant explicite et envoyer un message
Décrit les étapes de création d'un tuyau persistant avec un nom de tuyau spécifié (tuyau explicite).
-
Stockez vos données d'identification de magasin d'objets à l'aide de la procédure
DBMS_CLOUD.CREATE_CREDENTIAL. Par exemple :BEGIN DBMS_CLOUD.CREATE_CREDENTIAL( credential_name => 'my_persistent_pipe_cred', username => 'adb_user@example.com', password => 'password' ); END; /Cette opération stocke les données d'identification dans la base de données dans un format chiffré. Vous pouvez utiliser n'importe quel nom pour les données d'identification. Notez que cette étape n'est requise qu'une seule fois, sauf si les données d'identification du magasin d'objets changent. Après avoir stocké les données d'identification, vous pouvez utiliser le même nom pour accéder au magasin d'objets en nuage afin d'envoyer et de recevoir des messages avec
DBMS_PIPE.Pour des informations détaillées sur les paramètres, voir Procédure CREATE_CREDENTIAL. Pour Oracle Cloud Infrastructure Object Storage, il est nécessaire que les données d'identification utilisent l'authentification native d'Oracle Cloud Infrastructure.
Note : Certains outils tels que SQL*Plus et SQL Developer utilisent le caractère esperluette (
&) comme caractère spécial. Si votre mot de passe contient le caractère esperluette, utilisez la commandeSET DEFINE OFFdans ces outils, comme illustré dans l'exemple, pour désactiver le caractère spécial et obtenir les données d'identification créées correctement. -
Créez un canal explicite pour envoyer et extraire des messages. Par exemple, créez un canal nommé
ORDER_PIPE.DECLARE r_status INTEGER; BEGIN r_status := DBMS_PIPE.CREATE_PIPE(pipename => 'ORDER_PIPE'); END; /Pour plus d'informations, voir Fonction CREATE_PIPE.
-
Vérifiez que le tuyau est créé.
SELECT ownerid, name, type FROM v$db_pipes WHERE name = 'ORDER_PIPE';OWNERID NAME TYPE ------- ---------- ------- 80 ORDER_PIPE PRIVATE -
Utilisez les procédures
DBMS_PIPEpour définir les données d'identification et l'URI d'accès par défaut pour stocker les messages persistants dans le magasin d'objets en nuage.BEGIN DBMS_PIPE.SET_CREDENTIAL_NAME('my_persistent_pipe_cred'); DBMS_PIPE.SET_LOCATION_URI('https://objectstorage.us-phoenix-1.oraclecloud.com/n/namespace-string/b/bucketname1/'); END; /Ces procédures définissent le nom des données d'identification par défaut et l'URI d'emplacement par défaut à utiliser avec les procédures
DBMS_PIPE.Si vous utilisez Oracle Cloud Infrastructure Object Storage pour stocker des messages, vous pouvez utiliser des URI natifs d'Oracle Cloud Infrastructure ou des URI Swift. Toutefois, l'URI d'emplacement et les données d'identification doivent correspondre au type suivant :
-
Si vous utilisez un format d'URI natif pour accéder à Oracle Cloud Infrastructure Object Storage, vous devez utiliser l'authentification native des clés de signature Oracle Cloud Infrastructure dans l'objet de données d'identification.
-
Si vous utilisez le format d'URI Swift pour accéder à Oracle Cloud Infrastructure Object Storage, vous devez utiliser une authentification par jeton d'authentification dans l'objet de données d'identification.
Pour plus d'informations, voir Procédure SET_CREDENTIAL_NAME et Fonction GET_LOCATION_URI.
-
-
Emballez et envoyez un message sur le tuyau.
DECLARE l_result INTEGER; l_date DATE; BEGIN l_date := sysdate; DBMS_PIPE.PACK_MESSAGE(l_date); -- date of order DBMS_PIPE.PACK_MESSAGE('C123'); -- order number DBMS_PIPE.PACK_MESSAGE(5); -- number of items in order DBMS_PIPE.PACK_MESSAGE('Printers'); -- type of item in order l_result := DBMS_PIPE.SEND_MESSAGE( pipename => 'ORDER_PIPE', credential_name => DBMS_PIPE.GET_CREDENTIAL_NAME, location_uri => DBMS_PIPE.GET_LOCATION_URI); IF l_result = 0 THEN DBMS_OUTPUT.put_line('DBMS_PIPE sent order successfully'); END IF; END; /Pour plus d'informations, voir Procédures PACK_MESSAGE dans Informations de référence sur les ensembles et les types PL/SQL pour Oracle Database 19c ou Informations de référence sur les ensembles et les types PL/SQL pour Oracle Database 26ai et Fonction SEND_MESSAGE.
Extraire un message persistant sur la même base de données
Décrit les étapes d'extraction d'un message persistant à partir d'un canal explicite sur la même instance de base de données d'intelligence artificielle autonome (instance où le message a été envoyé).
Sur une instance de base de données Autonomous AI Database, vous pouvez recevoir des messages envoyés à un canal à partir d'une autre session. Les procédures DBMS_PIPE sont des procédures de droits de l'appelant et sont exécutées en tant qu'utilisateur appelé courant.
Les tuyaux privés appartiennent à l'utilisateur courant qui crée le tuyau. Les tuyaux privés ne sont accessibles que par le même utilisateur qui a créé le tuyau. Cela s'applique aux canaux utilisant des messages en mémoire et aux canaux utilisant des messages persistants avec des messages stockés dans le magasin d'objets en nuage.
Les canaux publics sont accessibles par toute session de base de données disposant du privilège d'exécution sur DBMS_PIPE. Cela s'applique aux canaux utilisant des messages en mémoire et aux canaux utilisant des messages persistants avec des messages stockés dans le magasin d'objets en nuage.
-
Vérifiez que le tuyau est créé.
SELECT ownerid, name, type FROM v$db_pipes WHERE name = 'ORDER_PIPE';OWNERID NAME TYPE ------- ---------- ------- 80 ORDER_PIPE PRIVATELorsque vous êtes sur la même instance de base de données d'intelligence artificielle autonome et que le canal existe, vous n'avez pas besoin d'exécuter
DBMS_PIPE.CREATE_PIPEavant de recevoir un message. Cela s'applique lorsque le canal a été créé sur la même instance, comme indiqué dans Créer un canal persistant explicite et envoyer un message. -
Recevez un message du tuyau.
DECLARE message1 DATE; message2 VARCHAR2(100); message3 INTEGER; message4 VARCHAR2(100); l_result INTEGER; BEGIN DBMS_PIPE.SET_CREDENTIAL_NAME('my_persistent_pipe_cred'); DBMS_PIPE.SET_LOCATION_URI('https://objectstorage.us-phoenix-1.oraclecloud.com/n/namespace-string/b/bucketname1/'); l_result := DBMS_PIPE.RECEIVE_MESSAGE ( pipename => 'ORDER_PIPE', timeout => DBMS_PIPE.MAXWAIT, credential_name => DBMS_PIPE.GET_CREDENTIAL_NAME, location_uri => DBMS_PIPE.GET_LOCATION_URI); IF l_result = 0 THEN DBMS_PIPE.unpack_message(message1); DBMS_PIPE.unpack_message(message2); DBMS_PIPE.unpack_message(message3); DBMS_PIPE.unpack_message(message4); DBMS_OUTPUT.put_line('Order Received Successfully On: ' || TO_CHAR(sysdate, 'dd-mm-yyyy hh24:mi:ss')); DBMS_OUTPUT.put_line('Date of Order: ' || message1); DBMS_OUTPUT.put_line('Order Number: ' || message2); DBMS_OUTPUT.put_line('Number of Items In Order: ' || message3); DBMS_OUTPUT.put_line('Item Type in Order: ' || message4); END IF; END; /Lorsque vous êtes sur la même instance de base de données d'intelligence artificielle autonome, les données d'identification existent déjà et vous n'avez pas besoin d'exécuter
DBMS_CLOUD.CREATE_CREDENTIALpour recevoir un message. Cela s'applique lorsque le canal a été créé sur la même instance, comme indiqué dans Créer un canal persistant explicite et envoyer un message.
Pour plus d'informations, voir Procédure SET_CREDENTIAL_NAME et Fonction GET_LOCATION_URI.
Pour plus d'informations, voir Fonction RECEIVE_MESSAGE.
Extraire un message persistant en créant un tuyau sur une autre base de données
Décrit les étapes d'extraction d'un message persistant stocké dans le magasin d'objets en nuage avec un canal explicite sur une instance de base de données IA autonome différente de l'instance qui a envoyé le message.
-
Stockez vos données d'identification de magasin d'objets à l'aide de la procédure
DBMS_CLOUD.CREATE_CREDENTIAL. Par exemple :BEGIN DBMS_CLOUD.CREATE_CREDENTIAL( credential_name => 'my_persistent_pipe_cred', username => 'adb_user@example.com', password => 'password' ); END; /Cette opération stocke les données d'identification dans la base de données dans un format chiffré. Vous pouvez utiliser n'importe quel nom pour les données d'identification. Notez que cette étape n'est requise qu'une seule fois, sauf si les données d'identification du magasin d'objets changent. Une fois les données d'identification stockées, vous pouvez utiliser le même nom pour accéder au magasin d'objets en nuage afin d'envoyer et de recevoir des messages avec
DBMS_PIPE.Pour des informations détaillées sur les paramètres, voir Procédure CREATE_CREDENTIAL.
Note : Certains outils tels que SQL*Plus et SQL Developer utilisent le caractère esperluette (
&) comme caractère spécial. Si votre mot de passe contient le caractère esperluette, utilisez la commandeSET DEFINE OFFdans ces outils, comme illustré dans l'exemple, pour désactiver le caractère spécial et obtenir les données d'identification créées correctement. -
Créez un canal explicite portant le même nom que le canal qui a envoyé le message. Par exemple, créez un canal nommé
ORDER_PIPE.DECLARE r_status INTEGER; BEGIN r_status := DBMS_PIPE.CREATE_PIPE(pipename => 'ORDER_PIPE'); END; /Voir Fonction CREATE_PIPE.
-
Vérifiez que le tuyau est créé.
SELECT ownerid, name, type FROM v$db_pipes WHERE name = 'ORDER_PIPE';OWNERID NAME TYPE ------- ---------- ------- 80 ORDER_PIPE PRIVATE -
Utilisez les procédures
DBMS_PIPEpour définir les données d'identification et l'URI d'accès par défaut pour le magasin d'objets afin queDBMS_PIPEpuisse accéder au message persistant.BEGIN DBMS_PIPE.SET_CREDENTIAL_NAME('my_persistent_pipe_cred'); DBMS_PIPE.SET_LOCATION_URI('https://objectstorage.us-phoenix-1.oraclecloud.com/n/namespace-string/b/bucketname1/'); END; /Ces procédures définissent le nom des données d'identification par défaut et l'URI d'emplacement par défaut à utiliser avec les procédures
DBMS_PIPE.Si vous utilisez Oracle Cloud Infrastructure Object Storage pour stocker des messages, vous pouvez utiliser des URI natifs d'Oracle Cloud Infrastructure ou des URI Swift. Toutefois, l'URI d'emplacement et les données d'identification doivent correspondre au type suivant :
-
Si vous utilisez un format d'URI natif pour accéder à Oracle Cloud Infrastructure Object Storage, vous devez utiliser l'authentification native des clés de signature Oracle Cloud Infrastructure dans l'objet de données d'identification.
-
Si vous utilisez le format d'URI Swift pour accéder à Oracle Cloud Infrastructure Object Storage, vous devez utiliser une authentification par jeton d'authentification dans l'objet de données d'identification.
Pour plus d'informations, voir Procédure SET_CREDENTIAL_NAME et Fonction GET_LOCATION_URI.
-
-
Recevez un message à partir du tuyau persistant.
DECLARE message1 DATE; message2 VARCHAR2(100); message3 INTEGER; message4 VARCHAR2(100); l_result INTEGER; BEGIN DBMS_PIPE.SET_CREDENTIAL_NAME('my_persistent_pipe_cred'); DBMS_PIPE.SET_LOCATION_URI('https://objectstorage.us-phoenix-1.oraclecloud.com/n/namespace-string/b/bucketname1/'); l_result := DBMS_PIPE.RECEIVE_MESSAGE ( pipename => 'ORDER_PIPE', timeout => DBMS_PIPE.MAXWAIT, credential_name => DBMS_PIPE.GET_CREDENTIAL_NAME, location_uri => DBMS_PIPE.GET_LOCATION_URI); IF l_result = 0 THEN DBMS_PIPE.unpack_message(message1); DBMS_PIPE.unpack_message(message2); DBMS_PIPE.unpack_message(message3); DBMS_PIPE.unpack_message(message4); DBMS_OUTPUT.put_line('Order Received Successfully On: ' || TO_CHAR(sysdate, 'dd-mm-yyyy hh24:mi:ss')); DBMS_OUTPUT.put_line('Date of Order: ' || message1); DBMS_OUTPUT.put_line('Order Number: ' || message2); DBMS_OUTPUT.put_line('Number of Items In Order: ' || message3); DBMS_OUTPUT.put_line('Item Type in Order: ' || message4); END IF; END; /Pour plus d'informations, voir Fonction RECEIVE_MESSAGE.
Supprimer un tuyau persistant
Décrit les étapes de suppression d'un tuyau persistant.
Les canaux persistants envoient et reçoivent des messages en stockant des messages dans le magasin d'objets en nuage. Utilisez DBMS_PIPE.REMOVE_PIPE pour supprimer un canal persistant dans une instance de base de données d'intelligence artificielle autonome.
-
Appelez la fonction
DBMS_PIPE.REMOVE_PIPEpour supprimer un canal.DECLARE l_result INTEGER; BEGIN l_result := DBMS_PIPE.REMOVE_PIPE('ORDER_PIPE'); END; /La fonction
REMOVE_PIPEsupprime le canal de l'instance de base de données d'IA autonome où il s'exécute, maisREMOVE_PIPEn'affecte pas les autres instances de base de données d'IA autonome avec un canal portant le même nom qui utilise le même URI d'emplacement. -
Dans l'instance de base de données de l'IA autonome, si vous exécutez
DBMS_PIPE.REMOVE_PIPE, vérifiez que le canal est supprimé.SELECT ownerid, name, type FROM v$db_pipes WHERE name = 'ORDER_PIPE';No rows selected