diff --git a/content/id/docs/tasks/configure-pod-container/security-context.md b/content/id/docs/tasks/configure-pod-container/security-context.md index 0312d37b74..f12aa4a47d 100644 --- a/content/id/docs/tasks/configure-pod-container/security-context.md +++ b/content/id/docs/tasks/configure-pod-container/security-context.md @@ -1,35 +1,35 @@ --- -title: Mengonfigurasi Konteks Keamanan untuk Pod atau Kontainer +title: Mengonfigurasi Konteks Keamanan untuk Pod atau Container content_template: templates/task weight: 80 --- {{% capture overview %}} -Konteks keamanan menentukan wewenang dan aturan kontrol akses untuk sebuah Pod -atau kontainer. Aturan konteks keamanan meliputi hal-hal berikut ini namun tidak terbatas pada hal-hal tersebut: +Konteks keamanan (_security context_) menentukan wewenang (_privilege_) dan aturan kontrol akses untuk sebuah Pod +atau Container. Aturan konteks keamanan meliputi hal-hal berikut ini namun tidak terbatas pada hal-hal tersebut: -* Diskresi kontrol akses: Izin untuk mengakses objek, seperti sebuah _file_, yang didasarkan pada -[ID pengguna atau_user ID_ (UID) dan ID grup atau _group ID_ (GID)](https://wiki.archlinux.org/index.php/users_and_groups). +* Kontrol akses bersifat diskresi: Izin untuk mengakses objek, seperti sebuah berkas, yang didasarkan pada +[ID pengguna atau _user ID_ (UID) dan ID grup atau _group ID_ (GID)](https://wiki.archlinux.org/index.php/users_and_groups). -* [_Security Enhanced Linux_ (SELinux)](https://en.wikipedia.org/wiki/Security-Enhanced_Linux): Dimana objek diberi label keamanan. +* [_Security Enhanced Linux_ (SELinux)](https://en.wikipedia.org/wiki/Security-Enhanced_Linux): Di mana objek diberi label keamanan. -* Menjalankan dengan wewenang atau tidak dengan wewenang. +* Menjalankan dengan wewenang (_privileged_) atau tanpa wewenang (_unprivileged_). -* [Kemampuan Linux](https://linux-audit.com/linux-capabilities-hardening-linux-binaries-by-removing-setuid/): Memberi sebuah proses beberapa wewenang, namun tidak semua wewenang dari pengguna _root_. +* [Kapabilitas Linux (Linux Capabilities)](https://linux-audit.com/linux-capabilities-hardening-linux-binaries-by-removing-setuid/): Memberi sebuah proses beberapa wewenang, namun tidak semua wewenang dari pengguna _root_. * [AppArmor](/docs/tutorials/clusters/apparmor/): Menggunakan profil program untuk membatasi kemampuan dari masing-masing program. * [Seccomp](https://en.wikipedia.org/wiki/Seccomp): Menyaring panggilan sistem (_system calls_) dari suatu proses. -* AllowPrivilegeEscalation: Mengontrol apakah suatu proses dapat memperoleh lebih banyak wewenang daripada proses induknya. Pilihan ini mengontrol secara langsung apakah opsi [`no_new_privs`](https://www.kernel.org/doc/Documentation/prctl/no_new_privs.txt) diaktifkan pada proses dalam kontainer. AllowPrivilegeEscalation selalu aktif (_true_) ketika kontainer: 1) berjalan dengan wewenang ATAU 2) memiliki `CAP_SYS_ADMIN`. +* AllowPrivilegeEscalation: Mengontrol apakah suatu proses dapat memperoleh lebih banyak wewenang daripada proses induknya. Pilihan ini mengontrol secara langsung apakah opsi [`no_new_privs`](https://www.kernel.org/doc/Documentation/prctl/no_new_privs.txt) diaktifkan pada proses dalam Container. AllowPrivilegeEscalation selalu aktif (_true_) ketika Container: 1) berjalan dengan wewenang ATAU 2) memiliki `CAP_SYS_ADMIN`. -* readOnlyRootFilesystem: _Mount_ _file_ sistem _root_ dari sebuah kontainer hanya sebatas untuk dibaca saja. +* readOnlyRootFilesystem: Menambatkan (_mount_) sistem berkas (_file system_) _root_ dari sebuah Container hanya sebatas untuk dibaca saja (_read-only_). -Poin-poin di atas bukanlah sekumpulan lengkap dari aturan konteks keamanan - silakan lihat [SecurityContext](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.18/#securitycontext-v1-core) untuk daftar yang lebih lengkap. +Poin-poin di atas bukanlah sekumpulan lengkap dari aturan konteks keamanan - silakan lihat [SecurityContext](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.18/#securitycontext-v1-core) untuk daftar lengkapnya. Untuk informasi lebih lanjut tentang mekanisme keamanan pada Linux, silahkan lihat -[tinjauan umum fitur keamanan pada Kernel Linux](https://www.linux.com/learn/overview-linux-kernel-security-features) +[ikhtisar fitur keamanan pada Kernel Linux](https://www.linux.com/learn/overview-linux-kernel-security-features) {{% /capture %}} @@ -44,32 +44,32 @@ Untuk informasi lebih lanjut tentang mekanisme keamanan pada Linux, silahkan lih ## Mengatur konteks keamanan untuk Pod Untuk menentukan aturan keamanan pada Pod, masukkan bagian `securityContext` -dalam spesifikasi Pod. Bagian `securityContext` adalah sebuah objek dari +dalam spesifikasi Pod. Bagian `securityContext` adalah sebuah objek [PodSecurityContext](/docs/reference/generate/kubernetes-api/{{}}/#podsecuritycontext-v1-core). -Aturan keamanan yang kamu tetapkan untuk Pod akan berlaku untuk semua kontainer dalam Pod tersebut. -Berikut ini adalah _file_ konfigurasi untuk Pod yang memiliki _volume_ `securityContext` dan `emptyDir`: +Aturan keamanan yang kamu tetapkan untuk Pod akan berlaku untuk semua Container dalam Pod tersebut. +Berikut sebuah berkas konfigurasi untuk Pod yang memiliki volume `securityContext` dan `emptyDir`: {{< codenew file="pods/security/security-context.yaml" >}} -Dalam _file_ konfigurasi ini, bagian `runAsUser` menentukan bahwa dalam setiap kontainer pada +Dalam berkas konfigurasi ini, bagian `runAsUser` menentukan bahwa dalam setiap Container pada Pod, semua proses dijalankan oleh ID pengguna 1000. Bagian `runAsGroup` menentukan grup utama dengan ID 3000 untuk -semua proses dalam setiap kontainer pada Pod. Jika bagian ini diabaikan, maka ID grup utama dari kontainer -akan berubah menjadi _root_(0). _File_ apa pun yang dibuat juga akan dimiliki oleh pengguna dengan ID 1000 dan grup dengan ID 3000 ketika `runAsGroup` ditentukan. -Pada saat bagian `fsGroup` ditentukan, semua proses kontainer juga merupakan bagian dari grup tambahan dengan ID 2000. -Pemilik dari _volume_ `/data/demo` dan _file_ apa pun yang dibuat dalam _volume_ tersebut adalah grup dengan ID 2000. +semua proses dalam setiap Container pada Pod. Jika bagian ini diabaikan, maka ID grup utama dari Container +akan berubah menjadi _root_(0). Berkas apa pun yang dibuat juga akan dimiliki oleh pengguna dengan ID 1000 dan grup dengan ID 3000 ketika `runAsGroup` ditentukan. +Karena `fsGroup` ditentukan, semua proses milik Container juga merupakan bagian dari grup tambahan dengan ID 2000. +Pemilik volume `/data/demo` dan berkas apa pun yang dibuat dalam volume tersebut adalah grup dengan ID 2000. -Buatlah Pod: +Buatlah Pod tersebut: ```shell kubectl apply -f https://k8s.io/examples/pods/security/security-context.yaml ``` -Verifikasi bahwa kontainer dari Pod sedang berjalan: +Verifikasi bahwa Container dari Pod sedang berjalan: ```shell kubectl get pod security-context-demo ``` -Dapatkan _shell_ dari kontainer yang sedang berjalan: +Masuk ke _shell_ dari Container yang sedang berjalan tersebut: ```shell kubectl exec -it security-context-demo -- sh @@ -81,7 +81,7 @@ Pada _shell_ kamu, lihat daftar proses yang berjalan: ps ``` -Tampilan menunjukkan bahwa proses dijalankan oleh pengguna dengan ID 1000, dimana merupakan nilai dari bagian `runAsUser`: +Keluarannya menunjukkan bahwa proses dijalankan oleh pengguna dengan ID 1000, yang merupakan nilai dari bagian `runAsUser`: ```shell PID USER TIME COMMAND @@ -90,28 +90,28 @@ PID USER TIME COMMAND ... ``` -Pada _shell_ kamu, pindahkan ke direktori `/data`, dan lihat isi dari direktori tersebut: +Pada _shell_ kamu, pindah ke direktori `/data`, dan lihat isinya: ```shell cd /data ls -l ``` -Tampilan menunjukkan bahwa direktori `/data/demo` memiliki grup dengan ID 2000, dimana merupakan +Keluarannya menunjukkan bahwa direktori `/data/demo` memiliki grup dengan ID 2000, yang merupakan nilai dari bagian `fsGroup`. ```shell drwxrwsrwx 2 root 2000 4096 Jun 6 20:08 demo ``` -Pada _shell_ kamu, pindahkan ke direktori `/data/demo`, dan buatlah _file_ didalamnya: +Pada _shell_ kamu, pindah ke direktori `/data/demo`, dan buatlah sebuah berkas didalamnya: ```shell cd demo echo hello > testfile ``` -Lihatlah daftar _file_ dalam direktori `/data/demo`: +Lihatlah daftar berkas dalam direktori `/data/demo`: ```shell ls -l @@ -130,9 +130,9 @@ $ id uid=1000 gid=3000 groups=2000 ``` -Kamu akan melihat bahwa nilai _gid_ adalah 3000 yang sama dengan bagian `runAsGroup`. Jika `runAsGroup` diabaikan maka nilai _gid_ akan -tetap bernilai 0(_root_) dan proses akan dapat berinteraksi dengan _file-file_ yang dimiliki oleh grup root(0) dan yang memiliki -izin grup seperti dengan grup root(0). +Kamu akan melihat bahwa nilai _gid_ adalah 3000, sama dengan bagian `runAsGroup`. Jika `runAsGroup` diabaikan maka nilai _gid_ akan +tetap bernilai 0(_root_) dan proses akan dapat berinteraksi dengan berkas-berkas yang dimiliki oleh grup root(0) dan yang memiliki +izin grup untuk grup root(0). Keluarlah dari _shell_ kamu: @@ -140,23 +140,23 @@ Keluarlah dari _shell_ kamu: exit ``` -## Melakukan konfigurasi izin _volume_ dan kebijakan perubahan kepemilikan untuk Pod +## Melakukan konfigurasi izin volume dan kebijakan perubahan kepemilikan untuk Pod {{< feature-state for_k8s_version="v1.18" state="alpha" >}} Secara bawaan, Kubernetes mengubah kepemilikan dan izin secara rekursif untuk konten masing-masing -_volume_ untuk mencocokkan `fsGroup` yang ditentukan dalam `securityContext` dari Pod pada saat _volume_ itu -di-_mounted_. Untuk _volume_ yang besar, memeriksa dan mengubah kepemilikan dan izin dapat memerlukan waktu yang sangat lama, +volume untuk mencocokkan `fsGroup` yang ditentukan dalam `securityContext` dari Pod pada saat volume itu +ditambatkan (_mounted_). Untuk volume yang besar, memeriksa dan mengubah kepemilikan dan izin dapat memerlukan waktu yang sangat lama, sehingga memperlambat proses menjalankan Pod. Kamu dapat menggunakan bagian `fsGroupChangePolicy` dalam sebuah `securityContext` -untuk mengontrol bagaimana cara Kubernetes untuk memeriksa dan mengelola kepemilikan dan izin -untuk _volume_ tersebut. +untuk mengontrol cara Kubernetes memeriksa dan mengelola kepemilikan dan izin +untuk sebuah volume. **fsGroupChangePolicy** - `fsGroupChangePolicy` mendefinisikan perilaku untuk mengubah kepemilikan dan izin volume -sebelum diekspos di dalam sebuah Pod. Bagian ini hanya berlaku untuk tipe _volume_ yang mendukung -`fsGroup` untuk mengontrol kepemilikan dan izin. Bagian ini memiliki dua kemungkinan nilai: +sebelum diekspos di dalam sebuah Pod. Bagian ini hanya berlaku untuk tipe volume yang mendukung +`fsGroup` untuk mengontrol kepemilikan dan izin. Bagian ini memiliki dua nilai yang dapat dimasukkan: -* _OnRootMismatch_: Hanya mengubah izin dan kepemilikan jika izin dan kepemilikan dari direktori _root_ tidak sesuai dengan izin _volume_ yang diharapkan. Hal ini dapat membantu mempersingkat waktu yang diperlukan untuk mengubah kepemilikan dan izin _volume_. -* _Always_: Selalu mengubah izin dan kepemilikan _volume_ ketika volume sudah di-_mounted_. +* _OnRootMismatch_: Hanya mengubah izin dan kepemilikan jika izin dan kepemilikan dari direktori _root_ tidak sesuai dengan izin volume yang diharapkan. Hal ini dapat membantu mempersingkat waktu yang diperlukan untuk mengubah kepemilikan dan izin sebuah volume. +* _Always_: Selalu mengubah izin dan kepemilikan volume ketika volume sudah ditambatkan. Sebagai contoh: @@ -168,43 +168,43 @@ securityContext: fsGroupChangePolicy: "OnRootMismatch" ``` -Ini adalah fitur alfa. Untuk menggunakannya, silahkan aktifkan [gerbang fitur](/docs/reference/command-line-tools-reference/feature-gates/) `ConfigurableFSGroupPolicy` untuk kube-api-server, kube-controller-manager, dan kubelet. +Ini adalah fitur alpha. Untuk menggunakannya, silahkan aktifkan [gerbang fitur](/docs/reference/command-line-tools-reference/feature-gates/) `ConfigurableFSGroupPolicy` untuk kube-api-server, kube-controller-manager, dan kubelet. {{< note >}} -Bagian ini tidak berpengaruh pada tipe _volume_ sementara (_ephemeral_) seperti +Bagian ini tidak berpengaruh pada tipe volume yang bersifat sementara (_ephemeral_) seperti [`secret`](https://kubernetes.io/docs/concepts/storage/volumes/#secret), [`configMap`](https://kubernetes.io/docs/concepts/storage/volumes/#configmap), dan [`emptydir`](https://kubernetes.io/docs/concepts/storage/volumes/#emptydir). {{< /note >}} -## Mengatur konteks keamanan untuk kontainer +## Mengatur konteks keamanan untuk Container -Untuk menentukan aturan keamanan untuk suatu kontainer, sertakan bagian `securityContext` -dalam manifes kontainer. Bagian `securityContext` adalah sebuah objek +Untuk menentukan aturan keamanan untuk suatu Container, sertakan bagian `securityContext` +dalam manifes Container. Bagian `securityContext` adalah sebuah objek [SecurityContext](/docs/reference/generate/kubernetes-api/{{}}/#securitycontext-v1-core). -Aturan keamanan yang kamu tentukan untuk kontainer hanya berlaku untuk -kontainer secara individu, dan aturan tersebut menimpa aturan yang dibuat pada tingkat Pod apabila -ada aturan yang tumpang tindih. Aturan pada kontainer tidak berpengaruh pada _volume_ pada Pod. +Aturan keamanan yang kamu tentukan untuk Container hanya berlaku untuk +Container secara individu, dan aturan tersebut menimpa aturan yang dibuat pada tingkat Pod apabila +ada aturan yang tumpang tindih. Aturan pada Container mempengaruhi volume pada Pod. -Berikut ini adalah _file_ konfigurasi untuk Pod yang hanya memiliki satu kontainer. Keduanya baik Pod -dan kontainer memiliki bagian `securityContext` seperti berikut: +Berikut berkas konfigurasi untuk Pod yang hanya memiliki satu Container. Keduanya, baik Pod +dan Container memiliki bagian `securityContext` sebagai berikut: {{< codenew file="pods/security/security-context-2.yaml" >}} -Buatlah Pod: +Buatlah Pod tersebut: ```shell kubectl apply -f https://k8s.io/examples/pods/security/security-context-2.yaml ``` -Verifikasi bahwa kontainer dalam Pod sedang berjalan: +Periksa jika Container dalam Pod sedang berjalan: ```shell kubectl get pod security-context-demo-2 ``` -Dapatkan _shell_ ke kontainer yang sedang berjalan: +Masuk ke dalam _shell_ Container yang sedang berjalan tersebut: ```shell kubectl exec -it security-context-demo-2 -- sh @@ -217,8 +217,8 @@ ps aux ``` Tampilan menunjukkan bahwa proses dijalankan oleh user dengan ID 2000, yang merupakan -nilai dari `runAsUser` seperti yang disebutkan untuk kontainer. Nilai tersebut menimpa nilai ID 1000 seperti yang -disebutkan untuk Pod. +nilai dari `runAsUser` seperti yang telah ditentukan untuk Container tersebut. Nilai tersebut menimpa nilai ID 1000 yang +ditentukan untuk Pod-nya. ``` USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND @@ -233,43 +233,43 @@ Keluar dari _shell_ anda: exit ``` -## Sekumpulan kemampuan untuk kontainer +## Mengatur Kapabilitas untuk Container -Dengan menggunakan [kemampuan Linux](http://man7.org/linux/man-pages/man7/capabilities.7.html), +Dengan menggunakan [Kapabilitas Linux (Linux Capabilities)](http://man7.org/linux/man-pages/man7/capabilities.7.html), kamu dapat memberikan wewenang tertentu kepada suatu proses tanpa memberikan semua wewenang -dari pengguna _root_. Untuk menambah atau menghapus kemampuan Linux pada suatu kontainer, masukkan -bagian `capabilities` pada `securityContext` dari manifes kontainer. +dari pengguna _root_. Untuk menambah atau menghapus Kapabilitas Linux pada suatu Container, masukkan +bagian `capabilities` pada `securityContext` di manifes Container-nya. -Pertama, lihatlah apa yang terjadi ketika kamu tidak menyertakan bagian `capabilities`. -Berikut ini adalah _file_ konfigurasi yang tidak menambah atau mengurangi kemampuan apa pun dari kontainer: +Pertama-tama, mari melihat apa yang terjadi ketika kamu tidak menyertakan bagian `capabilities`. +Berikut ini adalah berkas konfigurasi yang tidak menambah atau mengurangi kemampuan apa pun dari Container: {{< codenew file="pods/security/security-context-3.yaml" >}} -Buatlah Pod: +Buatlah Pod tersebut: ```shell kubectl apply -f https://k8s.io/examples/pods/security/security-context-3.yaml ``` -Verifikasi apakah kontainer dari Pod tersebut berjalan: +Verifikasi apakah Container dari Pod tersebut sedang berjalan: ```shell kubectl get pod security-context-demo-3 ``` -Masuk ke dalam _shell_ dari kontainer yang berjalan: +Masuk ke dalam _shell_ dari Container yang berjalan: ```shell kubectl exec -it security-context-demo-3 -- sh ``` -Dalam _sheel_ tersebut, lihatlah daftar proses yang berjalan: +Dalam _shell_ tersebut, lihatlah daftar proses yang berjalan: ```shell ps aux ``` -Tampilan menunjukkan ID dari proses atau _process IDs_ (PIDs) untuk kontainer tersebut: +Tampilan menunjukkan ID dari proses atau _process IDs_ (PIDs) untuk Container tersebut: ```shell USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND @@ -277,14 +277,14 @@ root 1 0.0 0.0 4336 796 ? Ss 18:17 0:00 /bin/sh -c node server. root 5 0.1 0.5 772124 22700 ? Sl 18:17 0:00 node server.js ``` -Dalam _shell_ kamu, lihatkan status dari proses dengan ID 1: +Dalam _shell_ kamu, lihat status dari proses dengan ID 1: ```shell cd /proc/1 cat status ``` -Tampilan menunjukkan _bitmap_ kemampuan untuk proses tersebut: +Tampilan menunjukkan _bitmap_ dari kapabilitas untuk proses tersebut: ``` ... @@ -293,40 +293,40 @@ CapEff: 00000000a80425fb ... ``` -Buatlah catatan untuk _bitmap_ kemampuan tersebut, dan keluarlah dari _shell_ anda: +Buatlah catatan untuk _bitmap_ dari kapabilitas tersebut, dan keluarlah dari _shell_ kamu: ```shell exit ``` -Selanjutnya, jalankan kontainer yang sama seperti dengan kontainer sebelumnya, namun -kontainer ini memiliki kemampuan tambahan yang sudah ditetapkan. +Berikutnya, jalankan Container yang sama seperti dengan Container sebelumnya, namun +Container ini memiliki kapabilitas tambahan yang sudah ditentukan. -Berikut ini adalah _file_ konfigurasi untuk Pod yang hanya menjalankan satu kontainer. Konfigurasi -ini menambahkan kapabilitas `CAP_NET_ADMIN` dan` CAP_SYS_TIME`: +Berikut ini adalah berkas konfigurasi untuk Pod yang hanya menjalankan satu Container. Konfigurasi +ini menambahkan kapabilitas `CAP_NET_ADMIN` dan `CAP_SYS_TIME`: {{< codenew file="pods/security/security-context-4.yaml" >}} -Buatlah Pod: +Buatlah Pod tersebut: ```shell kubectl apply -f https://k8s.io/examples/pods/security/security-context-4.yaml ``` -Masuk ke dalam _shell_ dari kontainer yang berjalan: +Masuk ke dalam _shell_ dari Container yang berjalan: ```shell kubectl exec -it security-context-demo-4 -- sh ``` -Dalam _shell_ kamu, lihatkan kapabilitas dari proses dengan ID 1: +Di dalam _shell_ kamu, lihatlah kapabilitas dari proses dengan ID 1: ```shell cd /proc/1 cat status ``` -Tampilan menunjukkan _bitmap_ kemampuan untuk proses tersebut: +Tampilan menunjukkan _bitmap_ kapabilitas untuk proses tersebut: ```shell ... @@ -335,28 +335,28 @@ CapEff: 00000000aa0435fb ... ``` -Bandingkan kemampuan dari kedua kontainers tersebut: +Bandingkan kemampuan dari kedua Containers tersebut: ``` 00000000a80425fb 00000000aa0435fb ``` -Dalam _bitmap_ kemampuan pada kontainer pertama, bit-12 dan ke-25 tidak diatur. Sedangkan dalam kontainer kedua, -bit ke-12 dan ke-25 diatur. Bit ke-12 adalah kemampuan `CAP_NET_ADMIN`, dan bit-25 adalah kemampuan `CAP_SYS_TIME`. +Dalam _bitmap_ kapabilitas pada Container pertama, bit-12 dan ke-25 tidak diatur. Sedangkan dalam Container kedua, +bit ke-12 dan ke-25 diatur. Bit ke-12 adalah kapabilitas `CAP_NET_ADMIN`, dan bit-25 adalah kapabilitas `CAP_SYS_TIME`. Lihatlah [capability.h](https://github.com/torvalds/linux/blob/master/include/uapi/linux/capability.h) -untuk definisi dari konstanta kemampuan yang lainnya. +untuk nilai dari konstanta kapabilitas-kapabilitas yang lainnya. {{< note >}} -Konstanta kemampuan Linux memiliki format `CAP_XXX`. Tetapi ketika kamu memasukkan daftar kemampuan dalam manifes kontainer kamu, kamu harus menghilangkan bagian `CAP_` dari konstanta. Misalnya, untuk menambahkan `CAP_SYS_TIME`, masukkan `SYS_TIME` dalam daftar kemampuan kontainer kamu. +Konstanta kapabilitas Linux memiliki format `CAP_XXX`. Tetapi ketika kamu memasukkan daftar kemampuan dalam manifes Container kamu, kamu harus menghilangkan bagian `CAP_` dari konstantanya. Misalnya, untuk menambahkan `CAP_SYS_TIME`, masukkan `SYS_TIME` ke dalam daftar kapabilitas Container kamu. {{< /note >}} -## Memberikan label SELinux pada sebuah kontainer +## Memberikan label SELinux pada sebuah Container -Untuk memberikan label SELinux pada sebuah kontainer, masukkan bagian `seLinuxOptions` pada -bab `securityContext` dari manifes Pod atau kontainer kamu. +Untuk memberikan label SELinux pada sebuah Container, masukkan bagian `seLinuxOptions` pada +bagian `securityContext` dari manifes Pod atau Container kamu. Bagian `seLinuxOptions` adalah sebuah objek [SELinuxOptions](/docs/reference/generated/kubernetes-api/{{}}/#selinuxoptions-v1-core). -Berikut ini adalah contoh yang menerapkan tingkat (_level_) dari SELinux: +Berikut ini adalah contoh yang menerapkan sebuah level dari SELinux: ```yaml ... @@ -366,33 +366,33 @@ securityContext: ``` {{< note >}} -Untuk menetapkan label SELinux, modul keamanan SELinux harus dimuat terlebih dahulu pada sistem operasi dari _host_. +Untuk menetapkan label SELinux, modul keamanan SELinux harus dimuat terlebih dahulu pada sistem operasi dari hosnya. {{< /note >}} ## Diskusi -Konteks keamanan untuk sebuah Pod berlaku juga untuk kontainer yang berada dalam Pod tersebut dan juga untuk -_volume_ dari Pod tersebut jika ada. Khususnya untuk `fsGroup` dan `seLinuxOptions` -akan diterapkan pada _volume_ seperti berikut ini: +Konteks keamanan untuk sebuah Pod berlaku juga untuk Container yang berada dalam Pod tersebut dan juga untuk +volume dari Pod tersebut jika ada. Terkhusus untuk `fsGroup` dan `seLinuxOptions` +akan diterapkan pada volume seperti berikut: -* `fsGroup`: _Volume_ yang mendukung manajemen kepemilikan akan dimodifikasi agar dapat dimiliki +* `fsGroup`: Volume yang mendukung manajemen kepemilikan (_ownership_) akan dimodifikasi agar dapat dimiliki dan ditulis oleh ID group (GID) yang disebutkan dalam `fsGroup`. Lihatlah [Dokumen Desain untuk Manajemen Kepemilikan](https://git.k8s.io/community/contributors/design-proposals/storage/volume-ownership-management.md) -untuk lebih detail. +untuk lebih lanjut. -* `seLinuxOptions`: _Volume_ yang mendukung pelabelan SELinux akan dilabel ulang agar dapat diakses -oleh label yang ditentukan dari `seLinuxOptions`. Biasanya kamu hanya +* `seLinuxOptions`: Volume yang mendukung pelabelan SELinux akan dilabel ulang agar dapat diakses +oleh label yang ditentukan pada `seLinuxOptions`. Biasanya kamu hanya perlu mengatur bagian `level`. Dimana ini akan menetapkan label [Keamanan multi-kategori (_Multi-Category Security_) (MCS)](https://selinuxproject.org/page/NB_MLS) -yang diberikan kepada semua kontainer dalam Pod serta Volume yang ada didalamnya. +yang diberikan kepada semua Container dalam Pod serta Volume yang ada didalamnya. {{< warning >}} -Setelah kamu menentukan label MCS untuk Pod, maka semua Pod dengan label yang sama dapat mengakses _volume_. Jika kamu membutuhkan perlindungan antar Pod, kamu harus menetapkan label MCS yang unik untuk setiap Pod. +Setelah kamu menentukan label MCS untuk Pod, maka semua Pod dengan label yang sama dapat mengakses Volume tersebut. Jika kamu membutuhkan perlindungan antar Pod, kamu harus menetapkan label MCS yang unik untuk setiap Pod. {{< /warning >}} -## Membersihkan (_Clean Up_) +## Bersih-bersih (_Clean Up_) -Menghapus Pod: +Hapus Pod-Pod tersebut: ```shell kubectl delete pod security-context-demo @@ -407,7 +407,7 @@ kubectl delete pod security-context-demo-4 * [PodSecurityContext](/docs/reference/generated/kubernetes-api/{{}}/#podsecuritycontext-v1-core) * [SecurityContext](/docs/reference/generated/kubernetes-api/{{}}/#securitycontext-v1-core) -* [Mengatur Docker dengan peningkatan keamanan terbaru](https://opensource.com/business/15/3/docker-security-tuning) +* [Menyetel Docker dengan peningkatan keamanan terbaru](https://opensource.com/business/15/3/docker-security-tuning) * [Dokumen desain konteks keamanan](https://git.k8s.io/community/contributors/design-proposals/auth/security_context.md) * [Dokumen desain manajemen kepemilikan](https://git.k8s.io/community/contributors/design-proposals/storage/volume-ownership-management.md) * [Kebijakan keamanan Pod](/docs/concepts/policy/pod-security-policy/) diff --git a/content/id/examples/pods/security/hello-apparmor.yaml b/content/id/examples/pods/security/hello-apparmor.yaml new file mode 100644 index 0000000000..3e9d7e9dbb --- /dev/null +++ b/content/id/examples/pods/security/hello-apparmor.yaml @@ -0,0 +1,13 @@ +apiVersion: v1 +kind: Pod +metadata: + name: hello-apparmor + annotations: + # Mengintruksikan Kubernetes untuk menerapkan profil AppArmor "k8s-apparmor-example-deny-write". + # Perlu dicatat bahwa ini akan di abaikan jika Node Kubernetes tidak berjalan pada versi 1.4 atau lebih. + container.apparmor.security.beta.kubernetes.io/hello: localhost/k8s-apparmor-example-deny-write +spec: + containers: + - name: hello + image: busybox + command: [ "sh", "-c", "echo 'Hello AppArmor!' && sleep 1h" ] diff --git a/content/id/examples/pods/security/security-context-2.yaml b/content/id/examples/pods/security/security-context-2.yaml new file mode 100644 index 0000000000..0e3185341e --- /dev/null +++ b/content/id/examples/pods/security/security-context-2.yaml @@ -0,0 +1,13 @@ +apiVersion: v1 +kind: Pod +metadata: + name: security-context-demo-2 +spec: + securityContext: + runAsUser: 1000 + containers: + - name: sec-ctx-demo-2 + image: gcr.io/google-samples/node-hello:1.0 + securityContext: + runAsUser: 2000 + allowPrivilegeEscalation: false diff --git a/content/id/examples/pods/security/security-context-3.yaml b/content/id/examples/pods/security/security-context-3.yaml new file mode 100644 index 0000000000..d68b2a783e --- /dev/null +++ b/content/id/examples/pods/security/security-context-3.yaml @@ -0,0 +1,8 @@ +apiVersion: v1 +kind: Pod +metadata: + name: security-context-demo-3 +spec: + containers: + - name: sec-ctx-3 + image: gcr.io/google-samples/node-hello:1.0 diff --git a/content/id/examples/pods/security/security-context-4.yaml b/content/id/examples/pods/security/security-context-4.yaml new file mode 100644 index 0000000000..d725308fec --- /dev/null +++ b/content/id/examples/pods/security/security-context-4.yaml @@ -0,0 +1,11 @@ +apiVersion: v1 +kind: Pod +metadata: + name: security-context-demo-4 +spec: + containers: + - name: sec-ctx-4 + image: gcr.io/google-samples/node-hello:1.0 + securityContext: + capabilities: + add: ["NET_ADMIN", "SYS_TIME"] diff --git a/content/id/examples/pods/security/security-context.yaml b/content/id/examples/pods/security/security-context.yaml new file mode 100644 index 0000000000..35cb1eeebe --- /dev/null +++ b/content/id/examples/pods/security/security-context.yaml @@ -0,0 +1,21 @@ +apiVersion: v1 +kind: Pod +metadata: + name: security-context-demo +spec: + securityContext: + runAsUser: 1000 + runAsGroup: 3000 + fsGroup: 2000 + volumes: + - name: sec-ctx-vol + emptyDir: {} + containers: + - name: sec-ctx-demo + image: busybox + command: [ "sh", "-c", "sleep 1h" ] + volumeMounts: + - name: sec-ctx-vol + mountPath: /data/demo + securityContext: + allowPrivilegeEscalation: false