Los conectores de lenguaje de AlloyDB son bibliotecas que proporcionan un proceso simplificado para establecer conexiones seguras a tu clúster. Para ello, usa lo siguiente:
- Conexiones mTLS automatizadas
- Compatibilidad con la autorización basada en Identity and Access Management (IAM)
- Autenticación de IAM automatizada
Los conectores de lenguaje de AlloyDB no pueden proporcionar una ruta de red a un clúster de AlloyDB, si aún no hay una.
Para obtener más información sobre los conectores de lenguaje de AlloyDB, consulta la descripción general de los conectores de lenguaje de AlloyDB.
En esta página, se analizan los siguientes conectores de lenguaje de AlloyDB:
- El conector de Java de AlloyDB
- El conector de AlloyDB para Go
- El conector de Python de AlloyDB
Antes de comenzar
Habilita la API de AlloyDB Admin.
Crea una instancia de AlloyDB y configura el usuario predeterminado.
Para obtener más información sobre cómo crear una instancia, consulta Crea una instancia principal.
Para obtener más información sobre los roles de usuario, consulta Roles predefinidos de IAM de AlloyDB.
Configura los siguientes roles y permisos necesarios para conectarte a una instancia de AlloyDB:
roles/alloydb.client
roles/serviceusage.serviceUsageConsumer
Para obtener más información sobre los roles y permisos necesarios, consulta Administra la autenticación de IAM.
Instala los conectores de lenguaje de AlloyDB
Java
El conector de Java de AlloyDB es una biblioteca que proporciona encriptación y autorización basadas en IAM cuando se conecta a una instancia de AlloyDB.
Instalación
En el caso de Maven, puedes instalar el conector de Java de AlloyDB si agregas lo siguiente a pom.xml
de tu proyecto:
<!-- Add the connector with the latest version -->
<dependency>
<groupId>com.google.cloud</groupId>
<artifactId>alloydb-jdbc-connector</artifactId>
<version>0.4.0</version>
</dependency>
<!-- Add the driver with the latest version -->
<dependency>
<groupId>org.postgresql</groupId>
<artifactId>postgresql</artifactId>
<version>46.6.0<</version>
</dependency>
<!-- Add HikariCP with the latest version -->
<dependency>
<groupId>com.zaxxer</groupId>
<artifactId>HikariCP</artifactId>
<version>5.1.0</version>
</dependency>
En el caso de Gradle, puedes instalar el conector de Java de AlloyDB si incluyes lo siguiente en el gradle.build
de tu proyecto:
// Add connector with the latest version
implementation group: 'com.google.cloud.alloydb', name: 'alloydb-jdbc-connector', version: '0.4.0'
// Add driver with the latest version
implementation group: 'org.postgresql', name: 'postgresql', version: '46.6.0'
// Add HikariCP with the latest version
implementation group: 'com.zaxxer', name: 'HikariCP', version: '5.1.0'
Python (pg8000)
El conector de Python de AlloyDB es una biblioteca que se puede usar junto con un controlador de base de datos para permitir que los usuarios con permisos suficientes se conecten a una base de datos de AlloyDB sin tener que incluir IPs en la lista de entidades permitidas de forma manual.
Instalación
Puedes instalar la biblioteca del conector de Python de AlloyDB con pip install
.
Si usas pg8000, ejecuta el siguiente comando:
pip install "google-cloud-alloydb-connector[pg8000]" sqlalchemy
Python (asyncpg)
El conector de Python de AlloyDB es una biblioteca que se puede usar junto con un controlador de base de datos para permitir que los usuarios con permisos suficientes se conecten a una base de datos de AlloyDB sin tener que incluir IPs en la lista de entidades permitidas de forma manual.
Instalación
Puedes instalar la biblioteca del conector de Python de AlloyDB con pip install
.
Si usas asyncpg, ejecuta el siguiente comando:
Para asyncpg, usa lo siguiente:
pip install "google-cloud-alloydb-connector[asyncpg]" "sqlalchemy[asyncio]"
Para obtener más información sobre el uso de controladores asíncronos, consulta Uso de controladores asíncronos.
Go (pgx)
El conector de Go de AlloyDB es un conector de AlloyDB diseñado para usarse con el lenguaje Go.
Instalación
Puedes instalar el conector de AlloyDB para Go con go get
.
Si usas pgx, ejecuta el siguiente comando:
go get github.com/jackc/pgx/v5
go get cloud.google.com/go/alloydbconn
Go (database/sql)
El conector de Go de AlloyDB es un conector de AlloyDB diseñado para usarse con el lenguaje Go.
Instalación
Puedes instalar el conector de AlloyDB para Go con go get
.
Si usas database/sql, ejecuta el siguiente comando:
go get cloud.google.com/go/alloydbconn
Configura los conectores de idiomas de AlloyDB
Java
Para usar el conector de Java de AlloyDB y conectarte a tu clúster de AlloyDB, configúralo con los siguientes pasos.
Para usar este fragmento en el contexto de una aplicación web, consulta el archivo README en GitHub.
Cómo usar una IP pública
Si usas una IP pública para conectarte a tu clúster de AlloyDB, incluye lo siguiente:
config.addDataSourceProperty("alloydbIpType", "PUBLIC");
Usa Private Service Connect
Si usas Private Service Connect para conectarte a tu instancia de AlloyDB, incluye lo siguiente:
config.addDataSourceProperty("alloydbIpType", "PSC");
Autenticación automática de IAM
De forma predeterminada, los conectores de lenguaje de AlloyDB usan la autenticación integrada. Puedes usar la autenticación automática de IAM con el conector de Java de AlloyDB. Para habilitarlo, incluye lo siguiente:
config.addDataSourceProperty("alloydbEnableIAMAuth", "true");
Python (pg8000)
Para usar el conector de Python de AlloyDB y conectarte a tu clúster de AlloyDB, configura el conector con los siguientes pasos si usas pg8000
.
Para usar este fragmento en el contexto de una aplicación web, consulta el archivo README en GitHub.
Cómo usar una IP pública
Si usas una IP pública para conectarte a tu clúster de AlloyDB, reemplaza la función de conexión por la siguiente:
def getconn() -> pg8000.dbapi.Connection:
conn: pg8000.dbapi.Connection = connector.connect(
inst_uri,
"pg8000",
user=user,
password=password,
db=db,
# use ip_type to specify public IP
ip_type=IPTypes.PUBLIC,
)
return conn
Usa Private Service Connect
Si usas Private Service Connect para conectarte a tu instancia de AlloyDB, incluye lo siguiente:
def getconn() -> pg8000.dbapi.Connection:
conn: pg8000.dbapi.Connection = connector.connect(
inst_uri,
"pg8000",
user=user,
password=password,
db=db,
# use ip_type to specify PSC
ip_type=IPTypes.PSC,
)
return conn
Autenticación automática de IAM
De forma predeterminada, los conectores de lenguaje de AlloyDB usan la autenticación integrada. Puedes usar la autenticación automática de IAM con el conector de Python de AlloyDB. Para habilitarla, reemplaza la función de conexión por lo siguiente:
def getconn() -> pg8000.dbapi.Connection:
conn: pg8000.dbapi.Connection = connector.connect(
inst_uri,
"pg8000",
user=user,
password=password,
db=db,
# use enable_iam_auth to enable IAM authentication
enable_iam_auth=True,
)
return conn
Python (asyncpg)
Para usar el conector de Python de AlloyDB y conectarte a tu clúster de AlloyDB, configura el conector con los siguientes pasos si usas async
.
Para usar este fragmento en el contexto de una aplicación web, consulta el archivo README en GitHub.
Cómo usar una IP pública
Si usas una IP pública para conectarte a tu clúster de AlloyDB, reemplaza la función de conexión por la siguiente:
async def getconn() -> asyncpg.Connection:
conn: asyncpg.Connection = await connector.connect(
inst_uri,
"asyncpg",
user=user,
password=password,
db=db,
# use ip_type to specify public IP
ip_type=IPTypes.PUBLIC,
)
return conn
Usa Private Service Connect
Si usas Private Service Connect para conectarte a tu instancia de AlloyDB, incluye lo siguiente:
async def getconn() -> asyncpg.Connection:
conn: asyncpg.Connection = await connector.connect(
inst_uri,
"asyncpg",
user=user,
password=password,
db=db,
# use ip_type to specify PSC
ip_type=IPTypes.PSC,
)
return conn
Autenticación automática de IAM
De forma predeterminada, los conectores de lenguaje de AlloyDB usan la autenticación integrada. Puedes usar la autenticación automática de IAM con el conector de Python de AlloyDB. Para habilitarla, reemplaza la función de conexión por lo siguiente:
async def getconn() -> asyncpg.Connection:
conn: asyncpg.Connection = await connector.connect(
inst_uri,
"asyncpg",
user=user,
password=password,
db=db,
# use enable_iam_auth to enable IAM authentication
enable_iam_auth=True,
)
return conn
Go (pgx)
Para usar el conector Go de AlloyDB y conectarte a tu clúster de AlloyDB, configura el conector con los siguientes pasos si usas pgx
.
Para usar este fragmento en el contexto de una aplicación web, consulta el archivo README en GitHub.
Cómo usar una IP pública
Si usas una IP pública para conectarte a tu clúster de AlloyDB,
reemplaza la función d.Dial
por lo siguiente:
d.Dial(ctx, instURI, alloydbconn.WithPublicIP())
Usa Private Service Connect
Si usas Private Service Connect para conectarte a tu instancia de AlloyDB, incluye lo siguiente:
d.Dial(ctx, instURI, alloydbconn.WithPSC())
Autenticación automática de IAM
De forma predeterminada, los conectores de lenguaje de AlloyDB usan la autenticación integrada.
Puedes usar la autenticación automática de IAM con el conector de Go de AlloyDB. Para habilitarlo, reemplaza la función alloydbconn.NewDialer
por lo siguiente:
d, err := alloydbconn.NewDialer(ctx, alloydbconn.WithIAMAuthN())
Go (database/sql)
Para usar el conector de Go de AlloyDB y conectarte a tu clúster de AlloyDB, configura el conector con los siguientes pasos si usas database/sql
.
Para usar este fragmento en el contexto de una aplicación web, consulta el archivo README en GitHub.
Cómo usar una IP pública
Si usas una IP pública para conectarte a tu clúster de AlloyDB,
reemplaza la función RegisterDriver
por lo siguiente:
cleanup, err := pgxv5.RegisterDriver(
"alloydb",
alloydbconn.WithDefaultDialOptions(alloydbconn.WithPublicIP())
)
Usa Private Service Connect
Si usas Private Service Connect para conectarte a tu instancia de AlloyDB, incluye lo siguiente:
cleanup, err := pgxv5.RegisterDriver(
"alloydb",
alloydbconn.WithDefaultDialOptions(alloydbconn.WithPSC())
)
Autenticación automática de IAM
De forma predeterminada, los conectores de lenguaje de AlloyDB usan la autenticación integrada.
Puedes usar la autenticación automática de IAM con el conector de Go de AlloyDB. Para habilitarlo, reemplaza
tu función RegisterDriver
por lo siguiente:
cleanup, err := pgxv4.RegisterDriver(
"alloydb",
alloydbconn.WithIAMAuthN()
)