Meng-uninstal Cloud Service Mesh
Halaman ini menjelaskan cara meng-uninstal Cloud Service Mesh.
Meng-uninstal Cloud Service Mesh
Gunakan perintah berikut untuk meng-uninstal semua komponen Cloud Service Mesh. Perintah
ini juga akan menghapus namespace istio-system
dan semua definisi resource
kustom (CRD), termasuk CRD yang Anda terapkan.
Untuk mencegah gangguan traffic aplikasi:
- Downgrade kebijakan mTLS STRICT ke PERMISSIVE.
- Hapus AuthorizationPolicy yang dapat memblokir traffic.
Nonaktifkan Cloud Service Mesh yang Dikelola Otomatis melalui Fleet API, jika diaktifkan.
Nonaktifkan injeksi otomatis sidecar di namespace Anda, jika diaktifkan. Jalankan perintah berikut untuk menampilkan label namespace:
kubectl get namespace YOUR_NAMESPACE --show-labels
Outputnya mirip dengan hal berikut ini:
NAME STATUS AGE LABELS demo Active 4d17h istio.io/rev=asm-181-5
Jika Anda melihat
istio.io/rev=
dalam output di kolomLABELS
, hapus:kubectl label namespace YOUR_NAMESPACE istio.io/rev-
Jika Anda melihat
istio-injection
dalam output di kolomLABELS
, hapus:kubectl label namespace YOUR_NAMESPACE istio-injection-
Jika Anda tidak melihat label
istio.io/rev
atauistio-injection
, berarti injeksi otomatis tidak diaktifkan di namespace.Mulai ulang workload yang telah memasukkan sidecar untuk menghapus proxy.
Jika Anda menggunakan Cloud Service Mesh terkelola, hapus resource
controlplanerevision
apa pun di cluster:kubectl delete controlplanerevision RELEASE_CHANNEL -n istio-system
Dengan RELEASE_CHANNEL adalah saluran rilis yang Anda sediakan, seperti
asm-managed
,asm-managed-rapid
, atauasm-managed-stable
.Hapus webhook dari cluster Anda, jika ada.
Cloud Service Mesh dalam cluster
Hapus
validatingwebhooksconfiguration
danmutatingwebhookconfiguration
.kubectl delete validatingwebhookconfiguration,mutatingwebhookconfiguration -l operator.istio.io/component=Pilot
Cloud Service Mesh Terkelola
A. Hapus
validatingwebhooksconfiguration
.kubectl delete validatingwebhookconfiguration istiod-istio-system-mcp
B. Hapus
mutatingwebhookconfiguration
.kubectl delete mutatingwebhookconfiguration istiod-RELEASE_CHANNEL
Setelah semua beban kerja muncul dan tidak ada proxy yang diamati, Anda dapat menghapus bidang kontrol dalam cluster dengan aman untuk menghentikan penagihan. Jika Anda men-deploy panel kontrol terkelola, panel kontrol tersebut akan otomatis dihapus dengan langkah sebelumnya.
Untuk menghapus platform kontrol dalam cluster, jalankan perintah di bawah:
istioctl x uninstall --purge
Jika tidak ada plane kontrol lain, Anda dapat menghapus namespace
istio-system
untuk menghapus semua resource Cloud Service Mesh. Jika tidak, hapus layanan yang sesuai dengan revisi Cloud Service Mesh. Hal ini menghindari penghapusan resource bersama, seperti CRD.Hapus namespace
istio-system
danasm-system
:kubectl delete namespace istio-system asm-system --ignore-not-found=true
Periksa apakah penghapusan berhasil:
kubectl get ns
Output akan menunjukkan status
Terminating
dan ditampilkan seperti yang ditunjukkan. Jika tidak, Anda mungkin harus menghapus resource yang tersisa di namespace secara manual dan mencoba lagi.NAME STATUS AGE istio-system Terminating 71m asm-system Terminating 71m
- Jika Anda akan menghapus cluster, atau telah menghapusnya, pastikan setiap cluster tidak terdaftar dari fleet Anda.
Jika Anda menggunakan Cloud Service Mesh terkelola, hapus deployment
mdp-controller
:kubectl delete deployment mdp-controller -n kube-system
Hapus daemonset
istio-cni-node
:kubectl delete daemonset istio-cni-node -n kube-system