Untuk mengakses workstation, Anda dapat menentukan domain kustom tepercaya, bukan
menggunakan domain cloudworkstations.dev
.
Arsitektur
Untuk menggunakan Cloud Workstation dengan nama host kustom, siapkan cluster pribadi dan siapkan endpoint Private Service Connect (PSC) untuk ingress HTTP bagi cluster pribadi Anda. Anda juga harus membuat Load Balancer Aplikasi dengan backend PSC yang menargetkan endpoint PSC yang dibuat untuk cluster pribadi Anda. Load Balancer Aplikasi ini dapat berupa eksternal atau internal, dan mengelola sertifikat SSL untuk domain kustom Anda.
Diagram berikut mengilustrasikan cluster dengan domain kustom:
Sebelum memulai
Untuk menyiapkan domain kustom Cloud Workstations, ikuti langkah-langkah berikut:
Buat cluster pribadi dan tentukan domain kustom tepercaya menggunakan perintah CLI
gcloud
atau REST API.Buat Load Balancer Aplikasi eksternal global dengan backend Private Service Connect (PSC) di project yang sama dengan yang Anda gunakan untuk project cluster workstation. Perhatikan hal-hal berikut:
Jika ingin workstation Anda bersifat pribadi (tidak dapat diakses melalui internet publik), pastikan Anda membuat load balancer internal. Untuk melakukannya, buat zona DNS pribadi dan tambahkan data yang memetakan domain ke alamat IP internal yang digunakan oleh load balancer. Untuk mengetahui informasi selengkapnya tentang cara membuat load balancer internal, lihat dokumentasi VPC.
Lampiran layanan yang perlu Anda referensikan dalam load balancer dapat diperoleh di resource cluster workstation setelah Anda membuat cluster.
Pastikan Anda mendapatkan sertifikat dan menetapkannya di load balancer sebagai sertifikat karakter pengganti untuk domain Anda—misalnya,
*.us-west1-cluster1.example.com
. Lihat Load balancer Sertifikat dan Google Cloud untuk mengetahui jenis-jenis sertifikat yang didukung untuk load balancer yang Anda pilih.Anda juga dapat membuat load balancer di project lain selama Anda menambahkannya ke daftar
PrivateClusterConfig.allowedProjects
.Jika memiliki beberapa cluster workstation di organisasi, Anda dapat menggunakan satu load balancer dengan layanan backend, sertifikat, dan aturan perutean yang terpisah.
Menyiapkan Domain Name System (DNS). Karena ini adalah domain yang Anda kelola, siapkan DNS untuk domain ini dengan memetakan semua subdomain dari domain yang disediakan ke load balancer. Misalnya, buat zona DNS untuk
us-west1-cluster1.example.com
dan tambahkan entri yang memetakan*.us-west1-cluster1.example.com
ke alamat IP eksternal yang digunakan oleh load balancer Anda.Untuk mengakses workstation menggunakan domain kustom, gunakan cluster yang Anda buat untuk membuat konfigurasi workstation, lalu buat workstation menggunakan konfigurasi workstation tersebut.
Mulai komputer Anda dan periksa URL-nya. Saat Anda menentukan domain kustom, URL workstation menggunakan format berikut:
https://PORT-WORKSTATION_NAME.DOMAIN
Bagian URL berikut bergantung pada konfigurasi Anda:
PORT
: nomor port, yaitu port80
secara default.WORKSTATION_NAME
: nama workstation Anda.DOMAIN
: nama domain khusus cluster Anda
Membuat cluster pribadi
Buat cluster workstation pribadi dengan endpoint pribadi:
gcloud
Sebelum memulai, pastikan Anda melakukan inisialisasi
gcloud
CLI dengan menjalankangcloud init
dan menentukan project default. Contoh berikut mengasumsikan bahwa Anda telah menetapkan project default.Untuk membuat cluster workstation pribadi, jalankan perintah berikut:
gcloud workstations clusters create WORKSTATION_CLUSTER \ --region=REGION \ --domain=DOMAIN \ --enable-private-endpoint
Ganti kode berikut:
WORKSTATION_CLUSTER
: nama cluster workstation yang akan dibuat.REGION
: nama region cluster.DOMAIN
: nama domain yang digunakan oleh Cloud Workstations untuk traffic masuk HTTP. Gunakan subdomain yang unik untuk cluster ini, misalnya,us-west1-cluster1.example.com
.
Untuk mengetahui informasi selengkapnya tentang perintah CLI gcloud
ini, baca dokumentasi referensi gcloud workstations clusters create
.
curl
curl -H "Authorization: Bearer $(gcloud auth print-access-token)" -H "Content-Type: application/json" -d '{"domain_config": {"domain": "DOMAIN"}, "private_cluster_config":{"enable_private_endpoint":true}}' https://workstations.googleapis.com/v1/projects/PROJECT_NAME/locations/REGION/workstationClusters?workstation_cluster_id=WORKSTATION_CLUSTER
Ganti kode berikut:
DOMAIN
: nama domain yang digunakan oleh Cloud Workstations untuk traffic masuk HTTP. Ini harus merupakan subdomain yang unik untuk cluster ini, misalnya,us-west1-cluster1.example.com
.PROJECT_NAME
: nama project.REGION
: nama region cluster.WORKSTATION_CLUSTER
: nama cluster workstation yang akan dibuat.
Untuk informasi selengkapnya tentang metode API ini, lihat
dokumentasi referensi
workstationClusters.create
.
REST
POST https://workstations.googleapis.com/v1/projects/PROJECT_NAME/locations/REGION/workstationClusters?workstationClusterId=WORKSTATION_CLUSTER { "domainConfig": { "domain": "DOMAIN" }, "privateClusterConfig": { "enablePrivateEndpoint": true } }
Ganti kode berikut:
PROJECT_NAME
: nama project.REGION
: nama region cluster.WORKSTATION_CLUSTER
: nama cluster workstation yang akan dibuat.DOMAIN
: nama domain yang digunakan oleh Cloud Workstations untuk traffic masuk HTTP. Ini harus merupakan subdomain yang unik untuk cluster ini, misalnya,us-west1-cluster1.example.com
.
Untuk informasi selengkapnya tentang metode API ini, lihat
dokumentasi referensi
workstationClusters.create
.
Membuat Load Balancer Aplikasi eksternal global dengan backend PSC
Ikuti langkah-langkah CLI dan REST API gcloud
ini untuk membuat
Load Balancer Aplikasi eksternal global dengan backend PSC:
- Membuat NEG untuk terhubung ke layanan yang dipublikasikan
- Menambahkan backend ke Load Balancer Aplikasi eksternal global
- Membuat peta URL untuk mengarahkan permintaan masuk ke layanan backend
- Membuat proxy HTTPS target
- Membuat alamat global
- Membuat aturan penerusan
Membuat NEG untuk terhubung ke layanan yang dipublikasikan
Saat membuat NEG yang mengarah ke layanan yang dipublikasikan, Anda memerlukan URI lampiran layanan untuk layanan tersebut. Lampiran layanan memiliki format berikut:
projects/SERVICE_PROJECT/regions/REGION/serviceAttachments/SERVICE_NAME
.
Anda dapat menemukan URI di resource cluster workstation.
gcloud
gcloud compute network-endpoint-groups create NEG_NAME \ --network-endpoint-type=private-service-connect \ --psc-target-service=TARGET_SERVICE \ --region=REGION \ --network=NETWORK \ --subnet=SUBNET
Ganti kode berikut:
NEG_NAME
: nama untuk grup endpoint jaringan.TARGET_SERVICE
: URI lampiran layanan.REGION
: region tempat membuat grup endpoint jaringan. Region harus sama dengan region layanan target.NETWORK
: jaringan untuk membuat grup endpoint jaringan. Jika dihilangkan, jaringan default akan digunakan.SUBNET
: subnet untuk membuat grup endpoint jaringan. Subnet harus berada di region yang sama dengan layanan target. Subnet harus disediakan jika Anda menyediakan jaringan. Jika jaringan dan subnet dihilangkan, jaringan default akan digunakan, dan subnet default dalamREGION
yang ditentukan akan digunakan.
Untuk mengetahui informasi selengkapnya tentang perintah CLI gcloud
ini, baca dokumentasi referensi gcloud compute network-endpoint-groups create
.
REST
POST https://compute.googleapis.com/compute/v1/projects/PROJECT_NAME/regions/REGION/networkEndpointGroups { "pscTargetService": "TARGET_SERVICE", "networkEndpointType": "PRIVATE_SERVICE_CONNECT", "name": "NEG_NAME" }
Ganti kode berikut:
PROJECT_NAME
: nama project.REGION
: region tempat membuat grup endpoint jaringan. Region harus sama dengan region layanan target.NEG_NAME
: nama untuk grup endpoint jaringan.TARGET_SERVICE
: URI lampiran layanan.
Menambahkan backend ke Load Balancer Aplikasi eksternal global
gcloud
Buat layanan backend untuk layanan target:
gcloud compute backend-services create BACKEND_SERVICE_NAME \ --load-balancing-scheme=EXTERNAL_MANAGED \ --protocol=HTTPS \ --global
Ganti
BACKEND_SERVICE_NAME
dengan nama layanan backend.Tambahkan NEG Private Service Connect yang mengarah ke layanan target.
gcloud compute backend-services add-backend BACKEND_SERVICE_NAME \ --network-endpoint-group=NEG_NAME \ --network-endpoint-group-region=NEG_REGION \ --global
Ganti kode berikut:
BACKEND_SERVICE_NAME
: nama layanan backend.NEG_NAME
: nama grup endpoint jaringan.NEG_REGION
: region grup endpoint jaringan.
Untuk mengetahui informasi selengkapnya tentang perintah CLI gcloud
ini, lihat dokumentasi referensi gcloud compute backend-services create
dan gcloud compute backend-services add-backend
.
REST
Buat layanan backend untuk layanan target:
POST https://compute.googleapis.com/compute/v1/projects/PROJECT_NAME/global/backendServices { "protocol": "HTTPS", "loadBalancingScheme": "EXTERNAL_MANAGED", "name": "BACKEND_SERVICE_NAME" }
Ganti
BACKEND_SERVICE_NAME
dengan nama layanan backend.Tambahkan NEG Private Service Connect yang mengarah ke layanan target.
PATCH https://compute.googleapis.com/compute/v1/projects/PROJECT_NAME/global/backendServices/BACKEND_SERVICE_NAME { "backends": [ { "group": "https://www.googleapis.com/compute/v1/projects/PROJECT_NAME/regions/NEG_REGION/networkEndpointGroups/NEG_NAME " } ] }
Ganti kode berikut:
PROJECT_NAME
: nama project.BACKEND_SERVICE_NAME
: nama layanan backend.NEG_REGION
: region grup endpoint jaringan.NEG_NAME
: nama grup endpoint jaringan.
Membuat peta URL untuk mengarahkan permintaan masuk ke layanan backend
gcloud
gcloud compute url-maps create URL_MAP_NAME \ --default-service=BACKEND_SERVICE_NAME \ --global
Ganti kode berikut:
URL_MAP_NAME
: nama peta URL yang akan dibuat.BACKEND_SERVICE_NAME
: nama layanan backend yang akan digunakan untuk permintaan jika peta URL ini tidak memiliki pemetaan.
Untuk mengetahui informasi selengkapnya tentang perintah CLI gcloud
ini, baca dokumentasi referensi gcloud compute url-maps create
.
REST
POST https://compute.googleapis.com/compute/v1/projects/PROJECT_NAME/global/urlMaps { "name": "URL_MAP_NAME", "defaultService": "https://www.googleapis.com/compute/v1/projects/PROJECT_NAME/global/backendServices/BACKEND_SERVICE_NAME " }
Ganti kode berikut:
PROJECT_NAME
: nama project.URL_MAP_NAME
: nama peta URL yang akan dibuat.BACKEND_SERVICE_NAME
: nama layanan backend yang akan digunakan untuk permintaan jika peta URL ini tidak memiliki pemetaan.
Membuat proxy HTTPS target
Buat proxy HTTPS target untuk mengarahkan permintaan ke peta URL Anda. Proxy adalah bagian dari load balancer yang menyimpan sertifikat SSL untuk Load Balancing HTTPS, sehingga Anda juga memuat sertifikat pada langkah ini:
gcloud
gcloud compute target-https-proxies create TARGET_HTTPS_PROXY_NAME \ --ssl-certificates=SSL_CERTIFICATE_NAME \ --url-map=URL_MAP_NAME \ --global
Ganti kode berikut:
TARGET_HTTPS_PROXY_NAME
: nama proxy HTTPS target yang akan dibuat.SSL_CERTIFICATE_NAME
: sertifikat SSL yang terkait dengan load balancer.URL_MAP_NAME
: resource peta URL.
Untuk mengetahui informasi selengkapnya tentang perintah CLI gcloud
ini, baca dokumentasi referensi gcloud compute target-https-proxies create
.
REST
POST https://compute.googleapis.com/compute/v1/projects/PROJECT_NAME/global/targetHttpsProxies { "sslCertificates": [ "https://www.googleapis.com/compute/v1/projects/PROJECT_NAME/global/sslCertificates/SSL_CERTIFICATE_NAME" ], "urlMap": "https://www.googleapis.com/compute/v1/projects/PROJECT_NAME/global/urlMaps/URL_MAP_NAME", "name": "TARGET_HTTPS_PROXY_NAME" }
Ganti kode berikut:
PROJECT_NAME
: nama project.SSL_CERTIFICATE_NAME
: sertifikat SSL yang terkait dengan load balancer.URL_MAP_NAME
: resource peta URL.TARGET_HTTPS_PROXY_NAME
: nama proxy HTTPS target yang akan dibuat.
Membuat alamat global
Cadangkan alamat IP statis yang akan digunakan oleh load balancer:
gcloud
gcloud compute addresses create LB_IP_ADDRESS_NAME \ --global
Ganti kode berikut:
LB_IP_ADDRESS_NAME
: nama untuk alamat IP eksternal atau internal statis yang dicadangkan dari load balancer.
Untuk mengetahui informasi selengkapnya tentang perintah CLI gcloud
ini, baca dokumentasi referensi gcloud compute addresses create
.
REST
POST https://compute.googleapis.com/compute/v1/projects/PROJECT_NAME/global/addresses { "name": "LB_IP_ADDRESS_NAME" }
Ganti kode berikut:
PROJECT_NAME
: nama project.LB_IP_ADDRESS_NAME
: nama untuk alamat IP eksternal atau internal statis yang dicadangkan dari load balancer.
Membuat aturan penerusan
Buat aturan penerusan untuk mengarahkan permintaan masuk ke proxy:
gcloud
gcloud compute forwarding-rules create HTTPS_FORWARDING_RULE_NAME \ --load-balancing-scheme=EXTERNAL_MANAGED \ --network-tier=PREMIUM \ --address=LB_IP_ADDRESS_NAME \ --target-https-proxy=TARGET_HTTPS_PROXY_NAME \ --global \ --ports=443
Ganti kode berikut:
HTTPS_FORWARDING_RULE_NAME
: nama aturan penerusan yang akan dibuat.LB_IP_ADDRESS_NAME
: nama untuk alamat IP eksternal atau internal statis yang dicadangkan dari load balancer.TARGET_HTTPS_PROXY_NAME
: proxy HTTPS target yang menerima traffic.
Untuk mengetahui informasi selengkapnya tentang perintah CLI gcloud
ini, baca dokumentasi referensi gcloud compute forwarding-rules create
.
REST
POST https://compute.googleapis.com/compute/v1/projects/PROJECT_NAME/global/forwardingRules { "loadBalancingScheme": "EXTERNAL_MANAGED", "networkTier": "PREMIUM", "IPAddress": "https://www.googleapis.com/compute/v1/projects/PROJECT_NAME/global/addresses/LB_IP_ADDRESS_NAME", "target": "https://www.googleapis.com/compute/v1/projects/PROJECT_NAME/global/targetHttpsProxies/TARGET_HTTPS_PROXY_NAME", "name": "HTTPS_FORWARDING_RULE_NAME", "portRange": "443-443" }
Ganti kode berikut:
PROJECT_NAME
: nama project.LB_IP_ADDRESS_NAME
: nama untuk alamat IP eksternal atau internal statis yang dicadangkan dari load balancer.TARGET_HTTPS_PROXY_NAME
: proxy HTTPS target yang menerima traffic.HTTPS_FORWARDING_RULE_NAME
: nama aturan penerusan yang akan dibuat.
Siapkan DNS
Siapkan DNS, lalu tambahkan data yang memetakan *.DOMAIN
—misalnya,
*.example.com
—ke alamat IP yang dicadangkan di langkah sebelumnya. Jika Anda menggunakan Cloud DNS untuk mengelola DNS bagi domain Anda, lihat Menambahkan data DNS.
Membuat konfigurasi workstation dan workstation Anda
Untuk mengakses workstation menggunakan domain kustom, lakukan hal berikut:
Gunakan cluster dengan domain kustom untuk membuat konfigurasi workstation.
Buat workstation menggunakan konfigurasi workstation dengan domain kustom.
Langkah selanjutnya
Untuk mengetahui informasi selengkapnya tentang penyiapan domain kustom dan cluster pribadi, lihat referensi berikut:
- Tutorial: Menyiapkan domain menggunakan Cloud DNS
- Mengonfigurasi Kontrol Layanan VPC dan cluster pribadi