Mengimpor dan mengekspor resource Google Cloud yang ada secara massal
Halaman ini menjelaskan perintah config-connector bulk-export dan cara menggunakannya untuk
mengekspor Google Cloud resource ke dalam file YAML Config Connector
yang selanjutnya dapat Anda impor ke Config Connector.
config-connector bulk-export menggunakan fungsi Ekspor Inventaris Aset Cloud untuk menemukan resource Google Cloud yang ada. Anda dapat memberikan ekspor Cloud Asset Inventory atau config-connector dapat melakukan ekspor atas nama Anda.
Cloud Asset Inventory mengekspor struktur JSON. Setiap struktur memiliki nama resource, jenis Inventaris Aset, dan resource ancestor-nya: project, folder, dan organisasi. Untuk mengetahui jenis yang didukung oleh inventaris aset, lihat Jenis aset yang didukung.
Batasan
Tidak semua resource mendukung perintah bulk-export. Untuk mendapatkan daftar resource yang didukung, jalankan config-connector print-resources.
Sebelum memulai
Jika Anda ingin menggunakan alat
config-connectoruntuk mengekspor langsung dari Inventaris Aset Cloud, aktifkan Cloud Asset Inventory API di project Identitas Anda dengan Google Cloudgcloud.gcloud services enable cloudasset.googleapis.com
Contoh ekspor massal
Dalam contoh ini, Anda membuat PubSubTopic dengan Google Cloud CLI, lalu mengimpornya ke Config Connector.
Buat topik bernama
sample-topicdengan Google Cloud CLI:gcloud pubsub topics create sample-topicAnda akan menerima konfirmasi bahwa topik telah dibuat.
Created topic [projects/PROJECT_ID/topics/sample-topic].Dalam output,
PROJECT_IDdiganti dengan Google Cloud project Anda.Dapatkan nama resource topik Google Cloud dan simpan ke variabel lingkungan dengan perintah berikut:
TOPIC_RESOURCE_NAME=$(gcloud pubsub topics describe sample-topic --format "value(name)")Untuk mengidentifikasi objek, alat
config-connectormenggunakan struktur JSON Cloud Asset Inventory. Simpan struktur JSON aset topik ke dalam variabel lingkungan:TOPIC_ASSET='{"name":"//pubsub.googleapis.com/'"${TOPIC_RESOURCE_NAME}"'","asset_type":"pubsub.googleapis.com/Topic"}'Teruskan aset ke
config-connector bulk-exportdengan menjalankan perintah berikut:echo ${TOPIC_ASSET} | config-connector bulk-exportOutputnya adalah resource Config Connector dalam format YAML.
--- apiVersion: pubsub.cnrm.cloud.google.com/v1beta1 kind: PubSubTopic metadata: annotations: cnrm.cloud.google.com/project-id: PROJECT_ID name: sample-topic ...Dalam output,
PROJECT_IDdiganti dengan Google Cloud project Anda.Anda dapat meneruskan resource ini ke Config Connector dengan
kubectl apply -f -. Untuk meneruskan resource secara langsung, jalankan perintah berikut:echo ${TOPIC_ASSET} | config-connector bulk-export | kubectl apply -f - --namespace CC_NAMESPACEGanti CC_NAMESPACE dengan namespace tempat Config Connector mengelola resource.
Config Connector mengambil resource.
Pastikan Config Connector mengelola resource dengan
kubectl describe:kubectl describe pubsubtopic sample-topic --namespace CC_NAMESPACEGanti
CC_NAMESPACEdengan namespace tempat Config Connector mengelola resource.
Pembersihan
Anda dapat menghapus PubSubTopic dengan config-connector bulk-export dan
kubectl delete.
echo ${TOPIC_ASSET} | config-connector bulk-export | kubectl delete -f - --namespace CC_NAMESPACE
Ganti CC_NAMESPACE dengan namespace tempat Config Connector
mengelola resource.
Menemukan resource yang akan diimpor
Saat mengimpor resource, Anda dapat melakukan
ekspor Inventaris Aset Cloud dan memberikan
hasilnya ke config-connector bulk-export atau meminta config-connector bulk-export melakukannya untuk
Anda.
Mengimpor dari ekspor Inventaris Aset Cloud
Anda dapat memberikan ekspor inventaris aset dengan memberikan jalur ke file lokal yang berisi ekspor atau menyalurkan hasil ekspor ke config-connector
di STDIN.
Mengimpor dari file lokal
Anda dapat memberikan
ekspor inventaris aset
ke config-connector bulk-export dengan menggunakan file lokal dengan parameter --input.
config-connector bulk-export --input ASSET_INVENTORY_EXPORT
Ganti ASSET_INVENTORY_EXPORT dengan nama file ekspor Cloud Asset Inventory Anda.
Mengimpor dari STDIN
Untuk menyediakan ekspor inventaris aset di STDIN, teruskan hasil ekspor ke
config-connector bulk-export. Misalnya, jika ekspor Anda berada dalam file lokal bernama
export.json, teruskan konten file ke config-connector bulk-export tanpa
memberikan parameter ekspor apa pun.
cat export.json | config-connector bulk-export
Memfilter ekspor Inventaris Aset di STDIN
Untuk memfilter ekspor inventaris aset, Anda dapat menggunakan alat
jq dan menyalurkan input
hasil ke config-connector bulk-export. Misalnya, jika Anda hanya ingin mengimpor aset
PubSubTopic dari file EXPORT_FILE, jalankan perintah
berikut:
cat EXPORT_FILE | jq '. | select( .asset_type == "pubsub.googleapis.com/Topic" )' | config-connector bulk-export
Mengekspor inventaris dengan config-connector
Alat config-connector bulk-export dapat mengekspor resource dari Google Cloud
Hierarki resource.
Mengekspor project
Untuk mengekspor semua resource dari project Anda, gunakan parameter --project.
config-connector bulk-export --project PROJECT_ID
Ganti PROJECT_ID dengan Google Cloud project Anda.
Mengekspor folder Anda
Untuk mengekspor semua resource dari folder, gunakan parameter --folder.
config-connector bulk-export --folder FOLDER_NUMBER
Ganti FOLDER_NUMBER dengan Google Cloud nomor folder Anda.
Mengekspor organisasi Anda
Untuk mengekspor semua resource dari organisasi Anda, gunakan parameter --organization.
config-connector bulk-export --organization ORGANIZATION_ID
Ganti ORGANIZATION_ID dengan Google Cloud ID organisasi Anda.
Lokasi Cloud Storage
Lokasi output ekspor inventaris aset adalah URI Cloud Storage. Saat melakukan ekspor, config-connector bulk-export menggunakan bucket Cloud Storage. Secara default, config-connector bulk-export
membuat bucket sementara. Anda juga dapat menentukan nama bucket.
Bucket Cloud Storage sementara
Jika Anda tidak memberikan parameter --storage-key, config-connector
bulk-export akan membuat bucket Cloud Storage sementara atas nama Anda. Bucket dibuat di lokasi default untuk bucket penyimpanan; US
multi-region. Bucket akan dihapus saat
ekspor selesai.
Menentukan bucket sementara
Untuk menentukan bucket, gunakan Cloud Storage URI dengan parameter storage-key. Jika URI hanya berupa nama bucket, nama akan dibuat
untuk objek penyimpanan ekspor. Jika URI adalah jalur lengkap ke objek penyimpanan,
maka jalur lengkap akan digunakan.
config-connector bulk-export --storage-key gs://BUCKET_NAME
Output
Output dari perintah config-connector bulk-export adalah
resource Config Connector dalam format YAML. File YAML ditulis ke
STDOUT secara default. Anda dapat mengarahkan output resource ke file dengan opsi output.
Output ke satu file
Saat Anda menetapkan parameter --output, config-connector bulk-export menulis hasilnya ke
satu file jika salah satu hal berikut benar:
- File yang ditentukan oleh
outputada dan merupakan fileregular. - File yang ditentukan oleh
outputtidak ada dan direktori induk yang diwakili olehoutputada.
Output ke direktori
config-connector menulis hasilnya ke beberapa file saat parameter --output
adalah direktori yang diakhiri dengan /. config-connector bulk-export membuat satu
file per resource, dan nama file cocok dengan nama resource-nya.
config-connector bulk-export --project PROJECT_ID --on-error continue --output OUTPUT_DIRECTORY/
Ganti PROJECT_ID dengan Google Cloud project Anda.
Misalnya, untuk mengeluarkan aset dari project my-project ke direktori sample, jalankan perintah berikut:
config-connector bulk-export --project my-project --on-error continue --output sample/
Opsi command line
Perintah config-connector bulk-export memiliki opsi berikut:
config-connector bulk-export
--input FILENAME \
--output FILENAME \
--storage-key gs://BUCKET_NAME \
--project PROJECT_ID \
--folder FOLDER_NUMBER \
--organization ORGANIZATION_ID \
--oauth2-token TOKEN \
--on-error [halt | continue | ignore] \
--iam-format [policy | policymember | none] \
--filter-deleted-iam-members [true | false] \
--verbose
--input: File input Inventaris Aset Cloud.--output: Jalur file output opsional yang menonaktifkan output standar. Jika file, hasilnya berisi semua output perintah; jika direktori, direktori akan berisi file baru untuk setiap resource dalam output.--storage-key: Bucket Cloud Storage sementara target untuk diekspor.--project: Google Cloud project ID yang akan diekspor--folder: Google Cloud ID folder yang akan diekspor--organization: Google Cloud ID organisasi yang akan diekspor.--oauth2-token: Token OAUTH2 sebagai identitas Google Cloud . Secara default,config-connectormenggunakan kredensial default Google Cloud CLI.--on-error: Mengontrol perilaku saat terjadi error yang dapat dipulihkan. Opsinya adalah 'continue', 'halt', atau 'ignore'.halt: menghentikan eksekusi jika terjadi error (default)continue: terus memproses resource, mencetak error ke STDERRignore: terus memproses resource dan tidak mencetak error
--iam-format: Menentukan jenis output resource IAM dengan ekspor Anda. Opsinya adalahpolicy(default),policymember, ataunone.--filter-deleted-iam-members: Menentukan apakah akan memfilter akun utama IAM yang dihapus. Opsinya adalahtrueataufalse. Nilai defaultnya adalahfalse.--verbose: Mengaktifkan logging panjang.
Langkah berikutnya
- Baca cara Config Connector mendapatkan resource Google Cloud yang ada
- Pelajari Inventaris Aset Cloud dan Mengekspor aset ke Cloud Storage.
- Pelajari resource yang didukung Config Connector.