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 avecDBMS_PIPEpermet à une ou plusieurs sessions de base de données de communiquer dans la même région ou entre des régions avec des messages stockés dans le magasin d'objets en nuage. - Créer un canal persistant explicite et envoyer un message
Décrit les étapes de création d'un canal persistant avec un nom de canal spécifié (canal explicite). - Extraire un message persistant sur la même base de données
Décrit les étapes pour extraire un message persistant à partir d'un canal explicite sur la même instance de base de données d'IA autonome (instance où le message a été envoyé). - Extraire un message persistant en créant un canal sur une autre base de données
Décrit les étapes pour extraire 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. - Supprimer un canal persistant
Décrit les étapes pour supprimer un canal persistant.
À propos de la messagerie persistante avec DBMS_PIPE
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.
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.eps
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 d'écritures et de lectures simultanées. À l'aide d'un canal de messagerie persistant,
DBMS_PIPEautorise une seule opération, l'envoi d'un message ou d'un message de réception à être actif à un moment donné. 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 DBMS_CLOUD. 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.
DBMS_PIPE Privilèges - Autorisation et sécurité
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).
Limitation de 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'intelligence artificielle 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électionner un jeu de caractères pour une base de données d'IA autonome.
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).
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.
Pour plus d'informations, voir Procédure SET_CREDENTIAL_NAME et Procédure SET_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.
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.