En esta página, aprenderás a usar la API de Datastream para crear, recuperar información sobre y borrar configuraciones de conectividad privada.
Las configuraciones de conectividad privada contienen información que Datastream usa para comunicarse con una fuente de datos a través de una red privada (de forma interna dentro de Google Cloudo con fuentes externas conectadas a través de VPN o Interconnect). Esta comunicación se realiza a través de una interfaz de Private Service Connect o una conexión de intercambio de tráfico de nube privada virtual (VPC).
Crea una configuración de conectividad privada con el intercambio de tráfico entre VPC
Antes de crear una configuración de conectividad privada, asegúrate de lo siguiente:
- Debes tener una red de VPC para intercambiar tráfico con la red privada de Datastream. Para obtener más información sobre cómo crear una red de VPC, consulta Usa el intercambio de tráfico entre redes de VPC.
- Tener un rango de IP disponible (con un bloque CIDR de /29 como mínimo) en la red de VPC Datastream usa este rango de IP para crear un intercambio de tráfico de VPC con la VPC proporcionada, de modo que el rango no se superponga con las subredes dentro de esa VPC. Como resultado, Datastream puede comunicarse con la fuente.
Hay dos parámetros asociados con la creación de una configuración de conectividad privada:
vpcName:
Especifica el nombre y la ruta de acceso de la red de VPC.subnet:
Asigna un rango de IP disponible en la red de VPC.
En el siguiente código, se muestra una solicitud para crear una configuración de conectividad privada y se especifica que el método de conectividad es el uso del intercambio de tráfico entre VPC (vpcPeeringConfig
).
REST
POST https://datastream.googleapis.com/v1/projects/PROJECT_ID/locations/ LOCATION/privateConnections?privateConnectionId=PRIVATE_CONNECTIVITY_CONFIGURATION_ID { "displayName": "DISPLAY_NAME", "vpcPeeringConfig": { "vpcName": "VPC_NAME", "subnet": "SUBNET" } }
Por ejemplo:
POST https://datastream.googleapis.com/v1/projects/myProjectId/locations/ us-central1/privateConnections?privateConnectionId=myPrivateConnection { "displayName": "my-private-connection", "vpcPeeringConfig": { "vpcName": "projects/my-project/global/networks/my-vpc", "subnet": "10.11.12.13/29" } }
Después de crear la configuración de conectividad privada, puedes ver información sobre ella llamando al método privateConnections/get
. El resultado es similar al siguiente:
{ "name": "projects/projectId/location/us-central1/privateConnections/myPrivateConnection", "createTime": "2019-12-22T16:17:37.159786963Z", "updateTime": "2019-12-22T16:17:37.159786963Z", "displayName": "my-private-connection", "state": "CREATED", "vpcPeeringConfig": { "vpcName": "projects/my-project/global/networks/my-vpc", "subnet": "10.11.12.13/29" } }
gcloud
gcloud datastream private-connections create PRIVATE_CONNECTION_NAME --location=LOCATION--display-name=DISPLAY_NAME --vpc=VPC_NAME --subnet=SUBNET
Por ejemplo:
gcloud datastream private-connections create my-privateConnection --location=us-central1--display-name=my-private-connection --vpc=my-vpc --subnet=10.11.12.13/29
Crea una configuración de conectividad privada con una interfaz de Private Service Connect
Antes de crear una configuración de conectividad privada, asegúrate de lo siguiente:
Debes tener una red de VPC para conectarte a la red privada de Datastream. Para obtener más información sobre cómo crear una red de VPC, consulta Crea y administra redes de VPC.
Crea un adjunto de red en tu proyecto de VPC.
Verifica que Google Cloud y el firewall local permitan el tráfico del rango de direcciones IP del adjunto de red a la base de datos de origen desde la que deseas transmitir datos.
En el siguiente código, se muestra una solicitud para crear una configuración de conectividad privada con interfaces de Private Service Connect. Primero, debes ejecutar un
comando para crear una configuración de conectividad privada con la marca validateOnly
(--validate-only
para Google Cloud CLI):
REST
POST "https://datastream.googleapis.com/v1/projects/PROJECT_ID/locations/ LOCATION/privateConnections?privateConnectionId=PRIVATE_CONNECTIVITY_CONFIGURATION_ID&validateOnly=true"
gcloud
gcloud datastream private-connections create PRIVATE_CONNECTION_NAME --location=LOCATION--display-name=DISPLAY_NAME --network-attachment=NETWORK_ATTACHMENT_NAME --validate-only
En la respuesta, se muestra el nombre del proyecto del productor que debes aprobar. Debes
agregarlo a la lista de proyectos permitidos del adjunto de red. Una vez agregado, ejecuta el comando para volver a crear la configuración de conectividad privada, esta vez sin la marca validateOnly
:
REST
POST https://datastream.googleapis.com/v1/projects/PROJECT_ID/locations/ LOCATION/privateConnections?privateConnectionId=PRIVATE_CONNECTIVITY_CONFIGURATION_ID { "displayName": "DISPLAY_NAME", "pscInterfaceConfig": { "networkAttachment": "NETWORK_ATTACHMENT_NAME" } }
Por ejemplo:
POST https://datastream.googleapis.com/v1/projects/myProjectId/locations/ us-central1/privateConnections?privateConnectionId=myPrivateConnection { "displayName": "my-private-connection", "pscInterfaceConfig": { "networkAttachment": "projects/my-project/regions/us-central1/networkAttachments/my-na" } }
gcloud
gcloud datastream private-connections create PRIVATE_CONNECTION_NAME --location=LOCATION--display-name=DISPLAY_NAME --network-attachment=NETWORK_ATTACHMENT_NAME
Por ejemplo:
gcloud datastream private-connections create my-private-connection --location=us-central1--display-name=my-private-connection --network-attachment=my-network-attachment
Obtén información sobre una configuración de conectividad privada
En el siguiente código, se muestra una solicitud para recuperar información sobre una configuración de conectividad privada que se creó.
REST
GET https://datastream.googleapis.com/v1/projects/PROJECT_ID/locations/ LOCATION/privateConnections/PRIVATE_CONNECTIVITY_CONFIGURATION_ID
Por ejemplo:
GET https://datastream.googleapis.com/v1/projects/myProjectId/locations/ us-central1/privateConnections/myPrivateConnection
gcloud
Para obtener más información sobre el uso de gcloud
para recuperar información sobre la configuración de tu conectividad privada, consulta la documentación del SDK de Google Cloud.
Enumera las configuraciones de conectividad privada
En el siguiente código, se muestra una solicitud para recuperar información sobre todas tus configuraciones de conectividad privada.
REST
GET https://datastream.googleapis.com/v1/projects/PROJECT_ID/locations/ LOCATION/privateConnections
gcloud
Para obtener más información sobre el uso de gcloud
para recuperar información sobre todas tus configuraciones de conectividad privada, consulta la documentación del SDK de Google Cloud.
Borrar una configuración de conectividad privada
En el siguiente código, se muestra una solicitud para borrar una configuración de conectividad privada. Después de borrar la configuración, no funcionarán los perfiles de conexión que la usen. Además, no se podrán usar las transmisiones que usen estos perfiles de conexión.
Para resolver este problema, asigna una configuración de conectividad privada diferente a cada perfil de conexión. Para obtener más información, consulta Cómo actualizar un perfil de conexión.
REST
DELETE https://datastream.googleapis.com/v1/projects/PROJECT_ID/locations/ LOCATION/privateConnections/[private-connectivity-configuration-id] {"force": true}
Por ejemplo:
DELETE https://datastream.googleapis.com/v1/projects/myProjectId/locations/ us-central1/privateConnections/myPrivateConnection {"force": true}
gcloud
Para obtener más información sobre cómo usar gcloud
para borrar la configuración de conectividad privada, consulta la documentación del SDK de Google Cloud.
¿Qué sigue?
- Obtén más información sobre la conectividad privada.
- Obtén información sobre otras opciones de conectividad de red que puedes usar con Datastream.
- Obtén información para usar la API de Datastream para administrar perfiles de conexión.
- Aprende a usar la API de Datastream para administrar transmisiones.
- Para obtener más información sobre el uso de la API de Datastream, consulta la documentación de referencia.