Kubernetes - Volume

Di Kubernetes, volume dapat dianggap sebagai direktori yang dapat diakses oleh container di dalam pod. Kami memiliki tipe volume yang berbeda di Kubernetes dan tipe tersebut menentukan bagaimana volume dibuat dan isinya.

Konsep volume hadir dengan Docker, namun satu-satunya masalah adalah bahwa volume sangat terbatas pada pod tertentu. Begitu umur pod berakhir, volumenya juga hilang.

Di sisi lain, volume yang dibuat melalui Kubernetes tidak terbatas pada container apa pun. Ini mendukung salah satu atau semua kontainer yang diterapkan di dalam pod Kubernetes. Keuntungan utama volume Kubernetes adalah, ia mendukung berbagai jenis penyimpanan di mana pod dapat menggunakan beberapa di antaranya pada saat yang bersamaan.

Jenis Volume Kubernetes

Berikut adalah daftar dari beberapa Volume Kubernetes yang populer -

  • emptyDir- Ini adalah jenis volume yang dibuat saat Pod pertama kali ditetapkan ke sebuah Node. Ia tetap aktif selama Pod tersebut berjalan di node tersebut. Volume awalnya kosong dan container dalam pod dapat membaca dan menulis file di volume emptyDir. Setelah Pod dihapus dari node, data di emptyDir akan dihapus.

  • hostPath - Jenis volume ini memasang file atau direktori dari filesystem node host ke pod Anda.

  • gcePersistentDisk- Jenis volume ini memasang Persistent Disk Google Compute Engine (GCE) ke dalam Pod Anda. Data dalam filegcePersistentDisk tetap utuh saat Pod dihapus dari node.

  • awsElasticBlockStore- Jenis volume ini memasang Penyimpanan Blok Elastis Amazon Web Services (AWS) ke dalam Pod Anda. SepertigcePersistentDisk, data di file awsElasticBlockStore tetap utuh saat Pod dihapus dari node.

  • nfs - An nfsvolume memungkinkan NFS (Sistem File Jaringan) yang ada untuk dipasang ke dalam pod Anda. Data di filenfsvolume tidak terhapus saat Pod dihapus dari node. Volume hanya dilepas.

  • iscsi - An iscsi volume memungkinkan volume iSCSI (SCSI over IP) yang sudah ada untuk dipasang ke dalam pod Anda.

  • flocker- Ini adalah manajer volume data kontainer berkerumun sumber terbuka. Ini digunakan untuk mengelola volume data. SEBUAHflockervolume memungkinkan set data Flocker dipasang ke dalam pod. Jika dataset tidak ada di Flocker, maka Anda harus membuatnya terlebih dahulu dengan menggunakan Flocker API.

  • glusterfs- Glusterfs adalah sistem file jaringan sumber terbuka. Volume glusterfs memungkinkan volume glusterfs dipasang ke pod Anda.

  • rbd- RBD adalah singkatan dari Rados Block Device. Sebuahrbdvolume memungkinkan volume Perangkat Blok Rados dipasang ke dalam pod Anda. Data tetap dipertahankan setelah Pod dihapus dari node.

  • cephfs - A cephfsvolume memungkinkan volume CephFS yang ada untuk dipasang ke dalam pod Anda. Data tetap utuh setelah Pod dihapus dari node.

  • gitRepo - A gitRepo volume me-mount direktori kosong dan mengkloning a git repositori ke dalamnya untuk digunakan pod Anda.

  • secret - A secret volume digunakan untuk menyampaikan informasi sensitif, seperti kata sandi, ke pod.

  • persistentVolumeClaim - A persistentVolumeClaimvolume digunakan untuk memasang PersistentVolume ke dalam pod. PersistentVolumes adalah cara bagi pengguna untuk "mengklaim" penyimpanan yang tahan lama (seperti GCE PersistentDisk atau volume iSCSI) tanpa mengetahui detail lingkungan cloud tertentu.

  • downwardAPI - A downwardAPIvolume digunakan untuk membuat data API ke bawah tersedia untuk aplikasi. Ini memasang direktori dan menulis data yang diminta dalam file teks biasa.

  • azureDiskVolume - An AzureDiskVolume digunakan untuk memasang Disk Data Microsoft Azure ke dalam Pod.

Volume Persisten dan Klaim Volume Persisten

Persistent Volume (PV)- Ini adalah bagian dari penyimpanan jaringan yang telah disediakan oleh administrator. Ini adalah sumber daya dalam kluster yang tidak bergantung pada setiap pod yang menggunakan PV.

Persistent Volume Claim (PVC)- Penyimpanan yang diminta oleh Kubernetes untuk podnya disebut PVC. Pengguna tidak perlu mengetahui penyediaan yang mendasarinya. Klaim harus dibuat di namespace yang sama tempat pod dibuat.

Membuat Volume Persisten

kind: PersistentVolume ---------> 1
apiVersion: v1
metadata:
   name: pv0001 ------------------> 2
   labels:
      type: local
spec:
   capacity: -----------------------> 3
      storage: 10Gi ----------------------> 4
   accessModes:
      - ReadWriteOnce -------------------> 5
      hostPath:
         path: "/tmp/data01" --------------------------> 6

Dalam kode di atas, kami telah mendefinisikan -

  • kind: PersistentVolume → Kita telah mendefinisikan jenisnya sebagai PersistentVolume yang memberi tahu kubernetes bahwa file yaml yang digunakan adalah untuk membuat Persistent Volume.

  • name: pv0001 → Nama PersistentVolume yang sedang kita buat.

  • capacity: → Spesifikasi ini akan menentukan kapasitas PV yang kita coba buat.

  • storage: 10Gi → Ini memberi tahu infrastruktur yang mendasari bahwa kami mencoba mengklaim ruang 10Gi di jalur yang ditentukan.

  • ReadWriteOnce → Ini memberi tahu hak akses volume yang kita buat.

  • path: "/tmp/data01" → Definisi ini memberi tahu mesin bahwa kami mencoba membuat volume di bawah jalur ini pada infrastruktur yang mendasarinya.

Membuat PV

$ kubectl create –f local-01.yaml
persistentvolume "pv0001" created

Memeriksa PV

$ kubectl get pv
NAME        CAPACITY      ACCESSMODES       STATUS       CLAIM      REASON     AGE
pv0001        10Gi            RWO         Available                            14s

Menjelaskan PV

$ kubectl describe pv pv0001

Membuat Klaim Volume Persisten

kind: PersistentVolumeClaim --------------> 1
apiVersion: v1
metadata:
   name: myclaim-1 --------------------> 2
spec:
   accessModes:
      - ReadWriteOnce ------------------------> 3
   resources:
      requests:
         storage: 3Gi ---------------------> 4

Dalam kode di atas, kami telah mendefinisikan -

  • kind: PersistentVolumeClaim → Ini menginstruksikan infrastruktur yang mendasari bahwa kami mencoba untuk mengklaim jumlah ruang tertentu.

  • name: myclaim-1 → Nama klaim yang kami coba buat.

  • ReadWriteOnce → Ini menentukan mode klaim yang kami coba buat.

  • storage: 3Gi → Ini akan memberi tahu kubernetes tentang jumlah ruang yang ingin kami klaim.

Membuat PVC

$ kubectl create –f myclaim-1
persistentvolumeclaim "myclaim-1" created

Mendapatkan Detail Tentang PVC

$ kubectl get pvc
NAME        STATUS   VOLUME   CAPACITY   ACCESSMODES   AGE
myclaim-1   Bound    pv0001     10Gi         RWO       7s

Jelaskan PVC

$ kubectl describe pv pv0001

Menggunakan PV dan PVC dengan POD

kind: Pod
apiVersion: v1
metadata:
   name: mypod
   labels:
      name: frontendhttp
spec:
   containers:
   - name: myfrontend
      image: nginx
      ports:
      - containerPort: 80
         name: "http-server"
      volumeMounts: ----------------------------> 1
      - mountPath: "/usr/share/tomcat/html"
         name: mypd
   volumes: -----------------------> 2
      - name: mypd
         persistentVolumeClaim: ------------------------->3
         claimName: myclaim-1

Dalam kode di atas, kami telah mendefinisikan -

  • volumeMounts: → Ini adalah jalur dalam wadah tempat pemasangan akan dilakukan.

  • Volume: → Definisi ini mendefinisikan definisi volume yang akan kami klaim.

  • persistentVolumeClaim: → Di bawah ini, kami mendefinisikan nama volume yang akan kami gunakan di pod yang ditentukan.