๐Ÿฅ•
TIL
  • [TIL] Studying tech / computer science knowledge
  • KeyMap
  • ์•Œ๊ณ ๋ฆฌ์ฆ˜
    • ๋ณต์žก๋„ ๊ณ„์‚ฐ ( Computational Complexity )
    • DisjointSet-unionFind
    • Bellman-ford Algorithm
    • Dijkstra's Algorithm
    • DP ( Dynamic Programming , ๋™์  ๊ณ„ํš๋ฒ• )
    • ํ”Œ๋กœ์ด๋“œ-์›Œ์…œ ์•Œ๊ณ ๋ฆฌ์ฆ˜ (Floyd-Warshall algorithm)
    • Kruskal's Algorithm
    • ์ตœ์žฅ ์ฆ๊ฐ€ ์ˆ˜์—ด (Longes Increasing Subsequence)
    • Prim's Algorithm
    • ์ •๋ ฌ
    • ์‹œ๊ฐ„๋ณต์žก๋„ ์™€ ๊ณต๊ฐ„๋ณต์žก๋„ ( Time Complexity & Space Complexity )
    • Topological Sort (์œ„์ƒ ์ •๋ ฌ)
  • ์ฑ… ์ฝ๊ณ ๋‚œ ํ›„ ์š”์•ฝ
    • ํ”„๋กœ๊ทธ๋ž˜๋ฐ ๋Œ€ํšŒ์—์„œ ๋ฐฐ์šฐ๋Š” ์•Œ๊ณ ๋ฆฌ์ฆ˜ ๋ฌธ์ œํ•ด๊ฒฐ ์ „๋žต
    • cleancode
    • ๋„๋ฉ”์ธ ์ฃผ๋„ ์„ค๊ณ„๋กœ ์‹œ์ž‘ํ•˜๋Š” ๋งˆ์ดํฌ๋กœ์„œ๋น„์Šค ๊ฐœ๋ฐœ
    • ์˜ค๋ธŒ์ ํŠธ
  • CDC
    • debzium
    • kafka
  • ๊ฐœ๋ฐœ ์ƒ์‹
    • asciidoctor
    • ์ปดํŒŒ์ผ๋Ÿฌ
    • ELK ์Šคํƒ
    • ์—”๋””์•ˆ
    • git
    • Gitmoji
    • ํ…Œ์ŠคํŠธ ์ข…๋ฅ˜
    • ๋ผ์ด๋ธŒ๋Ÿฌ๋ฆฌ์™€ ํ”„๋ ˆ์ž„์›Œํฌ
    • ์ •๊ทœ ํ‘œํ˜„์‹
    • REST API
    • ๋™๊ธฐ์™€ ๋น„๋™๊ธฐ / Blocking๊ณผ NonBlocking
    • Transaction Script์™€ Domain Model
    • ๋””์ž์ธ ํŒจํ„ด
      • ํ–‰๋™ ํŒจํ„ด
      • ๊ฐ์ฒด ์ƒ์„ฑ ํŒจํ„ด
        • ์ถ”์ƒ ํŒฉํ† ๋ฆฌ ํŒจํ„ด
        • ๋นŒ๋” ํŒจํ„ด
        • ํŒฉํ† ๋ฆฌ ๋ฉ”์„œ๋“œ ํŒจํ„ด
        • [์ƒ์„ฑ ํŒจํ„ด] ํ”„๋กœํ†  ํƒ€์ž… (Prototype Parttern)
        • ์‹ฑ๊ธ€ํ†ค
      • ๊ตฌ์กฐ ํŒจํ„ด
        • ์–ด๋Œ‘ํ„ฐ ํŒจํ„ด
        • ๋ธŒ๋ฆฟ์ง€ ํŒจํ„ด
        • ์ปดํฌ์ง“(Composite) ํŒจํ„ด
        • ๋ฐ์ฝ”๋ ˆ์ดํ„ฐ
        • ํ”„๋ก์‹œ
    • refactoring
      • ์ค‘๋ณต ์ฝ”๋“œ
      • ์ „์—ญ ๋ฐ์ดํ„ฐ
      • ๊ธด ํ•จ์ˆ˜
      • ๊ธด ๋งค๊ฐœ๋ณ€์ˆ˜ ๋ชฉ๋ก
      • ๊ฐ€๋ณ€ ๋ฐ์ดํ„ฐ
      • ์ดํ•ดํ•˜๊ธฐ ํž˜๋“  ์ด๋ฆ„
  • ์ž๋ฃŒ๊ตฌ์กฐ
    • AVL Tree
    • Splay Tree
    • aaTree
    • array-list
    • ์ž๋ฃŒ๊ตฌ์กฐ ์‹œ๊ฐ„/๊ณต๊ฐ„ ๋ณต์žก๋„
    • ๊ทธ๋ž˜ํ”„
    • ํž™
    • Red Black Tree
    • stack-queue
    • ํŠธ๋ฆฌ ( Tree )
  • DevOps
    • MSA
    • Kubernetes
      • AccessingAPI
      • controller
      • dashboard
      • kubernetes
      • object
      • pod
      • service
      • volume
  • Java
    • ์–ด๋…ธํ…Œ์ด์…˜
    • ์ œ์–ด๋ฌธ
    • ๋ฐ์ดํ„ฐ ํƒ€์ž…
    • Enum
    • jvm
    • ์—ฐ์‚ฐ์ž
    • thread
    • Java8
      • CompletableFuture
      • Date/Time
      • ์–ด๋…ธํ…Œ์ด์…˜๊ณผ ๋ฉ”ํƒ€์ŠคํŽ˜์ด์Šค
      • ์ธํ„ฐํŽ˜์ด์Šค
      • ๋žŒ๋‹ค์‹
      • Optional
      • ์ŠคํŠธ๋ฆผ
  • JavaScript
    • moduleProject
    • webpack-babel
    • ์ฝ”์–ด ์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ
      • array
      • ํ•จ์ˆ˜ ๋ฐ”์ธ๋”ฉ
      • ๋ฐ์ฝ”๋ ˆ์ดํ„ฐ์™€ ํฌ์›Œ๋”ฉ
      • Class
      • ๋น„๊ต ์—ฐ์‚ฐ์ž
      • Date ๋‚ด์žฅ ๊ฐ์ฒด
      • destructuring-assignment
      • function
      • ํ•จ์ˆ˜์˜ prototype ํ”„๋กœํผํ‹ฐ
      • ๊ฐ€๋น„์ง€ ์ปฌ๋ ‰์…˜ ( Garbage Collection )
      • JSON (JavaScript Object Notation)
      • map-set
      • ๋‚ด์žฅ ํ”„๋กœํ† ํƒ€์ž…
      • new์—ฐ์‚ฐ์ž์™€ ์ƒ์„ฑ์ž ํ•จ์ˆ˜
      • ๊ฐ์ฒด
      • Object.keys, values, entries
      • ์˜ต์…”๋„ ์ฒด์ด๋‹ '?.'
      • ํ”„๋กœํผํ‹ฐ ํ”Œ๋ž˜๊ทธ
      • ํ”„๋กœํผํ‹ฐ ์ข…๋ฅ˜
      • ํ”„๋กœํ†  ํƒ€์ž…
      • ํ˜ธ์ถœ ์Šค์ผ€์ค„๋ง ( scheduling a call )
      • scope
      • this
      • type-conversions
      • type
      • ํ•จ์ˆ˜์˜ ์ž๋ฃŒํ˜•
      • var_let_const
  • Linux
    • ๊ธฐ๋ณธ ๋ช…๋ น์–ด
    • ํŒŒ์ผ ์ข…๋ฅ˜
    • ๋ฆฌ๋ˆ…์Šค
  • ๋„คํŠธ์›Œํฌ
    • ์‘์šฉ ๊ณ„์ธต ( Application Layer )
    • ์˜ค๋ฅ˜ ๊ฒ€์ถœ๊ณผ ์˜ค๋ฅ˜ ์ •์ •
    • Http
    • Http Header
    • ์ปดํ“จํ„ฐ ๋„คํŠธ์›Œํฌ๋ž€
    • ๋„คํŠธ์›Œํฌ ๊ณ„์ธต
    • ๋„คํŠธ์›Œํฌ ์ œ์–ด ์˜์—ญ
    • ์ „์†ก ๊ณ„์ธต ( Transport Layer )
  • PHP
    • Facade
    • composer
    • scopeResolutionOperator
    • Laravel
      • SocialProvider
      • architecture
      • blade
      • controller
      • db
      • dbArchitecture
      • debug
      • eloquent
      • email
      • event
      • exceptionHandling
      • middleware
      • model
      • modelFactory
      • pagingLoading
      • queryBuilder
      • route
      • scout
      • seeding
      • tntsearch
      • validate
      • view
  • React
    • Next.js
    • React ๋ž€?
  • Spring
    • Controller
    • ์š”์ฒญ์ด ๋“ค์–ด์™”์„๋•Œ ์Šคํ”„๋ง์ด ์ฒ˜๋ฆฌํ•˜๋Š” ๋ฐฉ๋ฒ• ( ๋‚ด๋ถ€๊ตฌ์กฐ )
    • ConfigurationProperties
    • Entity / DTO / VO
    • Maven
    • Repository์™€ DAO
    • ์Šคํ”„๋ง ๋นˆ
    • Spring Framework
    • MVC ํŒจํ„ด
    • ๋„๋ฉ”์ธ ์ž…๋ ฅ๊ฐ’ ๊ฒ€์ฆ
    • Spring Cloud
      • Spring Cloud
      • Eureka
    • Spring Data
      • JPA
      • JPA ์–ด๋…ธํ…Œ์ด์…˜
      • ์—”ํ‹ฐํ‹ฐ ๋น„๊ต
      • ๋ณตํ•ฉ ํ‚ค์™€ ์‹๋ณ„ ๊ด€๊ณ„ ๋งคํ•‘
      • JPA ์˜ˆ์™ธ์ฒ˜๋ฆฌ
      • ๊ฐ์ฒด์ง€ํ–ฅ ์ฟผ๋ฆฌ
      • EntityManagerFactory์™€ EntityManager
      • JPA ์ตœ์ ํ™”
      • ํ”„๋ก์‹œ์™€ ์—ฐ๊ด€๊ด€๊ณ„ ๋งตํ•‘
      • ์—ฐ๊ด€๊ด€๊ณ„
      • ์ƒ์†๊ด€๊ณ„ ๋งตํ•‘
      • ํŠธ๋žœ์žญ์…˜ ๋ฒ”์œ„์™€ ์˜์†์„ฑ ์ปจํ…์ŠคํŠธ
      • ๋ฐ์ดํ„ฐ ํƒ€์ž…
      • MySQL ์—ฐ๊ฒฐ
      • Pageable
    • Spring Project๋“ค๊ณผ library
      • Custom Serialize
      • Elasticsearch Index API
      • Spring HATEOAS
      • lombok (๋กฌ๋ณต)
      • Model Mapper
      • Object Mapper
      • Representation Model
      • Spring REST Docs
      • Spring Boot
    • Spring Security
      • Spring Security
      • Authentication
      • Authentication Filter
      • Authorization Filter
      • Filter Chain
      • SecurityContext
      • Spring OAuth2.0
    • Spring Test
      • AssertJ
      • Junit5
      • JunitParams
      • Mock Object
  • DataBase
    • ALIAS
    • CONCAT
    • CTE
    • Group By
    • HAVING
    • IFNULL
    • ์ธ๋ฑ์Šค
    • JOIN
    • ORDER BY
    • ROLLUP
    • SELECT
    • SELECT DISTINCT
    • SQL
    • WHERE
  • Web ์ƒ์‹
    • OAuth
    • WAS
    • HTTPํ†ต์‹  ๊ธฐ๋ฐ˜ ์ธ์ฆ
    • ๋ธŒ๋ผ์šฐ์ €
    • CSR ๊ณผ SSR
    • HTTPS
    • Web
Powered by GitBook
On this page
  • 1. ๋ช…๋ น์–ด
  • volume mount
  • Dynamic Provisioning
  1. DevOps
  2. Kubernetes

volume

PreviousserviceNextJava

Last updated 3 years ago

volume2

๋ฐ์ดํ„ฐ๋ฅผ ์•ˆ์ •์ ์œผ๋กœ ๊ด€๋ฆฌํ•˜๊ธฐ ์œ„ํ•ด ์‚ฌ์šฉ๋˜์–ด cluster์™€ ๋ถ„๋ฆฌ๋˜์–ด ์กด์žฌ

๊ด€๋ฆฌ์ž๊ฐ€ ์ €์žฅ์šฉ๋Ÿ‰/access mode๋ฅผ ์„ค์ •ํ•ด pv๋ฅผ ๋งŒ๋“ค๊ณ  ์‚ฌ์šฉ์ž๊ฐ€ pvc๋ฅผ ๋งŒ๋“ค๋ฉด k8s๊ฐ€ ์ ์ ˆํ•œ pv๋ฅผ ์—ฐ๊ฒฐํ•ด์ฃผ๋ฉฐ access mode์—๋Š” 3๊ฐ€์ง€๊ฐ€ ์กด์žฌํ•œ๋‹ค. ์ด๋Ÿฐ ์—ฐ๊ฒฐ๋ฐฉ์‹์€ volume์ด ํ•„์š”ํ• ๋•Œ๋งˆ๋‹ค pv๋ฅผ ๋งŒ๋“ค์–ด์ฃผ์–ด์•ผ ํ•˜๊ณ  ์ด๋ฅผ ์—ฐ๊ฒฐํ•˜๊ธฐ ์œ„ํ•ด storage/access mode๋ฅผ ๋งž์ถ”์ฃผ์–ด์•ผ ํ•˜๋Š”๋ฐ ์ด๋ฅผ ํ•ด๊ฒฐํ•˜๊ธฐ ์œ„ํ•ด dynamic provisioning์ด ์กด์žฌํ•œ๋‹ค.

1. ๋ช…๋ น์–ด

# namespace๋‚ด์˜ ๋ชจ๋“  objects๋“ค ์กฐํšŒ
kubectl get all -n storagesos-operator

# Force Deletion
kubectl delete persistentvolumeclaims pvc-fast1 --namespace=default --grace-period 0 --force
kubectl delete persistentvolume pvc-b53fd802-3919-4fb0-8c1f-02221a3e4bc0 --grace-period 0 --force

# StorageClass ํ™•์ธ
kubectl get storageclasses.storage.k8s.io

volume mount

1) emptyDir

์ปจํ…Œ์ด๋„ˆ๋“ค๋ผ๋ฆฌ ๋ฐ์ดํ„ฐ๋ฅผ ๊ณต์œ ํ•˜๊ธฐ ์œ„ํ•ด ๋ณผ๋ฅจ์„ ์‚ฌ์šฉํ•˜๋Š” ๊ฒƒ์œผ๋กœ ์ด ๋ณผ๋ฅจ์ด ์ฒ˜์Œ ์ƒ์„ฑ๋ ๋•Œ๋Š” ํ•ญ์ƒ ๋น„์–ด์žˆ๊ธฐ ๋•Œ๋ฌธ์— empty๋ผ ๋ถˆ๋ฆฌ๋Š” ๊ฒƒ

๋ณผ๋ฅจ์€ ํŒŒ๋“œ์•ˆ์— ์ƒ์„ฑ์ด ๋˜๋Š” ๊ฒƒ์ด๊ธฐ ๋•Œ๋ฌธ์— ํŒŒ๋“œ๊ฐ€ ์‚ญ์ œ๊ฐ€ ๋œ๋‹ค๋ฉด ๊ฐ™์ด ์‚ญ์ œ๊ฐ€ ๋˜๊ธฐ ๋•Œ๋ฌธ์— ์ผ์‹œ์ ์ธ ๋ฐ์ดํ„ฐ๋ฅผ ์ €์žฅํ• ๋•Œ ์ด์šฉํ•˜๋Š” ๊ฒƒ์ด ์ข‹๋‹ค.

apiVersion: v1
kind: Pod
metadata:
  name: pod-volume-1
spec:
  containers:
    - name: container1
      image: tmkube/init
      volumeMounts:
        - name: empty-dir
          mountPath: /mount1
    - name: container2
      image: tmkube/init
      volumeMounts:
        - name: empty-dir
          mountPath: /mount2
  volumes:
    - name: empty-dir
      emptyDir: {}

2) hostPath

ํŒŒ๋“œ๋“ค์ด ๋“ค์–ด์žˆ๋Š” ๋…ธ๋“œ์˜ path๋ฅผ ๋ณผ๋ฅจ์œผ๋กœ์จ ์‚ฌ์šฉํ•˜๋Š” ๊ฒฝ์šฐ๊ฐ€ hostPath์ด๋ฉฐ, ํŒŒ๋“œ๋“ค์ด ๋ณผ๋ฅจ์„ ๋งˆ์šดํŠธํ•˜๋Š” ๊ฒƒ์ด๊ธฐ ๋•Œ๋ฌธ์— ํŒŒ๋“œ๊ฐ€ ์ฃฝ์–ด๋„ ๋ณผ๋ฅจ์ด ์‚ญ์ œ๋˜์ง€๋Š” ์•Š๋Š”๋‹ค. ํ•˜์ง€๋งŒ ํŒŒ๋“œ๊ฐ€ ์ฃฝ๊ณ  ์žฌ์ƒ์„ฑ๋˜๋Š” ์ˆœ๊ฐ„์— ์ด์ „์— ์ƒ์„ฑ๋˜์—ˆ๋˜ ๋…ธ๋“œ์— ์ƒ์„ฑ๋˜๋ฆฌ๋ผ๋Š” ๋ณด์žฅ์ด ์—†๋Š”๋ฐ ์ด๋ ‡๊ฒŒ ๋‹ค๋ฅธ ๋…ธ๋“œ์— ํŒŒ๋“œ๊ฐ€ ์žฌ์ƒ์„ฑ๋˜๊ฒŒ ๋˜๋ฉด ์ด์ „์— ๋งˆ์šดํŠธํ–ˆ๋˜ ๋ณผ๋ฅจ์— ์ ‘๊ทผํ•  ์ˆ˜ ์—†๊ฒŒ ๋œ๋‹ค.

ํŒŒ๋“œ๊ฐ€ ์ƒ์„ฑ๋ ๋•Œ๋งˆ๋‹ค ๋…ธ๋“œ๋‚ด์— ๋ณผ๋ฅจ์„ ์ƒˆ๋กœ ๋งˆ์šดํŠธํ•ด์คŒ์œผ๋กœ์จ ํ•ด๊ฒฐํ•  ์ˆ˜ ์žˆ์ง€๋งŒ k8s๊ฐ€ ์ž๋™์ ์œผ๋กœ ์ง€์›ํ•ด์ฃผ๋Š” ๊ธฐ๋Šฅ์ด์•„๋‹ˆ๋ผ ์šด์˜์ž๊ฐ€ ๊ฐœ๋ณ„์ ์œผ๋กœ ์„ค์ •ํ•ด์ฃผ์–ด์•ผ ํ•˜๋Š” ๋ถ€๋ถ„์ด๋ผ ์‹ค์ˆ˜์˜ ์—ฌ์ง€๊ฐ€ ์กด์žฌํ•œ๋‹ค.

apiVersion: v1
kind: Pod
metadata:
  name: pod-volume-2
spec:
  cointainers:
    - name: cotainer
      image: tmkube/init
      volumeMounts:
        - name: host-path
          mountPath: /mount1
  volumes:
    - name: host-path
      host-path:
        path: /node-v
        type: Diretory

์ด๋•Œ host-path์˜ path๋Š” ํŒŒ๋“œ๊ฐ€ ์ƒ์„ฑ๋˜๊ธฐ ์ „์— ๋…ธ๋“œ์— ์ƒ์„ฑ์ด ๋˜์–ด์žˆ์–ด์•ผ ๋งˆ์šดํŠธ๊ฐ€ ๊ฐ€๋Šฅํ•˜๋‹ค.

Type

  • DirectoryOrCreate : ์‹ค์ œ ๊ฒฝ๋กœ๊ฐ€ ์—†๋‹ค๋ฉด ์ƒ์„ฑ

  • Directory : ์‹ค์ œ ๊ฒฝ๋กœ๊ฐ€ ์žˆ์–ด์•ผ์ง€ ๊ฐ€๋Šฅ

  • FileOrCreate : ์‹ค์ œ ๊ฒฝ๋กœ์— ํŒŒ์ผ์ด ์—†๋‹ค๋ฉด ์ƒ์„ฑ

  • File : ์‹ค์ œ ๊ฒฝ๋กœ์— ํŒŒ์ผ์ด ์žˆ์–ด์•ผ ๊ฐ€๋Šฅ

3) PVC / PV (Persistent Volume Claim)

ํ•˜๋“œ๊ฐ™์ด ๋ฐ์ดํ„ฐ๋ฅผ ์˜์†์„ฑ์„ ๊ฐ€์ง„ ์ƒํƒœ๋กœ ์‚ฌ์šฉํ•˜๊ณ  ์‹ถ์„๋•Œ ์‚ฌ์šฉํ•  ์ˆ˜์žˆ๋Š”๋ฐ PV๋Š” ์ธํ”„๋ผ๋ฅผ ๊ด€๋ฆฌํ•˜๋Š” Admin์ด ์„ค์ •ํ•˜๋ฉฐ, PVC๋Š” ์ด volume๋ฅผ ์‚ฌ์šฉํ•˜๊ธฐ ์œ„ํ•ด ์‚ฌ์šฉ๋˜๋Š” ๋ชฉ์ ์œผ๋กœ ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ๋‹ค.

#PV
apiVersion: v1
kind: PersistentVolume
metadata:
  name: pv-03
spec:
  capacity:
    storage: 2G
  accessModes:
  - ReadWriteOnce
  local:
    path: /node-v
  nodeAffinity:
    required:
      nodeSelectorTerms:
      - matchExpressions:
        - {key: kubernetes.io/hostname, operator: In, values: [k8s-node1]}
#PV
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
  name: pvc-01
spec:
  accessModes:
  - ReadWriteOnce
  resources:
    requests:
      storage: 1G
  storageClassName: ""
#Pod
apiVersion: v1
kind: Pod
metadata:
  name: pod-volume-3
spec:
  containers:
  - name: container
    image: kubetm/init
    volumeMounts:
    - name: pvc-pv
      mountPath: /mount3
  volumes:
  - name : pvc-pv
    persistentVolumeClaim:
      claimName: pvc-01

Pv - PVC label๋กœ ์—ฐ๊ฒฐ

#PV
apiVersion: v1
kind: PersistentVolume
metadata:
  name: pv-04
  labels:
    pv: pv-04
spec:
  capacity:
    storage: 2G
  accessModes:
  - ReadWriteOnce
  local:
    path: /node-v
  nodeAffinity:
    required:
      nodeSelectorTerms:
      - matchExpressions:
        - {key: kubernetes.io/hostname, operator: In, values: [k8s-node1]}
#PV
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
  name: pvc-04
spec:
  accessModes:
  - ReadWriteOnce
  resources:
    requests:
      storage: 2G
  storageClassName: ""
  selector:
    matchLabels:
      pv: pv-04

Dynamic Provisioning

1) Dynamic Provisioning

์œ„์—์„œ local PV๋ฅผ ์ด์šฉํ•ด PVC๋ฅผ ๋งŒ๋“ค๋•Œ ClassName์„ ""๋กœ ์ฃผ์—ˆ๋Š”๋ฐ ์ด์ฒ˜๋Ÿผ ""๋Š” local, ํŠน์ • solution/cloud๋ฅผ ์ด์šฉํ•œ PV๋ฅผ ์‚ฌ์šฉํ• ๋•Œ๋Š” ํ•ด๋‹น storageClass๋ฅผ ์ฃผ์–ด์ง€๋ฉด ํ•ด๋‹น volume์ด ๋™์ ์œผ๋กœ ๋งŒ๋“ค์–ด์ง€๋ฉฐ default Storage๋ฅผ ์ƒ์„ฑํ•ด๋‘์—ˆ๋‹ค๋ฉด className์„ ์•„๋ฌด๊ฒƒ๋„ ์ฃผ์–ด์ง€์ง€ ์•Š์œผ๋ฉด defalut class๋ฅผ ์ด์šฉํ•ด ์ƒ์„ฑ์ด๋œ๋‹ค.

# Storage class
apiVersion: storage.k8s.io/v1
kind: StorageClass
metadata:
  name: default
  annotations:
    # Default StorageClass๋กœ ์„ ํƒ 
    storageclass.kubernetes.io/is-default-class: "true" 
# ๋™์ ์œผ๋กœ PV์ƒ์„ฑ์‹œ PersistentVolumeReclaimPolicy ์„ ํƒ (Default:Delete)
reclaimPolicy: Retain, Delete, Recycle
provisioner: kubernetes.io/storageos
# provisioner ์ข…๋ฅ˜์— ๋”ฐ๋ผ parameters์˜ ํ•˜์œ„ ๋‚ด์šฉ ๋‹ค๋ฆ„ 
parameters:     
#PV
apiVersion: v1
kind: PersistentVolume
metadata:
  name: pv-hostpath1
spec:
  capacity:
    storage: 1G
  accessModes:
  - ReadWriteOnce
  hostPath:
    path: /mnt/hostpath
    type: DirectoryOrCreate
#PVC (local)
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
  name: pvc-hostpath1
spec:
  accessModes:
  - ReadWriteOnce
  resources:
    requests:
      storage: 1G
  storageClassName: ""
#PVC (storage Class)
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
  name: pvc-fast1
spec:
  accessModes:
  - ReadWriteOnce
  resources:
    requests:
      storage: 1G
  storageClassName: "fast"
#PVC (default)
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
  name: pvc-default1
spec:
  accessModes:
  - ReadWriteOnce
  resources:
    requests:
      storage: 2G

2) Status / ReclaimPolicy

Status

  1. available : ์ฒ˜์Œ pv๊ฐ€ ์ƒ์„ฑ๋˜์–ด์žˆ์„๋•Œ์˜ ์ƒํƒœ

  2. Bound : PVC์™€ ์—ฐ๊ฒฐ๋˜์–ด ์žˆ๋Š” ์ƒํƒœ๋กœ PV๋ฅผ ์ง์ ‘๋งŒ๋“œ๋Š” ๊ฒฝ์šฐ์—๋Š” volume์— ์‹ค์ œ ๋ฐ์ดํ„ฐ๊ฐ€ ๋งŒ๋“ค์–ด์ง„ ์ƒํƒœ๋Š” ์•„๋‹ˆ๊ณ  pod๊ฐ€ pvc๋ฅผ ์‚ฌ์šฉํ•ด์„œ ๊ณ ์ •์ด ๋ ๋•Œ ์‹ค์ œ ๋ฐ์ดํ„ฐ๊ฐ€ ๋งŒ๋“ค์–ด์ง„๋‹ค.

pod๋ฅผ ์‚ญ์ œํ•œ๋‹ค๊ณ  ํ•ด์„œ pvc๊ฐ€ ์‚ญ์ œ๋˜๋Š” ๊ฒƒ์ด ์•„๋‹ˆ๊ธฐ ๋•Œ๋ฌธ์— ์ƒํƒœ๊ฐ€ ๋ณ€ํ•˜์ง€ ์•Š๋Š”๋‹ค.

  1. Released : pvc๊ฐ€ ์‚ญ์ œ๋˜์–ด pv์™€ ์—ฐ๊ฒฐ์ด ๋Š์–ด์ง„ ์ƒํƒœ

  2. Failed : ์œ„ ์ƒํƒœ ์ „ํ™˜๊ฐ„ ๋ฌธ์ œ๊ฐ€ ๋ฐœ์ƒํ•œ ์ƒํƒœ

Reclaim Policy

  1. Retain : ์ด ์ •์ฑ…์ด default๋กœ pvc๊ฐ€ ์‚ญ์ œ๋˜์—ˆ์„๋•Œ pv๊ฐ€ released๋กœ ๋ณ€ํ™˜๋˜๋ฉฐ ์‹ค์ œ ๋ฐ์ดํ„ฐ๋Š” ์œ ์ง€ ๋˜์ง€๋งŒ ์ด pv๋ฅผ ๋‹ค๋ฅธ pvc์— ์—ฐ๊ฒฐํ•  ์ˆ˜ ์—†์–ด ์ˆ˜๋™์œผ๋กœ pv๋ฅผ ์‚ญ์ œํ•ด์ฃผ์–ด์•ผ ํ•œ๋‹ค.

  2. Delete : pvc๋ฅผ ์‚ญ์ œํ•˜๋ฉด ๊ฐ™์ด pv๊ฐ€ ์‚ญ์ œ๋˜์–ด, storageClass๋ฅผ ์‚ฌ์šฉ์‹œ default ๊ฐ’์ด๋‹ค.

  3. Recycle : ํ˜„์žฌ๋Š” deprecated๋œ ์ •์ฑ…์œผ๋กœ ๋ฐ์ดํ„ฐ๋Š” ์‚ญ์ œ๋˜์ง€๋งŒ pv๋Š” ์žฌ์‚ฌ์šฉ์ด ๊ฐ€๋Šฅํ•œ ์ •์ฑ…์ด๋‹ค.

#Recycle
apiVersion: v1
kind: PersistentVolume
metadata:
  name: pv-recycle1
spec:
  persistentVolumeReclaimPolicy: Recycle
  capacity:
    storage: 3G
  accessModes:
  - ReadWriteOnce
  hostPath:
    path: /tmp/recycle
    type: DirectoryOrCreate

Recycle ์ •์ฑ…์€ /tmp/๋กœ ์‹œ์ž‘ํ•˜๋Š” path์—์„œ๋งŒ ๊ฐ€๋Šฅํ•˜๋‹ค.


Reference

์‚ฌ์šฉ์ž๊ฐ€ pvc๋ฅผ ๋งŒ๋“ค๋ฉด ์•Œ์•„์„œ pv๋ฅผ ๋งŒ๋“ค์–ด์ฃผ๊ณ  volume์„ ์—ฐ๊ฒฐํ•ด์ฃผ๋Š” ๊ธฐ๋Šฅ์ด๋ฉฐ ๋ชจ๋“  pv์—๋Š” ๊ฐ๊ฐ์˜ ์ƒํƒœ๊ฐ€ ์กด์žฌํ•˜๊ณ  pv๋ฅผ ์‚ญ์ œํ• ๋•Œ ์ •์ฑ…์˜ ์š”์†Œ๋„ ์กด์žฌํ•œ๋‹ค.

dp
status-reclaimPolicy

์ธํ”„๋Ÿฐ-๊น€ํƒœ๋ฏผ๋‹˜ ๊ฐ•์˜
volume
dynamicProvisioning