Sertifikat klien yang valid harus menampilkan rantai kepercayaan kembali ke anchor kepercayaan (sertifikat root) di penyimpanan kepercayaan. Halaman ini memberikan petunjuk untuk membuat rantai kepercayaan Anda sendiri dengan mengonfigurasi root certificate dan sertifikat perantara Anda sendiri menggunakan library OpenSSL.
Setelah membuat root of trust, dokumen ini menguraikan proses untuk menguploadnya ke trust store resource TrustConfig
Pengelola Sertifikat. Tindakan ini diikuti dengan menautkan konfigurasi kepercayaan ke resource Client Authentication (ServerTLSPolicy
), lalu melampirkan resource Client Authentication ke resource proxy HTTPS target load balancer.
Sebelum memulai
- Tinjau Ringkasan TLS bersama.
- Tinjau panduan untuk Mengelola konfigurasi tepercaya.
Instal Google Cloud CLI. Untuk mengetahui ringkasan lengkap alat ini, lihat ringkasan gcloud CLI. Anda dapat menemukan perintah yang terkait dengan load balancing di referensi API dan gcloud CLI.
Jika Anda belum menjalankan gcloud CLI sebelumnya, jalankan terlebih dahulu perintah
gcloud init
untuk melakukan autentikasi.Aktifkan API berikut: Compute Engine API, Certificate Manager API, Network Security, dan Network Services API. Untuk mempelajari lebih lanjut, lihat Mengaktifkan API.
Jika Anda menggunakan Load Balancer Aplikasi eksternal global atau Load Balancer Aplikasi klasik, pastikan Anda telah menyiapkan load balancer dengan salah satu backend yang didukung berikut:
- Backend grup instance VM
- Bucket Cloud Storage (Hanya didukung jika ada minimal satu layanan backend yang juga dilampirkan ke load balancer, selain bucket backend)
- Fungsi Cloud Run, App Engine, atau Cloud Functions
- Konektivitas hybrid
Jika Anda menggunakan Load Balancer Aplikasi eksternal regional, Load Balancer Aplikasi internal lintas region, atau Load Balancer Aplikasi internal regional, pastikan Anda telah menyiapkan load balancer dengan salah satu backend berikut yang didukung:
- Backend grup instance VM
- Cloud Run
- Konektivitas hybrid
Tetapkan project Anda.
gcloud
gcloud config set project PROJECT_ID
Izin
Untuk mendapatkan izin yang Anda perlukan untuk menyelesaikan panduan ini, minta administrator untuk memberi Anda peran IAM berikut pada project:
-
Untuk membuat resource load balancer seperti
TargetHTTPSProxy
: Compute Load Balancer Admin (roles/compute.loadBalancerAdmin
) -
Untuk menggunakan resource Certificate Manager:
Pemilik Certificate Manager (
roles/certificatemanager.owner
) -
Untuk membuat komponen keamanan dan jaringan:
Compute Network Admin (
roles/compute.networkAdmin
) dan Compute Security Admin (roles/compute.securityAdmin
) -
Untuk membuat project (opsional):
Project Creator (
roles/resourcemanager.projectCreator
)
Untuk mengetahui informasi selengkapnya tentang cara memberikan peran, lihat Mengelola akses ke project, folder, dan organisasi.
Anda mungkin juga bisa mendapatkan izin yang diperlukan melalui peran khusus atau peran bawaan lainnya.
Membuat root certificate dan intermediate certificate
Bagian ini menggunakan library OpenSSL untuk membuat root certificate (trust anchor) dan intermediate certificate.
Root certificate berada di bagian atas rantai sertifikat. Sertifikat intermediate adalah bagian dari rantai kepercayaan kembali ke root certificate. Sertifikat intermediate ditandatangani secara kriptografis oleh root certificate. Saat load balancer menerima sertifikat klien, load balancer akan memvalidasinya dengan membuat rantai kepercayaan dari sertifikat klien kembali ke anchor kepercayaan yang dikonfigurasi.
Gunakan perintah berikut untuk membuat root dan intermediate certificate. Pembuatan sertifikat perantara bersifat opsional. Namun, dalam penyiapan ini, kita menggunakan sertifikat perantara untuk menandatangani sertifikat klien.
Buat file konfigurasi OpenSSL.
Dalam contoh berikut, file konfigurasi (
example.cnf
) berisi bagian[ca_exts]
, yang menentukan ekstensi X.509 yang menandai sertifikat sebagai cocok untuk CA. Untuk mempelajari lebih lanjut persyaratan sertifikat root dan intermediate, lihat Persyaratan sertifikat.cat > example.cnf << EOF [req] distinguished_name = empty_distinguished_name [empty_distinguished_name] # Kept empty to allow setting via -subj command line arg. [ca_exts] basicConstraints=critical,CA:TRUE keyUsage=keyCertSign extendedKeyUsage=clientAuth EOF
Buat root certificate X.509 yang ditandatangani sendiri (
root.cert
). Root certificate ditandatangani sendiri dengan kunci pribadinya sendiri (root.key
).openssl req -x509 \ -new -sha256 -newkey rsa:2048 -nodes \ -days 3650 -subj '/CN=root' \ -config example.cnf \ -extensions ca_exts \ -keyout root.key -out root.cert
Buat permintaan penandatanganan sertifikat (
int.req
) untuk sertifikat perantara.openssl req -new \ -sha256 -newkey rsa:2048 -nodes \ -subj '/CN=int' \ -config example.cnf \ -extensions ca_exts \ -keyout int.key -out int.req
Tanda tangani CSR untuk membuat sertifikat perantara X.509 (
int.cert
). CSR ditandatangani menggunakan sertifikat root.openssl x509 -req \ -CAkey root.key -CA root.cert \ -set_serial 1 \ -days 3650 \ -extfile example.cnf \ -extensions ca_exts \ -in int.req -out int.cert
Membuat sertifikat yang ditandatangani sendiri yang dapat ditambahkan ke daftar yang diizinkan
Anda dapat membuat sertifikat yang ditandatangani sendiri dan menambahkannya ke daftar yang diizinkan dalam konfigurasi kepercayaan.
Gunakan perintah OpenSSL berikut untuk membuat sertifikat X.509 yang ditandatangani sendiri.
openssl req -x509 \
-new -sha256 -newkey rsa:2048 -nodes \
-days 3650 -subj '/CN=localhost' \
-keyout allowlisted.key -out allowlisted.cert
Sertifikat ini kemudian ditambahkan ke kolom allowlistedCertificates
dalam
konfigurasi kepercayaan.
Memformat sertifikat
Untuk menyertakan sertifikat baru atau yang sudah ada dalam TrustStore
, format
sertifikat menjadi satu baris dan simpan dalam variabel lingkungan, sehingga
sertifikat dapat direferensikan oleh file YAML konfigurasi kepercayaan.
export ROOT_CERT=$(cat root.cert | sed 's/^[ ]*//g' | tr '\n' $ | sed 's/\$/\\n/g')
export INTERMEDIATE_CERT=$(cat int.cert | sed 's/^[ ]*//g' | tr '\n' $ | sed 's/\$/\\n/g')
Untuk menyertakan sertifikat baru atau yang sudah ada yang ditambahkan ke daftar yang diizinkan dalam
konfigurasi kepercayaan, format sertifikat menjadi satu baris
dan simpan dalam variabel lingkungan, sehingga dapat dibaca ke dalam file
YAML. Untuk sertifikat yang ada dalam daftar yang diizinkan, gunakan perintah berikut untuk
memformat sertifikat menjadi satu baris dan menyimpannya di
variabel lingkungan ALLOWLISTED_CERT
.
export ALLOWLISTED_CERT=$(cat allowlisted.cert | sed 's/^[ ]*//g' | tr '\n' $ | sed 's/\$/\\n/g')
Membuat resource konfigurasi kepercayaan
Konfigurasi kepercayaan adalah resource yang mewakili konfigurasi Infrastruktur Kunci Publik (PKI) Anda di Pengelola Sertifikat.
Untuk membuat resource konfigurasi kepercayaan, selesaikan langkah-langkah berikut:
Konsol
Di konsol Google Cloud, buka halaman Certificate Manager.
Di tab Trust Configs, klik Add Trust Config.
Masukkan nama untuk konfigurasi.
Untuk Location, pilih Global atau Regional.
Lokasi menunjukkan tempat resource konfigurasi kepercayaan disimpan. Untuk Load Balancer Aplikasi eksternal global, Load Balancer Aplikasi klasik, dan Load Balancer Aplikasi internal lintas region, buat resource konfigurasi kepercayaan global. Untuk Load Balancer Aplikasi eksternal regional dan Load Balancer Aplikasi internal regional, buat resource konfigurasi kepercayaan regional.
Jika Anda memilih Regional, pilih region.
Di bagian Trust store, klik Add trust anchor dan upload file sertifikat yang dienkode PEM, atau salin konten sertifikat.
Klik Tambahkan.
Di bagian Trust store, klik Add intermediate CA dan upload file sertifikat yang dienkode PEM, atau salin konten sertifikat.
Langkah ini memungkinkan Anda menambahkan tingkat kepercayaan lain antara root certificate dan sertifikat server Anda.
Klik Tambahkan untuk menambahkan CA perantara.
Opsional: Di bagian Sertifikat yang diizinkan, klik Tambahkan sertifikat dan upload file sertifikat yang dienkode PEM, atau salin konten sertifikat.
Klik Tambahkan untuk menambahkan sertifikat yang diizinkan.
Klik Create.
Pastikan resource konfigurasi kepercayaan baru muncul dalam daftar konfigurasi.
gcloud
Buat file YAML konfigurasi kepercayaan (
trust_config.yaml
) yang menentukan parameter konfigurasi kepercayaan. Contoh resource konfigurasi trust ini berisi trust store dengan trust anchor dan sertifikat perantara. Fungsi ini membaca konten sertifikat dari variabel lingkungan yang dibuat di langkah Memformat sertifikat sebelumnya.cat << EOF > trust_config.yaml trustStores: - trustAnchors: - pemCertificate: "${ROOT_CERT?}" intermediateCas: - pemCertificate: "${INTERMEDIATE_CERT?}" EOF
Untuk membuat trust store dengan anchor kepercayaan atau sertifikat intermediate tambahan, tambahkan baris
pemCertificate
di bagian yang sesuai.Opsional: Tentukan sertifikat yang ditambahkan ke file YAML konfigurasi kepercayaan di kolom
allowlistedCertificates
. Anda tidak memerlukan trust store untuk menambahkan sertifikat ke daftar yang diizinkan.cat << EOF >> trust_config.yaml allowlistedCertificates: - pemCertificate: "${ALLOWLISTED_CERT?}" EOF
Sertifikat yang ditambahkan ke daftar yang diizinkan mewakili sertifikat apa pun yang dapat dienkapsulasi dalam konfigurasi kepercayaan sehingga selalu dianggap valid. Anda dapat menentukan beberapa sertifikat dalam daftar yang diizinkan dengan menggunakan beberapa instance kolom
pemCertificate
.Untuk mengimpor file YAML konfigurasi kepercayaan, gunakan perintah
gcloud certificate-manager trust-configs import
:global
Untuk Load Balancer Aplikasi eksternal global, Load Balancer Aplikasi klasik, dan Load Balancer Aplikasi internal lintas-region, tentukan
global
sebagai lokasi tempat resource konfigurasi kepercayaan disimpan.gcloud certificate-manager trust-configs import TRUST_CONFIG_NAME \ --source=trust_config.yaml \ --location=global
Ganti kode berikut:
TRUST_CONFIG_NAME
: nama resource konfigurasi kepercayaan.
regional
Untuk Load Balancer Aplikasi eksternal regional dan Load Balancer Aplikasi internal regional, tentukan region tempat resource konfigurasi kepercayaan disimpan.
gcloud certificate-manager trust-configs import TRUST_CONFIG_NAME \ --source=trust_config.yaml \ --location=LOCATION
Ganti kode berikut:
TRUST_CONFIG_NAME
: nama resource konfigurasi kepercayaan.LOCATION
: region tempat resource konfigurasi trust disimpan. Lokasi defaultnya adalahglobal
.
Membuat resource Autentikasi Klien
Resource Autentikasi Klien (juga disebut ServerTLSPolicy
) memungkinkan
Anda menentukan mode TLS sisi server dan resource konfigurasi kepercayaan yang akan digunakan
saat memvalidasi sertifikat klien. Jika klien menampilkan sertifikat
yang tidak valid atau tidak ada sertifikat ke load balancer, clientValidationMode
akan menentukan cara penanganan koneksi klien. Untuk mengetahui informasi selengkapnya, lihat
Mode validasi klien mTLS.
- Jika
clientValidationMode
ditetapkan keALLOW_INVALID_OR_MISSING_CLIENT_CERT
, semua permintaan akan diteruskan ke backend meskipun validasi gagal atau sertifikat klien tidak ada. - Jika
clientValidationMode
ditetapkan keREJECT_INVALID
, hanya permintaan yang menyediakan sertifikat klien yang dapat divalidasi terhadap resourceTrustConfig
yang diteruskan ke backend.
Untuk membuat resource Autentikasi Klien (ServerTlsPolicy
),
selesaikan langkah-langkah berikut:
Konsol
Di konsol Google Cloud, buka halaman Client Authentication.
Klik Create Client Authentication.
Masukkan nama untuk resource Autentikasi Klien.
Untuk Location, pilih Global atau Regional.
Untuk Load Balancer Aplikasi eksternal global, Load Balancer Aplikasi klasik, dan Load Balancer Aplikasi internal lintas-region, tetapkan lokasi ke global. Untuk Load Balancer Aplikasi eksternal regional dan Load Balancer Aplikasi internal regional, tetapkan lokasi ke region tempat load balancer dikonfigurasi.
Untuk Client Authentication mode, pilih Load balancing.
Pilih mode validasi klien.
Pilih resource konfigurasi kepercayaan yang Anda buat sebelumnya.
Klik Create.
Pastikan Autentikasi Klien (ServerTlsPolicy
) ditampilkan.
gcloud
Berdasarkan cara Anda ingin menangani koneksi, pilih salah satu opsi berikut untuk menentukan resource Autentikasi Klien (
ServerTlsPolicy
) dalam format YAML.Opsi 1:
clientValidationMode
ditetapkan keALLOW_INVALID_OR_MISSING_CLIENT_CERT
.global
Untuk Load Balancer Aplikasi eksternal global, Load Balancer Aplikasi klasik, dan Load Balancer Aplikasi internal lintas region, buat file YAML yang secara deklaratif menentukan mode validasi klien dan resource konfigurasi kepercayaan global:
cat << EOF > server_tls_policy.yaml name: SERVER_TLS_POLICY_NAME mtlsPolicy: clientValidationMode: ALLOW_INVALID_OR_MISSING_CLIENT_CERT clientValidationTrustConfig: projects/PROJECT_ID/locations/global/trustConfigs/TRUST_CONFIG_NAME EOF
regional
Untuk Load Balancer Aplikasi eksternal regional dan Load Balancer Aplikasi internal regional, buat file YAML yang secara deklaratif menentukan mode validasi klien dan resource konfigurasi kepercayaan regional:
cat << EOF > server_tls_policy.yaml name: SERVER_TLS_POLICY_NAME mtlsPolicy: clientValidationMode: ALLOW_INVALID_OR_MISSING_CLIENT_CERT clientValidationTrustConfig: projects/PROJECT_ID/locations/REGION/trustConfigs/TRUST_CONFIG_NAME EOF
Opsi 2:
clientValidationMode
ditetapkan keREJECT_INVALID
.global
Untuk Load Balancer Aplikasi eksternal global, Load Balancer Aplikasi klasik, dan Load Balancer Aplikasi internal lintas region, buat file YAML yang secara deklaratif menentukan mode validasi klien dan resource konfigurasi kepercayaan global:
cat << EOF > server_tls_policy.yaml name: SERVER_TLS_POLICY_NAME mtlsPolicy: clientValidationMode: REJECT_INVALID clientValidationTrustConfig: projects/PROJECT_ID/locations/global/trustConfigs/TRUST_CONFIG_NAME EOF
regional
Untuk Load Balancer Aplikasi eksternal regional dan Load Balancer Aplikasi internal regional, buat file YAML yang secara deklaratif menentukan mode validasi klien dan resource konfigurasi kepercayaan regional:
cat << EOF > server_tls_policy.yaml name: SERVER_TLS_POLICY_NAME mtlsPolicy: clientValidationMode: REJECT_INVALID clientValidationTrustConfig: projects/PROJECT_ID/locations/REGION/trustConfigs/TRUST_CONFIG_NAME EOF
Ganti kode berikut:
SERVER_TLS_POLICY_NAME
: nama resource Autentikasi Klien (ServerTlsPolicy
).PROJECT_ID
: ID project Google Cloud Anda.LOCATION
: untuk Load Balancer Aplikasi eksternal global, Load Balancer Aplikasi klasik, dan Load Balancer Aplikasi internal lintas region, gunakanglobal
. Untuk Load Balancer Aplikasi eksternal regional atau Load Balancer Aplikasi internal regional, gunakan region tempat Anda mengonfigurasi load balancer.TRUST_CONFIG_NAME
: nama resource konfigurasi kepercayaan yang Anda buat sebelumnya.
Untuk mengimpor resource
ServerTlsPolicy
Autentikasi Klien, gunakan perintahgcloud network-security server-tls-policies import
:global
Untuk Load Balancer Aplikasi eksternal global, Load Balancer Aplikasi klasik, dan Load Balancer Aplikasi internal lintas-region, tetapkan tanda
--location
keglobal
.gcloud network-security server-tls-policies import SERVER_TLS_POLICY_NAME \ --source=server_tls_policy.yaml \ --location=global
Ganti kode berikut:
SERVER_TLS_POLICY_NAME
: nama resource Autentikasi Klien (ServerTlsPolicy
).regional
Untuk Load Balancer Aplikasi eksternal regional dan Load Balancer Aplikasi internal regional, tetapkan flag
--location
ke region tempat load balancer dikonfigurasi.gcloud network-security server-tls-policies import SERVER_TLS_POLICY_NAME \ --source=server_tls_policy.yaml \ --location=LOCATION
Ganti kode berikut:
SERVER_TLS_POLICY_NAME
: nama resource Autentikasi Klien (ServerTlsPolicy
).Opsional: Untuk mencantumkan semua resource Autentikasi Klien (
ServerTlsPolicies
), gunakan perintahgcloud network-security server-tls-policies list
:gcloud network-security server-tls-policies list \ --location=LOCATION
Ganti kode berikut:
LOCATION
: Untuk Load Balancer Aplikasi eksternal global, Load Balancer Aplikasi klasik, dan Load Balancer Aplikasi internal lintas region, gunakanglobal
. Untuk Load Balancer Aplikasi eksternal regional atau Load Balancer Aplikasi internal regional, gunakan region tempat Anda mengonfigurasi load balancer.
Melampirkan resource Autentikasi Klien ke load balancer
Agar autentikasi TLS bersama berfungsi, setelah menyiapkan load balancer, Anda
harus melampirkan resource Autentikasi Klien (ServerTLSPolicy
)
ke resource proxy HTTPS target load balancer.
Konsol
Di konsol Google Cloud, buka halaman Load balancing.
Dari daftar load balancer, pilih load balancer tempat Anda perlu melampirkan resource Autentikasi Klien (
ServerTLSPolicy
).Klik
Edit.Di bagian Frontend configuration untuk frontend HTTPS, luaskan bagian Show Advanced features.
Dari daftar Client Authentication, pilih resource Client Authentication.
Klik Done.
Klik Perbarui.
gcloud
Untuk mencantumkan semua resource proxy HTTPS target dalam project Anda, gunakan perintah
gcloud compute target-https-proxies list
:gcloud compute target-https-proxies list
Perhatikan nama proxy HTTPS target yang akan dilampirkan ke resource
ServerTLSPolicy
. Nama ini disebut sebagaiTARGET_HTTPS_PROXY_NAME
dalam langkah-langkah berikut.Untuk mengekspor konfigurasi proxy HTTPS target ke file, gunakan perintah
gcloud compute target-https-proxies export
.global
gcloud compute target-https-proxies export TARGET_HTTPS_PROXY_NAME \ --destination=TARGET_PROXY_FILENAME \ --global
Ganti kode berikut:
TARGET_HTTPS_PROXY_NAME
: nama proxy target.TARGET_PROXY_FILENAME
: nama file konfigurasi proxy target dalam format YAML. Contoh,mtls_target_proxy.yaml
.
regional
gcloud compute target-https-proxies export TARGET_HTTPS_PROXY_NAME \ --destination=TARGET_PROXY_FILENAME \ --region=REGION
Ganti kode berikut:
TARGET_HTTPS_PROXY_NAME
: nama proxy target.TARGET_PROXY_FILENAME
: nama file konfigurasi proxy target dalam format YAML. Misalnya,mtls_target_proxy.yaml
REGION
: region tempat Anda mengonfigurasi load balancer.
Untuk mencantumkan semua resource Autentikasi Klien (
ServerTlsPolicy
), gunakan perintahgcloud network-security server-tls-policies list
:gcloud network-security server-tls-policies list \ --location=LOCATION
Ganti kode berikut:
LOCATION
: untuk Load Balancer Aplikasi internal lintas region, Load Balancer Aplikasi eksternal global, atau Load Balancer Aplikasi klasik, gunakanglobal
. Untuk Load Balancer Aplikasi eksternal regional atau Load Balancer Aplikasi internal regional, gunakan region tempat Anda mengonfigurasi load balancer.Catat nama resource Autentikasi Klien (
ServerTLSPolicy
) untuk mengonfigurasi mTLS. Nama ini disebut sebagaiSERVER_TLS_POLICY_NAME
di langkah berikutnya.Tambahkan Autentikasi Klien (
ServerTlsPolicy
) ke proxy HTTPS target.echo "serverTlsPolicy: //networksecurity.googleapis.com/projects/PROJECT_ID/locations/LOCATION/serverTlsPolicies/SERVER_TLS_POLICY_NAME" >> TARGET_PROXY_FILENAME
Ganti kode berikut:
PROJECT_ID
: ID project Google Cloud Anda.LOCATION
: untuk Load Balancer Aplikasi eksternal global atau Load Balancer Aplikasi klasik, dan Load Balancer Aplikasi internal lintas region, gunakanglobal
. Untuk Load Balancer Aplikasi eksternal regional atau Load Balancer Aplikasi internal regional, gunakan region tempat Anda mengonfigurasi load balancer.SERVER_TLS_POLICY_NAME
: nama resource Autentikasi Klien (ServerTLSPolicy
).TARGET_PROXY_FILENAME
: nama file konfigurasi proxy target dalam format YAML.
Untuk mengimpor konfigurasi proxy HTTPS target dari file, gunakan perintah
gcloud compute target-https-proxies import
.global
gcloud compute target-https-proxies import TARGET_HTTPS_PROXY_NAME \ --source=TARGET_PROXY_FILENAME \ --global
Ganti kode berikut:
TARGET_HTTPS_PROXY_NAME
: nama proxy target.TARGET_PROXY_FILENAME
: nama file konfigurasi proxy target dalam format YAML. Contoh,mtls_target_proxy.yaml
.
regional
gcloud compute target-https-proxies import TARGET_HTTPS_PROXY_NAME \ --source=TARGET_PROXY_FILENAME \ --region=REGION
Ganti kode berikut:
TARGET_HTTPS_PROXY_NAME
: nama proxy target.TARGET_PROXY_FILENAME
: nama file konfigurasi proxy target dalam format YAML. Misalnya,mtls_target_proxy.yaml
REGION
: region tempat Anda mengonfigurasi load balancer.
Menambahkan header kustom mTLS
Saat mengaktifkan mTLS, Anda dapat meneruskan informasi tentang koneksi mTLS menggunakan header kustom. Anda juga dapat mengaktifkan logging sehingga kegagalan koneksi mTLS dicatat dalam log.
Menambahkan header kustom mTLS ke layanan backend
Untuk Load Balancer Aplikasi eksternal global atau Load Balancer Aplikasi klasik, Anda dapat menggunakan header kustom untuk meneruskan informasi tentang koneksi mTLS ke layanan backend.
Untuk mencantumkan semua layanan backend dalam project, gunakan perintah
gcloud compute backend-services list
:gcloud compute backend-services list
Catat nama layanan backend untuk mengaktifkan header dan logging kustom. Nama ini disebut sebagai
BACKEND_SERVICE
di langkah berikutnya.Untuk mengupdate layanan backend, gunakan perintah
gcloud compute backend-services update
:gcloud compute backend-services update BACKEND_SERVICE \ --global \ --enable-logging \ --logging-sample-rate=1 \ --custom-request-header='X-Client-Cert-Present:{client_cert_present}' \ --custom-request-header='X-Client-Cert-Chain-Verified:{client_cert_chain_verified}' \ --custom-request-header='X-Client-Cert-Error:{client_cert_error}' \ --custom-request-header='X-Client-Cert-Hash:{client_cert_sha256_fingerprint}' \ --custom-request-header='X-Client-Cert-Serial-Number:{client_cert_serial_number}' \ --custom-request-header='X-Client-Cert-SPIFFE:{client_cert_spiffe_id}' \ --custom-request-header='X-Client-Cert-URI-SANs:{client_cert_uri_sans}' \ --custom-request-header='X-Client-Cert-DNSName-SANs:{client_cert_dnsname_sans}' \ --custom-request-header='X-Client-Cert-Valid-Not-Before:{client_cert_valid_not_before}' \ --custom-request-header='X-Client-Cert-Valid-Not-After:{client_cert_valid_not_after}'
Menambahkan header kustom mTLS ke peta URL
Untuk Load Balancer Aplikasi internal lintas-region, Load Balancer Aplikasi eksternal regional, atau Load Balancer Aplikasi internal regional, Anda dapat menggunakan header kustom untuk meneruskan informasi tentang koneksi mTLS ke peta URL.
Untuk mencantumkan semua peta URL dalam project, gunakan
perintah gcloud compute url-maps list
:
gcloud compute url-maps list
Perhatikan nama peta URL untuk mengaktifkan header dan logging kustom.
Nama ini disebut sebagai URL_MAP_NAME
di
langkah berikutnya.
global
Untuk mengedit peta URL untuk Load Balancer Aplikasi internal lintas-region, gunakan perintah gcloud compute
url-maps edit
:
gcloud compute url-maps edit URL_MAP_NAME --global
Berikut adalah contoh file YAML yang menunjukkan cara menggunakan variabel
dalam header permintaan kustom (requestHeadersToAdd
). Anda dapat menggunakan
variabel yang sama untuk mengirim header respons kustom
(responseHeadersToAdd
).
headerAction: requestHeadersToAdd: - headerName: "X-Client-Cert-Present" headerValue: "{client_cert_present}" - headerName: "X-Client-Cert-Chain-Verified" headerValue: "{client_cert_chain_verified}" - headerName: "X-Client-Cert-Error" headerValue: "{client_cert_error}" - headerName: "X-Client-Cert-Hash" headerValue: "{client_cert_sha256_fingerprint}" - headerName: "X-Client-Cert-Serial-Number" headerValue: "{client_cert_serial_number}" - headerName: "X-Client-Cert-SPIFFE" headerValue: "{client_cert_spiffe_id}" - headerName: "X-Client-Cert-URI-SANs" headerValue: "{client_cert_uri_sans}" - headerName: "X-Client-Cert-DNSName-SANs" headerValue: "{client_cert_dnsname_sans}" - headerName: "X-Client-Cert-Valid-Not-Before" headerValue: "{client_cert_valid_not_before}" - headerName: "X-Client-Cert-Valid-Not-After" headerValue: "{client_cert_valid_not_after}" - headerName: "X-Client-Cert-Issuer-Dn" headerValue: "{client_cert_issuer_dn}" - headerName: "X-Client-Cert-Subject-Dn" headerValue: "{client_cert_subject_dn}" - headerName: "X-Client-Cert-Leaf" headerValue: "{client_cert_leaf}" - headerName: "X-Client-Cert-Chain" headerValue: "{client_cert_chain}"
regional
Untuk mengedit peta URL untuk Load Balancer Aplikasi eksternal regional atau Load Balancer Aplikasi internal regional, gunakan perintah gcloud compute
url-maps edit
:
gcloud compute url-maps edit URL_MAP_NAME --region=REGION
Berikut adalah contoh file YAML yang menunjukkan cara menggunakan variabel dalam header permintaan kustom (requestHeadersToAdd
). Anda dapat menggunakan variabel yang sama untuk mengirim header respons kustom (responseHeadersToAdd
).
defaultService: regions/REGION/backendServices/BACKEND_SERVICE_1 name: regional-lb-map region: region/REGION headerAction: requestHeadersToAdd: - headerName: "X-Client-Cert-Present" headerValue: "{client_cert_present}" - headerName: "X-Client-Cert-Chain-Verified" headerValue: "{client_cert_chain_verified}" - headerName: "X-Client-Cert-Error" headerValue: "{client_cert_error}" - headerName: "X-Client-Cert-Hash" headerValue: "{client_cert_sha256_fingerprint}" - headerName: "X-Client-Cert-Serial-Number" headerValue: "{client_cert_serial_number}" - headerName: "X-Client-Cert-SPIFFE" headerValue: "{client_cert_spiffe_id}" - headerName: "X-Client-Cert-URI-SANs" headerValue: "{client_cert_uri_sans}" - headerName: "X-Client-Cert-DNSName-SANs" headerValue: "{client_cert_dnsname_sans}" - headerName: "X-Client-Cert-Valid-Not-Before" headerValue: "{client_cert_valid_not_before}" - headerName: "X-Client-Cert-Valid-Not-After" headerValue: "{client_cert_valid_not_after}" - headerName: "X-Client-Cert-Issuer-Dn" headerValue: "{client_cert_issuer_dn}" - headerName: "X-Client-Cert-Subject-Dn" headerValue: "{client_cert_subject_dn}" - headerName: "X-Client-Cert-Leaf" headerValue: "{client_cert_leaf}" - headerName: "X-Client-Cert-Chain" headerValue: "{client_cert_chain}"
Menandatangani sertifikat klien dengan sertifikat perantara
Bagian ini menyediakan opsi konfigurasi tambahan untuk membuat sertifikat klien (daun). Jika Anda telah membuat resource TrustConfig yang berisi sertifikat perantara, lakukan hal berikut:
Buat file konfigurasi untuk membuat CSR bagi sertifikat klien.
File konfigurasi berikut (
client.config
) berisi bagian[extension_requirements]
, yang menentukan ekstensi X.509 yang akan disertakan dalam CSR. Untuk mempelajari persyaratan sertifikat klien lebih lanjut, lihat Persyaratan sertifikat.cat > client.config << EOF [req] default_bits = 2048 req_extensions = extension_requirements distinguished_name = dn_requirements prompt = no [extension_requirements] basicConstraints = critical, CA:FALSE keyUsage = critical, nonRepudiation, digitalSignature, keyEncipherment extendedKeyUsage = clientAuth [dn_requirements] countryName = US stateOrProvinceName = California localityName = San Francisco 0.organizationName = example organizationalUnitName = test commonName = test.example.com emailAddress = test@example.com EOF
Jika Anda ingin melampirkan identitas SPIFFE ke file konfigurasi, lakukan hal berikut:
Tambahkan kolom
subjectAltName
ke bagian[extension_requirements]
sebagai berikut:subjectAltName = @sans_list
Tambahkan bagian baru (
[sans_list]
) di bagian bawah fileclient.config
sebagai berikut:[sans_list] URI.1 = spiffe://example.com/test-identity
Buat CSR (
client.csr
) untuk sertifikat klien.openssl req -new \ -config client.config \ -keyout client.key -out client.csr
Tanda tangani CSR untuk menerbitkan sertifikat klien X.509 (
client.cert
). CSR ditandatangani oleh sertifikat perantara.openssl x509 -req \ -CAkey int.key -CA int.cert \ -days 365 \ -extfile client.config \ -extensions extension_requirements \ -in client.csr -out client.cert
Kirim permintaan HTTPS aman ke alamat IP load balancer menggunakan sertifikat SSL sisi klien. Klien menampilkan sertifikatnya (
client.cert
) untuk mengautentikasi dirinya ke load balancer.curl -v --key client.key --cert client.cert https://IP_ADDRESS
Ganti IP_ADDRESS dengan alamat IP load balancer.