Halaman ini menjelaskan cara menggunakan Private Service Connect untuk terhubung ke instance AlloyDB untuk PostgreSQL.
Anda dapat menggunakan Private Service Connect untuk terhubung ke instance AlloyDB utama atau replika bacanya, atau instance AlloyDB sekunder dari beberapa jaringan Virtual Private Cloud (VPC) yang tergabung dalam grup, tim, project, atau organisasi yang berbeda.
Peran yang diperlukan
Anda harus memberikan semua peran berikut kepada pengguna di jaringan VPC agar dapat terhubung ke instance AlloyDB.
Peran | Deskripsi |
---|---|
compute.networkAdmin |
Memberikan kontrol penuh atas jaringan VPC yang memulai koneksi ke instance AlloyDB. Jika Anda menggunakan Private Service Connect untuk terhubung ke instance AlloyDB dari beberapa jaringan VPC, setiap jaringan memiliki administratornya sendiri. |
dns.admin |
Memberikan kontrol penuh atas resource Cloud DNS, termasuk zona dan data DNS. |
alloydb.admin |
Memberikan kontrol penuh atas instance AlloyDB dan mengontrol instance selama siklus prosesnya. |
alloydb.databaseUser (Opsional) |
Memberikan akses ke instance AlloyDB. Jika terhubung melalui klien Proxy Auth AlloyDB, Anda harus memiliki peran Klien AlloyDB. Jika terhubung langsung, Anda tidak memerlukan peran dan izin Identity and Access Management (IAM). |
Mengaktifkan Private Service Connect
Mengaktifkan Private Service Connect melibatkan pembuatan cluster AlloyDB dengan Private Service Connect yang dikonfigurasi, lalu membuat instance AlloyDB dengan daftar project yang diizinkan.
Membuat cluster utama AlloyDB
Contoh berikut menggunakan perintah gcloud alloydb clusters create
dengan flag --enable-private-service-connect
yang membuat cluster AlloyDB dengan Private Service Connect yang diaktifkan.
Proses pembuatan cluster tetap sama, kecuali untuk meneruskan flag --enable-private-service-connect
. Untuk informasi mendetail tentang cara membuat cluster, lihat Membuat cluster dan instance utamanya.
Untuk membuat cluster, gunakan perintah gcloud alloydb clusters
create
.
gcloud alloydb clusters create CLUSTER_ID \
--password=PASSWORD \
--region=REGION_ID \
--project=PROJECT_ID \
--enable-private-service-connect
Ganti kode berikut:
CLUSTER_ID
: ID cluster yang Anda buat. Nama harus diawali dengan huruf kecil dan dapat berisi huruf kecil, angka, dan tanda hubung.PASSWORD
: sandi yang akan digunakan untuk penggunapostgres
default.REGION_ID
: region tempat Anda ingin menempatkan cluster.PROJECT_ID
: ID project tempat Anda ingin menempatkan cluster.
Perintah ini memulai operasi yang berjalan lama, dan menampilkan ID operasi.
Cluster sekunder yang dibuat untuk cluster utama yang mengaktifkan Private Service Connect akan otomatis mewarisi konfigurasi Private Service Connect. Untuk mengetahui informasi selengkapnya, lihat Membuat cluster sekunder.
Membuat instance AlloyDB
Contoh berikut menunjukkan cara membuat instance utama dengan daftar project yang diizinkan yang dikonfigurasi. Proses pembuatan instance tetap sama, kecuali meneruskan daftar project yang diizinkan menggunakan flag --allowed-psc-projects
untuk cluster utama yang mengaktifkan Private Service Connect.
Untuk mengetahui informasi selengkapnya tentang cara membuat jenis instance lainnya, lihat Membuat instance kumpulan baca dan Membuat instance sekunder.
Untuk membuat instance utama, gunakan perintah gcloud alloydb instances create
.
gcloud alloydb instances create INSTANCE_ID \
--instance-type=PRIMARY \
--cpu-count=CPU_COUNT \
--availability-type=AVAILABILITY \
--region=REGION_ID \
--cluster=CLUSTER_ID \
--project=PROJECT_ID \
--allowed-psc-projects=ALLOWED_PROJECT_LIST
Ganti kode berikut:
INSTANCE_ID
: ID instance yang Anda buat. Nama harus diawali dengan huruf kecil dan dapat berisi huruf kecil, angka, dan tanda hubung.CPU_COUNT
: jumlah vCPU yang Anda inginkan untuk instance. Nilai yang valid mencakup hal berikut:2
: 2 vCPU, RAM 16 GB4
: 4 vCPU, RAM 32 GB8
: 8 vCPU, RAM 64 GB16
: 16 vCPU, RAM 128 GB32
: 32 vCPU, RAM 256 GB64
: 64 vCPU, RAM 512 GB96
: 96 vCPU, RAM 768 GB128
: 128 vCPU, RAM 864 GB
AVAILABILITY
: menunjukkan apakah instance ini harus sangat tersedia (HA) atau tidak, dengan node di beberapa zona. Nilai yang valid mencakup:REGIONAL
: membuat instance HA dengan node aktif dan standby terpisah, serta failover otomatis di antara keduanya. Ini adalah nilai default, yang cocok untuk lingkungan produksi.ZONAL
: membuat instance dasar, yang hanya berisi satu node, dan tidak ada failover otomatis.
REGION_ID
: region tempat Anda ingin menempatkan instance.CLUSTER_ID
: ID cluster yang Anda buat sebelumnya.ALLOWED_PROJECT_LIST
: daftar yang dipisahkan koma untuk project ID atau nomor project yang ingin Anda izinkan mengakses instance—misalnya,my-project-1
,12345
,my-project-n
.
Mendapatkan lampiran layanan
Setelah membuat instance AlloyDB dengan Private Service Connect yang diaktifkan, dapatkan URL lampiran layanan dan gunakan untuk membuat endpoint Private Service Connect.
Gunakan perintah gcloud alloydb instances describe
untuk melihat detail tentang instance.
gcloud alloydb instances describe INSTANCE_ID \
--cluster=CLUSTER_ID --region=REGION_ID
Ganti kode berikut:
INSTANCE_ID
: ID instance.CLUSTER_ID
: ID cluster.REGION_ID
: region tempat cluster AlloyDB di-deploy.
Contoh respons untuk perintah ini adalah sebagai berikut:
"pscInstanceConfig": {
"serviceAttachmentLink:": "https://www.googleapis.com/compute/v1/projects/my-project/regions/my-region/serviceAttachments/my-service-attachment-id"
"allowedConsumerProjects": {
"45678",
"12345",
"67890",
},
"pscDnsName": "11111111-1111-1111-1111-111111111111.22222222-2222-2222-2222-222222222222.alloydb-psc.goog."
}
Parameter pscServiceAttachmentLink
menyimpan nilai URL lampiran layanan.
Membuat endpoint Private Service Connect
Untuk membuat endpoint Private Service Connect, teruskan URL lampiran layanan beserta nama endpoint yang unik. Untuk mengetahui informasi selengkapnya tentang cara membuat endpoint Private Service Connect, lihat Membuat endpoint.
Anda juga dapat mencadangkan alamat IP internal untuk endpoint Private Service Connect menggunakan perintah gcloud compute addresses create
, lalu menggunakan alamat IP yang dicadangkan saat membuat endpoint.
Menghubungkan ke instance AlloyDB
Anda dapat terhubung ke instance AlloyDB dengan Private Service Connect yang diaktifkan menggunakan salah satu opsi berikut:
- alamat IP internal,
- data DNS
- Proxy Auth AlloyDB
- AlloyDB Language Connector
Untuk terhubung menggunakan data DNS, Anda harus membuat data DNS di zona DNS pribadi pada jaringan VPC yang sesuai. Setelah membuat data DNS, Anda dapat menggunakan data ini untuk terhubung ke instance yang mengaktifkan Private Service Connect secara langsung menggunakan data DNS, menggunakan AlloyDB Auth Proxy, atau menggunakan AlloyDB Language Connector.
Mengonfigurasi zona DNS terkelola dan data DNS
Untuk mengonfigurasi zona DNS terkelola dan data DNS di jaringan Anda, ikuti langkah-langkah berikut:
Untuk melihat informasi ringkasan tentang instance AlloyDB, termasuk nama DNS instance tersebut, gunakan perintah
gcloud alloydb instances describe
:gcloud alloydb instances describe INSTANCE_ID \ --project=CLUSTER_ID
Ganti kode berikut:
INSTANCE_ID
: ID instance.CLUSTER_ID
: ID cluster.
Dalam respons, pastikan nama DNS muncul. Nama DNS memiliki pola
INSTANCE_UID.PROJECT_UID.REGION_NAME.alloydb-psc.goog.
.Untuk membuat zona DNS pribadi, gunakan perintah
gcloud dns managed-zones create
. Zona ini dikaitkan dengan jaringan VPC yang digunakan untuk terhubung ke instance AlloyDB melalui endpoint Private Service Connect.gcloud dns managed-zones create ZONE_NAME \ --project=PROJECT_ID \ --description=DESCRIPTION \ --dns-name=DNS_NAME \ --networks=NETWORK_NAME \ --visibility=private
Ganti kode berikut:
ZONE_NAME
: nama zona DNS.PROJECT_ID
: ID atau nomor project Google Cloud yang berisi zona.DESCRIPTION
: deskripsi zona (misalnya, zona DNS untuk instance AlloyDB).DNS_NAME
: nama DNS untuk zona, sepertiINSTANCE_UID.PROJECT_UID.REGION_NAME.alloydb-psc.goog.
.NETWORK_NAME
: Nama jaringan VPC.
Setelah Anda membuat endpoint Private Service Connect, untuk membuat data DNS di zona, gunakan perintah gcloud dns record-sets create:
gcloud dns record-sets create DNS_NAME \ --project=PROJECT_ID \ --type=RRSET_TYPE \ --rrdatas=RR_DATA \ --zone=ZONE_NAME
Ganti kode berikut:
DNS_NAME
: nama DNS yang telah Anda ambil sebelumnya dalam prosedur ini.RRSET_TYPE
: jenis data resource dari kumpulan data DNS (misalnya, A).RR_DATA
: alamat IP yang dialokasikan untuk endpoint Private Service Connect (misalnya, 198.51.100.5). Anda juga dapat memasukkan beberapa nilai seperti rrdata1 rrdata2 rrdata3 (misalnya, 10.1.2.3 10.2.3.4 10.3.4.5).
Menghubungkan langsung menggunakan data DNS
Setelah membuat endpoint Private Service Connect, dan membuat data DNS, Anda dapat terhubung langsung menggunakan data DNS.
Untuk mengambil data DNS endpoint Private Service Connect, gunakan perintah
gcloud compute addresses describe
:gcloud compute addresses describe DNS_RECORD \ --project=PROJECT_ID \ --region=REGION_NAME
Ganti kode berikut:
DNS_RECORD
: data DNS untuk endpoint.PROJECT_ID
: ID atau nomor project Google Cloud yang berisi endpoint.REGION_NAME
: nama region untuk endpoint.
Untuk terhubung ke instance AlloyDB, gunakan data DNS.
psql user=USERNAME host=DNS_RECORD
Ganti kode berikut:
USERNAME
: nama pengguna yang terhubung ke instance.DNS_RECORD
: data DNS endpoint.
Terhubung menggunakan Proxy Auth AlloyDB
Proxy Auth AlloyDB adalah konektor yang memungkinkan Anda membuat koneksi terenkripsi yang diotorisasi ke database AlloyDB. Proxy Auth AlloyDB bekerja dengan menjalankan klien lokal di lingkungan lokal. Aplikasi Anda berkomunikasi dengan Proxy Auth AlloyDB menggunakan protokol database standar yang digunakan oleh database Anda.
Saat Anda menetapkan flag --psc
saat memulai klien Auth Proxy, Proxy Auth AlloyDB akan menggunakan data DNS yang Anda buat untuk terhubung ke instance yang mengaktifkan Private Service Connect.
Pastikan Anda memulai klien Auth Proxy dengan meneruskan URI instance yang Anda ambil menggunakan perintah gcloud alloydb instances list
, dan menetapkan tanda --psc
.
Untuk mengetahui informasi selengkapnya tentang cara menghubungkan ke instance menggunakan Auth Proxy, lihat Menghubungkan menggunakan Auth Proxy.
Menghubungkan menggunakan AlloyDB Language Connectors
AlloyDB Language Connectors adalah library yang menyediakan mTLS otomatis dengan TLS 1.3 dan otorisasi Identity and Access Management (IAM) saat terhubung ke instance AlloyDB.
Setelah menentukan bahwa instance mendukung Private Service Connect, Language Connector akan menggunakan data DNS yang Anda buat untuk terhubung ke instance.
Java
Jika Anda menggunakan Private Service Connect untuk terhubung ke instance AlloyDB, sertakan hal berikut:
config.addDataSourceProperty("alloydbIpType", "PSC");
Untuk mengetahui informasi selengkapnya tentang penggunaan endpoint Private Service Connect di Konektor Bahasa Java, lihat repositori GitHub.
Python (pg8000)
Jika Anda menggunakan Private Service Connect untuk terhubung ke instance AlloyDB, sertakan hal berikut:
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
Untuk mengetahui informasi selengkapnya tentang penggunaan endpoint Private Service Connect di Konektor Bahasa Python, lihat repositori GitHub.
Python (asyncpg)
Jika Anda menggunakan Private Service Connect untuk terhubung ke instance AlloyDB, sertakan hal berikut:
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
Untuk mengetahui informasi selengkapnya tentang penggunaan endpoint Private Service Connect di Konektor Bahasa Python, lihat repositori GitHub.
Go (pgx)
Jika Anda menggunakan Private Service Connect untuk terhubung ke instance AlloyDB, sertakan hal berikut:
d.Dial(ctx, instURI, alloydbconn.WithPSC())
Untuk mengetahui informasi selengkapnya tentang penggunaan endpoint Private Service Connect di Konektor Bahasa Go, lihat repositori GitHub.
Go (database/sql)
Jika Anda menggunakan Private Service Connect untuk terhubung ke instance AlloyDB, sertakan hal berikut:
cleanup, err := pgxv5.RegisterDriver(
"alloydb",
alloydbconn.WithDefaultDialOptions(alloydbconn.WithPSC())
)
Untuk mengetahui informasi selengkapnya tentang penggunaan endpoint Private Service Connect di Konektor Bahasa Go, lihat repositori GitHub.
Menghubungkan langsung melalui alamat IP internal
Setelah membuat endpoint Private Service Connect, Anda dapat langsung terhubung ke instance AlloyDB menggunakan alamat IP yang Anda konfigurasi.
Untuk mengambil alamat IP endpoint Private Service Connect, gunakan perintah
gcloud compute addresses describe
:gcloud compute addresses describe ADDRESS_NAME \ --project=PROJECT_ID \ --region=REGION_NAME
Ganti kode berikut:
ADDRESS_NAME
: nama alamat IP endpoint.PROJECT_ID
: ID atau nomor project Google Cloud yang berisi endpoint.REGION_NAME
: nama region untuk endpoint.
Untuk terhubung ke instance AlloyDB, gunakan alamat IP internal.
psql user=USERNAME hostaddr=IP_ADDRESS"
Ganti kode berikut:
USERNAME
: nama pengguna yang terhubung ke instance.IP_ADDRESS
: alamat IP endpoint.
Batasan
- Anda dapat menyiapkan hingga 20 endpoint Private Service Connect yang terhubung ke lampiran layanan instance AlloyDB dengan Private Service Connect yang diaktifkan.
- Anda tidak dapat menggunakan tanda
--network
saat membuat cluster yang mengaktifkan Private Service Connect karena terkait dengan akses layanan pribadi. - Anda tidak dapat mengaktifkan atau menonaktifkan Private Service Connect pada instance yang ada.
- Anda tidak dapat mengonfigurasi instance dengan Private Service Connect yang diaktifkan untuk menggunakan akses layanan pribadi.
- Ekstensi
pglogical
,dblink
, danpostgres_fdw
yang memerlukan konektivitas keluar tidak didukung.