Creación de enlaces de base de datos desde una base de datos de IA autónoma a una instancia de Oracle Database accesible públicamente con una cartera (mTLS)
Puede crear enlaces de base de datos desde una base de datos de IA autónoma a una base de datos Oracle de destino que esté en un punto final público.
Para utilizar enlaces de base de datos con la base de datos de IA autónoma, la base de datos de destino se debe configurar para utilizar TCP/IP con autenticación SSL (TCPS). Las bases de datos de IA autónomas utilizan TCP/IP con autenticación SSL (TCPS) por defecto, por lo que no es necesario realizar ninguna configuración adicional en la base de datos de destino para enlazar a otra base de datos de IA autónoma. Otras bases de datos Oracle se deben configurar para utilizar TCP/IP con autenticación SSL (TCPS). Consulte Configuring Secure Sockets Layer Authentication en la Oracle Database 19c Security Guide u Oracle Database 26ai Security Guide para obtener más información.
Para crear enlaces de base de datos a un destino público, se debe poder acceder a Oracle Database de destino. Algunas bases de datos pueden limitar el acceso (por ejemplo, mediante listas de control de acceso). Asegúrese de activar la base de datos de destino para permitir el acceso desde la base de datos de origen para que el enlace de base de datos funcione. Si limita el acceso con listas de control de acceso (ACL), puede encontrar la dirección IP de salida de su base de datos de IA autónoma de origen y permitir que esa dirección IP se conecte a su base de datos de destino.
Consulte Cómo crear un enlace de base de datos desde la base de datos de IA autónoma a una instancia de Database Cloud Service para obtener más información.
Para crear enlaces de base de datos a una base de datos Oracle de destino con una cartera (mTLS):
-
Copie la cartera de la base de datos de destino,
cwallet.sso, que contiene los certificados de la base de datos de destino en el almacén de objetos.Tenga en cuenta lo siguiente para el archivo de cartera:
-
El archivo de cartera, junto con el ID de usuario y la contraseña de la base de datos, proporcionan acceso a los datos de la Oracle Database de destino. Almacene los archivos de cartera en una ubicación segura. Comparta los archivos de cartera solo con usuarios autorizados.
-
No cambie el nombre del archivo de cartera. El archivo de cartera de Object Storage debe tener el nombre
cwallet.sso.
-
-
Cree credenciales para acceder al almacén de objetos en el que almacena el archivo de cartera
cwallet.sso. Consulte Procedimiento CREATE_CREDENTIAL para obtener información sobre los parámetros de nombre de usuario y contraseña para diferentes servicios de almacenamiento de objetos. -
Cree un directorio en la base de datos de IA autónoma para el archivo de cartera
cwallet.sso.Por ejemplo:
CREATE DIRECTORY *dblink_wallet_dir* AS '*directory_path_of_your_choice*';Consulte Crear directorio en base de datos de IA autónoma para obtener información sobre la creación de directorios.
-
Utilice
DBMS_CLOUD.GET_OBJECTpara cargar la cartera de la base de datos de destino en el directorio creado en el paso anterior, DBLINK_WALLET_DIR.Por ejemplo:
BEGIN DBMS_CLOUD.GET_OBJECT( credential_name => 'DEF_CRED_NAME', object_uri => 'https://objectstorage.us-phoenix-1.oraclecloud.com/n/*namespace-string*/b/*bucketname*/o/cwallet.sso', directory_name => '*DBLINK_WALLET_DIR*'); END; /En este ejemplo,
*namespace-string*es el espacio ybucketnamees el nombre del cubo de Oracle Cloud Infrastructure. Consulte Descripción de los espacios de nombres de Object Storage para obtener más información.Nota:
credential_nameque utiliza en este paso son las credenciales para el almacén de objetos. En el siguiente paso, creará las credenciales para acceder a la base de datos destino. -
En la instancia de base de datos de IA autónoma, cree credenciales para acceder a la base de datos de destino.
usernameypasswordque especifique conDBMS_CLOUD.CREATE_CREDENTIALson las credenciales de la base de datos destino que utilice para crear el enlace de base de datos.Nota: Se necesita proporcionar el parámetro
credential_name.Por ejemplo:
BEGIN DBMS_CLOUD.CREATE_CREDENTIAL( credential_name => 'DB_LINK_CRED', username => 'NICK', password => '*password*'); END; /Los caracteres del parámetro
usernamedeben estar en mayúsculas.Esta operación almacena las credenciales en la base de datos en un formato cifrado. Puede utilizar cualquier nombre para el nombre de credencial.
-
Cree el enlace de base de datos a la base de datos destino mediante
DBMS_CLOUD_ADMIN.CREATE_DATABASE_LINK.Por ejemplo:
BEGIN DBMS_CLOUD_ADMIN.CREATE_DATABASE_LINK( db_link_name => 'SALESLINK', hostname => 'adb.eu-frankfurt-1.oraclecloud.com', port => '1522', service_name => '*example*_medium.atpc.example.oraclecloud.com', ssl_server_cert_dn => 'CN=atpc.example.oraclecloud.com,OU=Oracle BMCS FRANKFURT,O=Oracle Corporation,L=Redwood City,ST=California,C=US', credential_name => 'DB_LINK_CRED', directory_name => '*DBLINK_WALLET_DIR*'); END; /Los usuarios que no sean ADMIN necesitan privilegios para ejecutar
DBMS_CLOUD_ADMIN.CREATE_DATABASE_LINK.Si el archivo de cartera del directorio especificado con
directory_nameno escwallet.sso, el procedimiento informa un error como:ORA-28759: failure to open file. -
Utilice el enlace de base de datos que ha creado para acceder a los datos de la base de datos destino.
Por ejemplo:
SELECT * FROM employees@SALESLINK;
Para las credenciales que cree en el paso 5, las credenciales de la base de datos de destino, si cambia la contraseña del usuario de destino, puede actualizar la credencial que contiene las credenciales del usuario de destino de la siguiente manera:
BEGIN
DBMS_CLOUD.UPDATE_CREDENTIAL (
credential_name => 'DB_LINK_CRED',
attribute => 'PASSWORD',
value => '*password*' );
END;
/
Donde password es la nueva contraseña.
Después de esta operación, los enlaces de base de datos existentes que utilizan esta credencial siguen funcionando sin tener que borrar y volver a crear los enlaces de base de datos.
Para obtener información adicional, consulte:
Notas de Enlace de Base de Datos con una Oracle Database de Destino
Proporciona notas para crear enlaces de base de datos a una base de datos Oracle de destino (cuando el destino no es una base de datos de IA autónoma)
Notas para enlaces de base de datos a otras bases de datos Oracle:
-
Solo un archivo de cartera es válido por directorio para su uso con enlaces de base de datos. Solo puede cargar un
cwallet.ssoa la vez en el directorio que seleccione para los archivos de cartera (por ejemplo, DBLINK_WALLET_DIR). Esto significa que, concwallet.ssoen DBLINK_WALLET_DIR, solo puede crear enlaces de base de datos a las bases de datos para las que la cartera de ese directorio es válida. Para utilizar varios archivoscwallet.ssocon enlaces de base de datos, debe crear directorios adicionales y colocar cadacwallet.ssoen un directorio diferente. Al crear enlaces de base de datos conDBMS_CLOUD_ADMIN.CREATE_DATABASE_LINK, especifique el directorio que contiene la cartera con el parámetrodirectory_name.Consulte Crear directorio en base de datos de IA autónoma para obtener información sobre la creación de directorios.
-
Las versiones de base de datos Oracle de destino soportadas para enlaces de base de datos a otra instancia de Oracle Database son: 19c, 12.2.0 y 12.1.0.
Nota: Para obtener información completa sobre las versiones soportadas, consulte Matriz de soporte de interoperabilidad del servidor cliente para diferentes versiones de Oracle (ID de documento 207303.1)
-
La base de datos de IA autónoma define el parámetro
SEC_CASE_SENSITIVE_LOGONentruey este valor no se puede cambiar. Si la base de datos de destino no es una base de datos de IA autónoma, debe definir el parámetroSEC_CASE_SENSITIVE_LOGONentrueen la base de datos de destino. SiSEC_CASE_SENSITIVE_LOGONse define enfalseen la base de datos de destino, se emite el errorORA-28040: No matching authentication protocol. -
Para mostrar los enlaces de base de datos, utilice la vista
ALL_DB_LINKS. Consulte ALL_DB_LINKS en Oracle Database 19c Database Reference u Oracle Database 26ai Database Reference para obtener más información. -
El archivo de cartera, junto con el ID de usuario y la contraseña de la base de datos, proporcionan acceso a los datos de la base de datos Oracle de destino. Almacene los archivos de cartera en una ubicación segura. Comparta los archivos de cartera solo con usuarios autorizados.
-
Cuando la instancia de base de datos de IA autónoma está en un punto final privado, hay dos opciones para especificar la base de datos de destino: utilice el parámetro
hostnameo el parámetrorac_hostnames:-
Para un destino en un punto final privado,
DBMS_CLOUD_ADMIN.CREATE_DATABASE_LINKsoporta la especificación de un único nombre de host con el parámetrohostname. En un punto final privado, no se soporta el uso de una dirección IP, una IP de SCAN o un nombre de host de SCAN (cuando el destino está en un punto final público,CREATE_DATABASE_LINKsoporta el uso de una dirección IP, una IP de SCAN o un nombre de host de SCAN). -
Cuando el destino es una base de datos Oracle RAC, utilice el parámetro
rac_hostnamespara especificar uno o más nombres de host conDBMS_CLOUD_ADMIN.CREATE_DATABASE_LINK. Esto le permite aprovechar las capacidades de alta disponibilidad de Oracle RAC. No se admite el uso de una dirección IP, una IP de SCAN o un nombre de host de SCAN en el valorrac_hostnames.Al especificar una lista de nombres de host en el parámetro
rac_hostnames,CREATE_DATABASE_LINKutiliza todos los nombres de host especificados como direcciones en la cadena de conexión. Si uno de los hosts especificados no está disponible en la base de datos Oracle RAC de destino, Autonomous Database intenta conectarse automáticamente mediante otro nombre de host de la lista. -
DBMS_CLOUD_ADMIN.CREATE_DATABASE_LINKno soporta un valor delocalhostparahostnameo en el parámetrorac_hostnames.
-