Konfigurasikan domain kustom yang akan digunakan untuk mengakses layanan
penayangan Knative Anda. Anda dapat memetakan satu atau beberapa domain kustom ke setiap layanan, atau Anda dapat memetakan satu domain ke cluster yang digunakan semua layanan. Pemetaan domain kustom Anda dapat berupa domain dasar seperti your-domain.com
, atau subdomain, seperti your-subdomain.your-domain.com
.
Secara default, layanan yang Anda deploy ke cluster penayangan Knative ditetapkan ke domain dasar nip.io
. Dengan demikian, Anda dapat langsung menguji layanan di URL seperti:
http://{SERVICE_NAME}.{NAMESPACE}.kuberun.{EXTERNAL_IP}.nip.io
Pelajari domain pengujian lebih lanjut.
Sebelum memulai
Anda harus memiliki atau membeli domain yang ingin dipetakan ke layanan Anda. Anda dapat menggunakan registrar nama domain apa pun, tetapi jika menggunakan Cloud Domains, domain akan otomatis diverifikasi untuk penayangan Knative, sehingga Anda tidak perlu melalui proses verifikasi domain.
Jika Anda ingin mendaftarkan domain ke Cloud Domains, lihat Mendaftarkan domain ke Cloud Domains dalam konsol penayangan Knative.
Anda harus memiliki setidaknya peran Identity and Access Management Kubernetes Engine Developer atau izin yang setara.
Untuk mengaktifkan HTTPS dengan pemetaan domain kustom, Anda harus menyiapkan sertifikat TLS terkelola atau mengonfigurasi sertifikat Anda sendiri.
Untuk memetakan domain kustom ke cluster atau layanan di jaringan internal pribadi, Anda harus menonaktifkan sertifikat TLS terkelola.
Memetakan domain kustom
Anda dapat menggunakan konsol Google Cloud atau alat command line untuk memetakan domain kustom.
Secara umum, untuk mengonfigurasi domain kustom:
- Opsional: Cadangkan alamat IP load balancer Anda.
- Lakukan pemetaan layanan atau cluster ke domain kustom di penayangan Knative.
- Perbarui data DNS di registrar domain Anda.
Mencadangkan alamat IP load balancer
Saat penayangan Knative diinstal, pengontrol ingress Istio akan membuat load balancer dengan alamat IP yang tersedia.
Bergantung pada cluster GKE, Anda mungkin perlu mencadangkan alamat IP load balancer untuk pengontrol ingress Istio:
- Di luar Google Cloud
- Lihat dokumentasi untuk lingkungan tempat Anda menjalankan cluster GKE untuk menentukan cara alamat IP dikelola dan apakah alamat IP load balancer Anda bersifat statis. Lihat juga halaman konfigurasi untuk cluster GKE Anda. Misalnya, bergantung pada cara Anda mengonfigurasi load balancing untuk Google Distributed Cloud, Anda mungkin telah mencadangkan alamat IP tersebut.
- Di Google Cloud
Anda harus mencadangkan alamat IP eksternal load balancer untuk memastikan alamat tersebut tetap sama jika layanan ingress Anda pernah dihapus. Bergantung pada konfigurasi cluster Anda, alamat IP tersedia secara eksternal atau hanya internal, misalnya, cluster pribadi.
- Load balancer internal di Google Cloud
- Lihat halaman berikut untuk mengetahui detail tentang cara mencadangkan alamat IP load balancer internal Anda: Mencadangkan alamat IP internal statis
- Load balancer eksternal di Google Cloud
- Untuk mencadangkan alamat IP load balancer eksternal:
Dapatkan alamat IP load balancer:
Konsol
Untuk mendapatkan alamat IP eksternal load balancer dari konsol Google Cloud:- Buka halaman GKE di konsol Google Cloud:
Buka GKE - Klik Layanan dan traffic masuk.
- Identifikasi layanan yang merupakan ingress Istio
cluster Anda. Type layanan akan menjadi External load
balancer, dan Name akan menjadi
istio-ingressgateway
. - Setelah menemukan layanan ingress Istio cluster, salin
Endpoint-nya. Ini akan menjadi alamat IP tanpa nomor
port. Misalnya, Anda mungkin melihat
00.000.000.000:11
tercantum sebagai endpoint, tetapi Anda hanya perlu menyalin00.000.000.000
.
kubectl
Untuk mendapatkan IP eksternal bagi Load Balancer, jalankan perintah berikut:
kubectl get svc istio-ingressgateway -n ASM-INGRESS-NAMESPACE
Ganti ASM-INGRESS-NAMESPACE dengan namespace tempat ingress Cloud Service Mesh Anda berada. Tentukan
istio-system
jika Anda menginstal Cloud Service Mesh menggunakan konfigurasi defaultnya.Output yang dihasilkan akan terlihat mirip dengan berikut ini:
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) istio-ingressgateway LoadBalancer XX.XX.XXX.XX pending 80:32380/TCP,443:32390/TCP,32400:32400/TCP
dengan nilai EXTERNAL-IP adalah alamat IP eksternal Load Balancer Anda.
- Buka halaman GKE di konsol Google Cloud:
Cadangkan alamat IP sebagai IP statis:
gcloud compute addresses create ADDRESS-NAME --addresses EXTERNAL-IP --region REGION
Ganti:
- ADDRESS-NAME dengan nama yang ingin Anda berikan ke IP statis.
- EXTERNAL-IP dengan alamat IP eksternal load balancer yang Anda dapatkan di langkah sebelumnya.
- REGION dengan region tempat cluster Anda berada.
Setelah mendapatkan alamat IP load balancer, Anda dapat menggunakannya untuk memetakan domain kustom:
Layanan pemetaan
Pilih salah satu metode berikut untuk memetakan domain kustom Anda ke layanan penayangan Knative. Setiap layanan dapat dipetakan ke beberapa domain.
Konsol
Buka halaman pemetaan domain di konsol Google Cloud:
Perlu diperhatikan bahwa tampilan jendela Anda terlalu kecil, Tombol Pemetaan Domain Kustom tidak ditampilkan dan Anda harus mengklik ikon elips vertikal 3 titik di sebelah pojok kanan halaman.
Klik Tambahkan Pemetaan, lalu pilih Tambahkan pemetaan domain layanan untuk memetakan domain ke setiap layanan. Anda dapat memetakan beberapa domain ke setiap layanan.
Dari daftar dropdown di formulir Tambahkan Pemetaan, pilih layanan yang ingin Anda petakan domain kustomnya:
Masukkan nama domain. Misalnya,
your-domain.com
atausubdomain.your-domain.com
. Persyaratan domain:- Pemetaan jalur dasar tidak didukung. Istilah jalur dasar
mengacu pada nama jalur URL yang berada setelah nama domain. Misalnya,
users
adalah jalur dasaryour-domain.com/users
. Penayangan Knative hanya memungkinkan Anda memetakan domain ke/
, bukan ke jalur dasar tertentu. Jadi, pemilihan rute jalur apa pun harus ditangani menggunakan router di dalam penampung layanan atau menggunakan Firebase Hosting. -
Anda tidak dapat memetakan domain ke subdomain yang cocok dengan URL layanan Anda. URL ke layanan ditentukan sebagai
http://{service}.{namespace}.{your-domain.com}
, jadi jika Anda memiliki layanan ditest.default.your-domain.com
, Anda tidak boleh membuat pemetaan domain ke subdomain yang samatest.default.
your-domain.com
.
- Pemetaan jalur dasar tidak didukung. Istilah jalur dasar
mengacu pada nama jalur URL yang berada setelah nama domain. Misalnya,
Klik Lanjutkan.
Perbarui data DNS di situs web registrar domain Anda menggunakan data DNS yang ditampilkan pada langkah terakhir. Anda dapat menampilkan data kapan saja dengan mengklik Data DNS pada "..." menu tindakan untuk pemetaan domain.
Klik Done.
gcloud
Lakukan pemetaan layanan Anda ke domain kustom:
gcloud run domain-mappings create --service SERVICE --domain DOMAIN
Ganti:
- SERVICE dengan nama layanan Anda.
- DOMAIN dengan domain kustom Anda. Misalnya,
your-domain.com
atausubdomain.your-domain.com
. Persyaratan domain:- Pemetaan jalur dasar tidak didukung. Istilah jalur dasar
mengacu pada nama jalur URL yang berada setelah nama domain. Misalnya,
users
adalah jalur dasaryour-domain.com/users
. Penayangan Knative hanya memungkinkan Anda memetakan domain ke/
, bukan ke jalur dasar tertentu. Jadi, pemilihan rute jalur apa pun harus ditangani menggunakan router di dalam penampung layanan atau menggunakan Firebase Hosting. -
Anda tidak dapat memetakan domain ke subdomain yang cocok dengan URL layanan Anda. URL ke layanan ditentukan sebagai
http://{service}.{namespace}.{your-domain.com}
, jadi jika Anda memiliki layanan ditest.default.your-domain.com
, Anda tidak boleh membuat pemetaan domain ke subdomain yang samatest.default.
your-domain.com
.
- Pemetaan jalur dasar tidak didukung. Istilah jalur dasar
mengacu pada nama jalur URL yang berada setelah nama domain. Misalnya,
Setelah domain kustom dipetakan ke penayangan Knative, Anda harus menambahkan data DNS di registrar domain.
Memetakan cluster
Pilih salah satu metode berikut untuk memetakan domain kustom ke cluster:
Konsol
Buka halaman pemetaan domain di konsol Google Cloud:
Perlu diperhatikan bahwa tampilan jendela Anda terlalu kecil, Tombol Pemetaan Domain Kustom tidak ditampilkan dan Anda harus mengklik ikon elips vertikal 3 titik di sebelah pojok kanan halaman.
Klik Tambahkan Pemetaan, lalu pilih Tambahkan domain default untuk memetakan domain ke semua layanan di cluster Anda. Secara default, layanan baru yang Anda deploy menggunakan domain yang dipetakan.
Klik kotak centang untuk menerapkan pemetaan domain baru ke semua layanan yang ada di cluster Anda.
Dari daftar dropdown di formulir Tambahkan Pemetaan, pilih cluster yang ingin Anda petakan domain kustomnya:
Masukkan nama domain. Misalnya,
your-domain.com
atausubdomain.your-domain.com
. Persyaratan domain:- Pemetaan jalur dasar tidak didukung. Istilah jalur dasar
mengacu pada nama jalur URL yang berada setelah nama domain. Misalnya,
users
adalah jalur dasaryour-domain.com/users
. Penayangan Knative hanya memungkinkan Anda memetakan domain ke/
, bukan ke jalur dasar tertentu. Jadi, pemilihan rute apa pun harus ditangani menggunakan router di dalam penampung layanan atau menggunakan Firebase Hosting. -
Anda tidak dapat memetakan domain ke subdomain yang cocok dengan URL layanan Anda. URL ke layanan ditentukan sebagai
http://{service}.{namespace}.{your-domain.com}
, jadi jika Anda memiliki layanan ditest.default.your-domain.com
, Anda tidak boleh membuat pemetaan domain ke subdomain yang samatest.default.
your-domain.com
.
- Pemetaan jalur dasar tidak didukung. Istilah jalur dasar
mengacu pada nama jalur URL yang berada setelah nama domain. Misalnya,
Klik Lanjutkan.
Perbarui data DNS di situs web registrar domain Anda menggunakan data DNS yang ditampilkan pada langkah terakhir. Anda dapat menampilkan data kapan saja dengan mengklik Data DNS pada "..." menu tindakan untuk pemetaan domain.
Klik Done.
kubectl
Jalankan perintah berikut untuk menghapus domain dasar yang ada dari ConfigMap
config-domain
dan menggantinya dengan domain kustom Anda:kubectl patch configmap config-domain --namespace knative-serving --patch \ '{"data": {"nip.io": null, "DOMAIN": ""}}'
Ganti DOMAIN dengan domain kustom Anda. Misalnya,
your-domain.com
atausubdomain.your-domain.com
. Persyaratan domain:- Pemetaan jalur dasar tidak didukung. Istilah jalur dasar
mengacu pada nama jalur URL yang berada setelah nama domain. Misalnya,
users
adalah jalur dasaryour-domain.com/users
. Penayangan Knative hanya memungkinkan Anda memetakan domain ke/
, bukan ke jalur dasar tertentu. Jadi, pemilihan rute apa pun harus ditangani menggunakan router di dalam penampung layanan atau menggunakan Firebase Hosting. -
Anda tidak dapat memetakan domain ke subdomain yang cocok dengan URL layanan Anda. URL ke layanan ditentukan sebagai
http://{service}.{namespace}.{your-domain.com}
, jadi jika Anda memiliki layanan ditest.default.your-domain.com
, Anda tidak boleh membuat pemetaan domain ke subdomain yang samatest.default.
your-domain.com
.
- Pemetaan jalur dasar tidak didukung. Istilah jalur dasar
mengacu pada nama jalur URL yang berada setelah nama domain. Misalnya,
Setelah domain kustom dipetakan ke penayangan Knative, Anda harus menambahkan data DNS di registrar domain.
Tambahkan data DNS di registrar domain
Setelah memetakan layanan ke domain kustom di penayangan Knative, Anda harus memperbarui data DNS di registrar domain. Untuk memudahkan, penayangan Knative membuat dan menampilkan data DNS yang perlu Anda masukkan. Anda harus menambahkan data ini yang mengarah ke layanan penayangan Knative di registrar domain agar pemetaan dapat dilakukan.
Jika Anda menggunakan Cloud DNS sebagai penyedia DNS, lihat Penambahan data.
Ambil informasi data DNS untuk pemetaan domain menggunakan:
Konsol
Buka halaman pemetaan domain penayangan Knative:
Klik ikon elips vertikal titik 3 di sebelah kanan layanan Anda, lalu klik DATA DNS untuk menampilkan semua data DNS:
gcloud
gcloud run domain-mappings describe --domain DOMAIN
Ganti DOMAIN dengan domain kustom Anda. Misalnya,
your-domain.com
atausubdomain.your-domain.com
.Anda memerlukan semua data yang ditampilkan di bawah judul
resourceRecords
.Login ke akun Anda di registrar domain, dan kemudian buka halaman konfigurasi DNS.
Cari bagian data host di halaman konfigurasi domain Anda, lalu kemudian tambahkan setiap data resource yang Anda terima saat Anda melakukan pemetaan domain ke layanan penayangan Knative Anda.
Saat Anda menambahkan setiap data DNS diatas ke akun di penyedia DNS:
- Pilih jenis yang ditampilkan dalam data DNS di langkah sebelumnya:
A
, atauAAAA
, atauCNAME
. - Gunakan nama
www
untuk pemetaan kewww.your-domain.com
. - Gunakan nama
@
untuk memetakanyour-domain.com
. - Gunakan
karakter pengganti
*
untuk memetakan ke*.your-domain.com
.
- Pilih jenis yang ditampilkan dalam data DNS di langkah sebelumnya:
Simpan perubahan di halaman konfigurasi DNS untuk akun domain Anda. Umumnya, diperlukan waktu beberapa menit agar perubahan ini diterapkan, tetapi dalam beberapa kasus, diperlukan waktu hingga beberapa jam, bergantung pada registrar dan Time-To-Live (TTL) dari data DNS sebelumnya untuk domain Anda. Anda dapat menggunakan alat
dig
, seperti versidig
online ini, untuk mengonfirmasi bahwa data DNS telah berhasil diupdate.Uji kesuksesan dengan menjelajahi layanan Anda di URL barunya, misalnya
https://www.your-domain.com
. Perhatikan bahwa perlu waktu beberapa menit untuk menerbitkan sertifikat SSL/TLS terkelola.
Menambahkan pemilik domain terverifikasi ke pengguna atau akun layanan lain
Saat pengguna memverifikasi domain, domain tersebut hanya diverifikasi ke akun pengguna tersebut. Hal ini berarti bahwa hanya pengguna tersebut yang dapat menambahkan lebih banyak pemetaan domain yang menggunakan domain tersebut. Jadi, untuk memungkinkan pengguna lain untuk menambahkan pemetaan yang menggunakan domain tersebut, Anda harus menambahkan mereka sebagai pemilik verifikasi.
Jika Anda perlu untuk menambahkan pemilik verifikasi domain Anda ke pengguna, atau akun layanan lain, Anda dapat menambahkan perizinan melalui halaman Search Console :
Buka alamat ini di browser web Anda:
Di bagian Properties, klik domain yang ingin ditambahkan pengguna atau akun layanan.
Scroll ke bagian daftar Verified owners, klik Add an owner, lalu masukkan alamat email Akun Google atau ID akun layanan.
Untuk melihat daftar akun layanan, buka halaman Service Accounts di konsol Google Cloud:
Mendaftarkan domain dengan Cloud Domains dalam konsol penayangan Knative
Untuk mendaftarkan domain dengan Cloud Domains dari dalam konsol penayangan Knative:
Buka halaman pemetaan domain penayangan Knative:
Klik Daftar domain.
Selesaikan proses pendaftaran dengan mengikuti petunjuk untuk Mendaftarkan domain.
Selesaikan langkah-langkah sebelumnya di halaman ini untuk Memetakan domain ke penayangan Knative, lalu tambahkan data DNS di registrar domain Anda.
Pemecahan masalah
Lihat masalah umum di Memecahkan masalah domain kustom dan TLS terkelola.