2024. 6. 25. 00:48ใComputerScience/DockerKubernetes
Chap19. Controllers
- ์ฟ ๋ฒ๋คํฐ์ค๋ ์ฌ๋ฌ SW๋ค์ ์งํฉ์ฒด
* Controllers
- take care of routine tasks to ensure the desired state (์ํ์ผ) of the cluster matches the observed state (ํ์ํ)
- Each controller is responsible for a particular resource in the Kubernetes
- ์ฌ๋์ด ๊ฐ์
ํ๋ ์ผ์ด ์ค์ด๋ฆ - ์ง์ ์์ผ๋ก ์
๋ ฅํ์ง ์์๋, ์๋ง์ ์ฟ ๋ฒ๋คํฐ์ค๋ฅผ ๊ตฌ์ฑํ๋ SW๋ค์ด ๊ฐ๋ฐ์๊ฐ ์๊ตฌํ๋ ํ๊ฒฝ(desired state)์ observed state๋ก ์ต๋ํ ์ ๊ณตํด์ผ ํจ / ๊ฐ๋ฐ์๋ ์ฟ ๋ฒ๋คํฐ์ค์๊ฒ ๋ถํํจ
* Label – key-value pair – pod๊ณผ ๊ฐ์ objects์ attached
- ๋์ปค์์๋ ๋ด ์ปดํจํฐ๋ฅผ ๊ฐ์ ํจ, ์ฟ ๋ฒ๋คํฐ์ค์์๋ ์ด๋ ์ปดํจํฐ์์ ์ด๋ป๊ฒ ๋์ํ ์ง ์ ์ ์dma
- desired state๋ฅผ ์๊ตฌํ ๋ฟ์ด์ง, ํด๋ฌ์คํฐ ์ ๋
ธ๋๋ค ์ค ์ด๋์ ๋์ํ ์ง ์ ์ ์๋ค. IP Address ๋์ ๋ผ๋ฒจ์ ์ฌ์ฉ
- ๋ผ๋ฒจ๋ก ๋ช
๋ น์ด๋ ๋ถํ์ด ์ ์ฉ๋๊ธธ ๋ฐ๋ผ๋ pod๋ค์ ์งํฉ์ ์๋ฏธ (๊ทธ๋ฃจํ์ ๊ธฐ๋ฅ)
* Kubernetes pods are mortal - pod๋ ์ค๊ฐ์ค๊ฐ ์ฃฝ์ ์ ์๋ค / ์๋ช ์ด ์๋ค
-> pod์ ์๋กญ๊ฒ ๋์์ desired state๋ฅผ ์ ์งํจ – ๋ฐ๋ผ์ IP address๋ ์ธ์ ๊ฐ๋ ๋ฐ๋ ์ ๋ณด / ์ฃฝ๊ณ ์๋ก์ด ์ ๊ฐ ๋ง๋ค์ด์ง๋ฉด IP๊ฐ ๋ฐ๋
- ์ฟ ๋ฒ๋คํฐ์ค๋ ํ๋ค์ด ๋ํํ ๋, ๊ฐ๋ณ pod์ ์ ๋ณด์ธ IP address๋ฅผ ์ฌ์ฉํ์ง ์์ - ๋ผ๋ฒจ๋ก ์ ๊ทผํจ, ์ง์ ์ ๊ทผํ์ง ์๋๋ก, ์ค๊ฐ์ ๋์
- IP๋ฅผ ์๋ค? ๋๊ฐ ๋ช ๊ฐ ์๋์ง ๋นคํ ์๋ค - ์ด๋ฐ ๊ฒฐํฉ์ฑ ์ง์
- the set of pods running in one moment in time could be different from the set of Pods running that application a moment later
+ ์ด๊ฑธ ์ด์ํ๋ ๊ฑด ์ฟ ๋ฒ๋คํฐ์ค๊ฐ ์์์ ํ ๊ฒ์ด๋ค / ์๋น์ค(node port) ์ด๋ฐ ์ ๋ค์ด ๋ฐ๊นฅ์ ๋ถ์ (ํธ๋ํฝ์ ๋ฐ์)
- ์ค๊ฐ์ ์๋ ์๋น์ค๊ฐ ๋ด ๋ค์ 3๊ฐ์ ํ์ด ์๊ตฌ๋ -> ์ฌ๋ ์ ํํ
์ผ์ ๋ ์ค์ผ์ง (๋ก๋๋ฐธ๋ฐ์ฑ)
- ๋ฐ๊นฅ์์ ์์ ip๋ฅผ ๋ณผ ํ์ X / ์๋น์ค๊น์ง๋ง ์ค๋ฉด ๋ค๋ก ์์์ ๋ณด๋ + ์๋น์ค๋ผ๋ ์ ๋ง์ ๋ ๋ค์ ํ๋ค์ ๋ฐ๋ผ๋ณผ ๋ label (app:myapp)์ผ๋ก ์ฐพ์์, ์ ์ํ๋ฉด ๋๋ค / ๋ค์ ์๋ ์ ๋ค์ IP Address๋ฅผ ์ ํ์๊ฐ ์๋ค -> ๋ผ๋ฒจ์ ์
* ReplicaSet – to maintain a stable set of replica Pods running at any given time
- To guarantee the availability of a specified number of identical Pods
- ๋์ปค์์๋ replicas ๋ช
๋ น์ผ๋ก ๊ฐ์ ์ง์ / ์ฟ ๋ฒ๋คํฐ์ค๋ replica set controller์๊ฒ ๋ด๊ฐ ์ํ๋ ์ํ๋ฅผ ์ ๋ฌํ๋ฉด,
์ํ๋ ๊ฐ์๋งํผ ์์ ์ ์ผ๋ก ์ํ - Replica set ์๋ SW
- A ReplicaSet creates & delete Pods as needed to reach the desired state
- ์ฐ๋ฆฌ๊ฐ replica set controller์๊ฒ ์ค ๋ 3๊ฐ์ง ์ ๋ณด๋ฅผ ์ค๋ค
1) ์ด๋ฐ ํ์ด์ผ (๊ธฐ์กด ์ํ์ผ = pod template)
2) number of replica - ์ด๊ฑธ ๋ช ๊ฐ ์คํํด์ฃผ์ธ์
3) selector - ๋ผ๋ฒจ์ ์ ๋ฌ + IP Address ๋์ ์ ๋ ํฐ๋ก ์๋ณ
+ Set-based Requirement – filtering keys according to a set of values
ex) environment in (Production, qa) / tier notin (frontend, backend) – in, not in, exist ๋ฑ
ex) kubectl get pods -l environment=production, tier=frontend // -l ๋ผ๋ฒจ์ ๋ํ ์กฐ๊ฑด์ ์๋ฏธํจ
* ReplicaSet์ class์ (kind๊ฐ ํด๋์ค๋ฅผ ์๋ฏธํจ)
- ์ฆ, ReplicaSet ๊ฐ์ฒด๋ฅผ ํ๋ ๋ง๋ค์ด์ ๋์ฐ๋ ๊ฒ๊ณผ ๋์ผํ ์๋ฏธ
- ์ด๊ฒ simple-replicaset.yaml ์ํ์ผ์ ์๋ฏธ
-> ๋ผ๋ฒจ์ my-little-pod์ผ๋ก ์ด๋ก์์ 3๊ฐ ๋์๋ฌ๋ผ๊ณ rs์๊ฒ ๋ถํํ๋ ๊ฒ
+ IP address๋ ๋ฌด์ฉ์ง๋ฌผ / label์ ์จ์ผํ๋ค.
* Service Distribution in ReplicaSet (Rolling)
- ๊ตฌ๋ฅด๋ ๊ฒ์ฒ๋ผ ์๋น์ค๊ฐ ํ๋ํ๋ ์ฒ์ฒํ ๋ฐ๊พธ๋ ๊ฒ
- 3๊ฐ์ pod์ update ํ๋ ค๋ฉด, ํ๋ํ๋์ฉ ๋๊ณ , ์๋กญ๊ฒ ์ฐ๊ฒฐํจ -> rolling update
- ํ๋์ฉ ๋ฐ๊พธ๋ฉด์ ์ง๋๊ฐ ๋๊ฐ / ๋กค๋ฐฑ์ ํ๋์ฉ ๋ค๋ก๊ฐ๋ ๊ฒ (์๋ณต)
- ํ์์ ํ๋ ๋ง๋ค๊ณ , ๋
น์์ ์ง์ด๋ค
* Apply my-replicaset
- kubectl apply -f simple-replicaset.yaml // ํด๋น ๋๋ ํ ๋ฆฌ์ ํ์ผ์ ํ์ฉํ์ฌ
Chap20. Kubernetes Objects & kubecctl Commands
- ํด๋์ค๋ก๋ถํฐ ๊ฐ์ฒด๋ฅผ ๋ง๋๋ ๊ฒ๊ณผ ์ ์ฌํ ๋์
- CRUD์ ๋์์ด ๋ฆฌ์์ค(๊ฐ์ฒด) / restful interface๋ฅผ ์ฌ์ฉํ์ฌ ๋ฆฌ์์ค๋ฅผ ์์ฑํ๊ณ ์
๋ฐ์ดํธ, ์ญ์ ํ๋ ์ฉ๋๋ก ์ฌ์ฉํจ
- API์ URL์ด ์ด๋ค ๋ฆฌ์์ค, ์ด๋ค ๊ฐ์ฒด๋ฅผ ์์ฑํ ๊ฒ์ธ์ง๋ฅผ ์๋ฏธํจ
+ ๋์ปค์ ๊ฐ๋ฐ ํ๊ฒฝ์ ๋ ์ค์ค๋ก -> API ํธ์ถ์ด ํฐ ์๋ฏธ ์์์
- ์ฟ ๋ฒ๋คํฐ์ค๋ ์ํ์ผor ์์ผ๋ก ํ๋ ๊ฒ์ restfulAPI๋ฅผ ์ ์ํ์ฌ ํธ์ถํจ
- ์ํ์ผ ์๋ kind๊ฐ ๋ฆฌ์์คํ์
์ ์๋ฏธ
- class๋ก๋ถํฐ ์ธ์คํด์ค๊ฐ ๋ง๋ค์ด์ง๋ค๋ ๊ฒ์ด ๊ฐ์ฒด์งํฅ์ ์ปจ์
๊ณผ ๋์ผํ๋ค
- A resource is an object with a type, associated data, relationships to other resources, and a set of methods
- it it similar to an object instance in an object-oriented programming language, with the important difference that only a few standard methods are defined for the resources (get post put and delete) while object instance๋ ๋ง์
* Record of Intent – ์ฟ ๋ฒ๋คํฐ์ค์๊ฒ your cluster’s desired state๋ฅผ ์ ๋ฌ
- All objects have common metadata – ์ํ์ผ์ ์๋ฏธ / ์ด์ํ๋ ์
์ฅ์์๋ intent ๋ผ๋ ๋ง์ ๋ง์ด ํ๋ค
- ๋ค ์๋ํ๋ฅผ ํ๋ ๊ฒ + ๋ณธ์ธ์ ์์ฌ(desired state)๋ง ๋ฐํ๋ ๊ฒ
+ policy = ์กฐ๊ฑด๋ฌธ์ ์ฃผ๋ ๊ฒ / CLI๋ก ๋ณด๋ด์ผ ํ ๋ช
๋ น์ API๋ก ํธ์ถํ๋ ๊ฒ
ex) CPU ๋ณด๋๊น ๊ฐ๋น๊ฐ๋น, pod์ ๋ ๋์์ผ๊ฒ ์ด ๋ฑ ์์ผ๋ก ํ๋ ์ปค๋งจ๋๋ผ์ธ๋ค์ API๋ฅผ ์ฌ์ฉํ์ฌ ์๋ํ ๊ฐ๋ฅ
- ์ด๋ฌํ API์ ๋ํด Official Kubernetes Client Libraries๊ฐ ์ธ์ด๋ณ๋ก ์ ๊ณต๋จ
- ์ํ์ผ๋ก spec์ ๋ช
์ํ๋ค – ์ด๊ฒ ์ฐ๋ฆฌ์ intent (desired state)
- ์ฟ ๋ฒ๋คํฐ์ค๊ฐ ์ด์ํ๋ ์ํฉ - status (object์ ์ค์ ์ํ) / ์๊ฐ์ ๋ฐ๋ผ ์ํ๊ฐ ๋ณํ๋ฉด, ์ฟ ๋ฒ๋คํฐ์ค๊ฐ ์
๋ฐ์ดํธ ํจ
* Deployment – is an object that can represent an application running on your cluster
- replica set์ ๊ธฐ๋ฅ์ , ์ฝ๋์์ผ๋ก๋ kind๋ง ReplicaSet -> Deployment๋ก ๋ฐ๋
- kubectl apply -f simple-deployment.yaml
+ 3๊ฐ์ pod ์ค ์ด๋ pod์ nginx๋ก ๊ฐ๊ณ ์๋๊ฑฐ์ง? log ๋ช
๋ น์ด๋ฅผ ํตํด ๋ณผ ์ ์๋ค
-> load balancing ์ผ๋ก 3๊ฐ์ pod๋ค์ด ๋ฒ๊ฐ์ ๊ฐ๋ฉด์ ๋ตํ๋ ๊ฒ์ ํ์ธํ ์ ์๋ค
+ Deployment is a higher-level concept that manages ReplicaSets and provides declarative updates to Pods along with a lot of other useful features. + Recommend using Deployments instead of directly using ReplicaSets // Deployment resource makes it easier for updating your pods to a newer version // automatically without any human interaction and increases the abstraction by one level.
Chap21. Dashboard
- ํ์ํ Pod์ ๋์ฐ๊ณ ๋ชจ๋ํฐ๋งํ ์ดํ, ์๋ก์ด pod ๋์ฐ๊ธฐ
+ ๋ฒ์ ์ ๊ทธ๋ ์ด๋, ๋ค์ด๊ทธ๋ ์ด๋ ๋ฑ ๋ค์ํ ์์ ์ ์๋ํํด์ฃผ๋ deployment controller (์ง๋ ์๊ฐ)
- ์ฟ ๋ฒ๋คํฐ์ค๋ ์น ์๋ฒ์ฒ๋ผ dashboard๋ฅผ ์ ๊ณตํ๋ค
– ์ฌ๋ด ํน์ ํ๋ฉด์ ๋ณด์ฌ์ฃผ๋ ๋์๋ณด๋๋ฅผ ๋ง์ด ๊ฐ๋ฐ, ์คํ์์ค
- minikube dashboard (--url)
- kubectl apply -f simple-deployment.yaml --record
+ Pod๋ค์ด ์์ฑ๋๊ณ , ์ฃฝ๋ ๊ณผ์ ์ ๋์ ์ผ๋ก UI๋ฅผ ํตํด ํ์ธํ ์ ์๋ค.
- pod์ ๊ฐ์ ๋ก delete ์ฃฝ์ด๋ฉด replicaset์ด ํ๋ ๋ ์ด๋ฆผ (desired state ์ ์งํ๋ ค๊ณ )
- Scale Up & Down, Deployment yaml ํ์ผ update๋ ๊ฐ๋ฅ
Chap22. Services
* Pods – mortal - ๋ค์ํ ์ด์ ๋ก pod์ ์ค๊ฐ์ ์ฃฝ์ ์ ์์ + ์ฃฝ์๋ค ์ด์๋๋ค๊ณ ๊ฐ์ ์ ๋ ์๋ (๋์ ์ด๋ค)
- ์ค์ผ์ผ๋ง ์
, ๋ค์ด๋ ๊ฐ๋ฅ + IP address๊ฐ ํฐ ์๋ฏธ ์์
* How do those frontends find out and keep track of which backends are in that set?
+ ์์์ ์๊ตฌ๋ฅผ ๋ฐ์์ฃผ๋ pod๋ค์ด ํ๋ก ํธ์๋ / ๋ค์์ ์์
์ ํด์ฃผ๋ backend pods / ๋ต: ๋ผ๋ฒจ๊ณผ ์
๋ ํฐ
* Services – an abstraction which defines a logical set of Pods and a policy by which to access them
- ์๋น์ค๋ฅผ ์ ์ดํ๊ธฐ ์ํ ๋ชฉ์ ์ผ๋ก LabelSelector ์ฌ์ฉ – set of pods targeted by a Service is determined by LS
+ pod๋ค์ด IP address๋ฅผ ๊ฐ์ง๋ง, ์ด๊ฑธ ๊ฐ๊ณ ์์
ํ์ง๋ ์์ - Cluster ๋ฐ๊นฅ์ผ๋ก๋ ์๋ฌด ์๋ฏธ๊ฐ ์์
-> ์ธ๋ถ๋ก ๋คํธ์ํฌ์ ๊ตฌ๋ฉ์ ๋ซ์ผ๋ ค๊ณ ์๋น์ค ๋์
* Cluster IP Service – it is the default Kubernetes service – ์ต์ด์ ์๋น์ค
- it gives you a service inside your cluster that other apps inside your cluster can access
- ์ธ๋ถ ํต์ ์ด ํ์ ์๋ค -> only cluster IP๋ง ๊ฐ๊ณ ํจ / there is no external access.
* NodePort Service - ํด๋ฌ์คํฐ๋ฅผ ๊ตฌ์ฑํ๊ณ ์๋ ๋
ธ๋์ ๊ตฌ๋ฉ์ ๋ซ์ด์, ์ธ๋ถ์์ ์์ผ๋ก ํธ๋ํฝ์ด ๋ค์ด์ฌ ์ ์๋๋ก
- opens a specific port on all the Nodes and any traffic that is sent to this port is forwarded to the service.
* Load Balancer Service - ๋ณ๋์ ๋ถ๋ฆฌ๋ ๋ฌผ๋ฆฌ์ ์ธ ์ปดํจํฐ๊ฐ ์์ ๋ ์ฐ๋ ์กฐ๊ธ ๋ ๋๋ํ ๋คํธ์ํฌ ๊ธฐ๋ฅ์ด ์๋ค
- On GKE, this will spin up a Network Load Balancer that will give you a single IP address that will forward all traffic to your service (๊ตฌ๊ธ ์ฟ ๋ฒ๋คํฐ์ค ์์ง like Docker-Hub)
* Ingress – it is actually not a type of service
- it sits in front of multiple services and act as a “smart router” or entrypoint into your cluster
- ์์ ์๋ ์ ๋ค์ ๊ฐ๊ณ ์งํ๋๊ธฐ ๋๋ฌธ์ ํ์ผ์ด ๊ฐ๊ฒฐํจ
- ๋ฐ๋ผ์ ์์ two-replicas-with-label.yaml์ ๋จผ์ ์คํํ๊ณ , ์ด ์๋น์ค๋ฅผ ๋๋ฆฌ๋ ๊ฒ
- ๋ด๊ฐ selectํ ์ ๋ค์ app์ด eva์ธ ๊ฒ๋ค ์ค release๊ฐ west์ธ ์ ๋ค / ๊ทธ pod ๋ ๊ฐ๊ฐ node port ์๋น์ค์ ์ฐ๊ฒฐ๋จ
- NodePort: ์ธ๋ถ์ ๊ณต๊ฐ, ํต์ ํ ์ ์๋ port number 80์ ์ด์ด์ค๋ค.
- kubectl get pod -l app=eva -l release=west - ์ผ์ชฝ์ pod 2๊ฐ
- kubectl get pod -l app=eva -l release=east - ์ค๋ฅธ์ชฝ์ pod 2๊ฐ
* kubectl cluster-info -> ์ฌ๊ธฐ์ ์์๋ธ ์ฟ ๋ฒ๋คํฐ์ค ์๋น์ค์ IP๊ฐ curl ๋ช
๋ น์ด์ ๋๋ฉ์ธ(masterIP) ์๋ฆฌ๋ก ๋ค์ด๊ฐ
- curl http://192.168.64.2:30658 // ๋
ธ๋ํฌํธ๊ฐ port 80์ 32530์ mappingํ์ฌ ์ด์ด๋
+ curl http://eva/ // ์ดํ๋ฆฌ์ผ์ด์
์ ์ด๋ฆ, ๋ผ๋ฒจ๋ก๋ ์ ๊ทผ์ด ๊ฐ๋ฅํ๋ค!
+ Cluser IP – Cluster IP isn’t accessible from outside of the Kubernetes cluster. This is an internal IP only meaning that other pods can use a Services Cluster IP to communicate between them but we can’t just put this IP address in our web browser and expect to get connected to the service in our Kubernetes cluster.
+ NodePort – A NodePort exposes a service on each node’s IP address on a specific port.
- NodePort doesn’t replace ClusterIP however, all it does is direct traffic to the ClusterIP from Outside the cluster.
- NodePort must be within the port range 30000-32767
Chap23. Images and Registries
- ์ฟ ๋ฒ๋คํฐ์ค ์ด๋ฏธ์ง๋ ๋์ปค์ ๋์ผํ ์ด๋ฏธ์ง - ์ด๋ฅผ ๋ฐํ์ผ๋ก pod์ ์คํํ๋ค
- you need to push it to a registry before referring to it in a Kubernetes pod
+ The default pull policy is IfNotPresent which causes the kublet to skip pulling an image if it already exists
* ImagePullPolicy
1) IfNotPresent – the image is pulled only if it is not already present locally - ๋ณธ์ธ์ ๋ก์ปฌ์ ์๋ค๋ฉด ๊ฐ์ ธ์ค๋ ์ ์ฑ
2) Always – the image is pulled every time the pod is started - ๋ณธ์ธ์ ๋ก์ปฌ์ ์๋ ์๋ ๊ฐ์ ธ์ค๋ ๊ฒ
3) Never – the image is assumed to exist locally – No attempt is made to pull the image
* Why You Should Avoid :latest tag - immutable vs muttable
- ๋ฒ์ ์ด ๊ณ ์ ๋์๋ค๋ฉด ์ข๊ฒ ๋ค (immutable) - ํ๋์ ๋ฒ์ ์ด ๋ช
์์ ์ผ๋ก ์ด์ / latest๋ผ๋ฉด 1๊ณผ 2๊ฐ ํผ์ฉ๋ ์ฐ๋ ค์
-> ๋ฒ์ ํธ๋ํน์ ์๋ฌ์ฌํญ์ด ์์ผ๋, ์ ํํ ๋ฒ์ ์ ๋ช
์ํ์ (latest ๋ง๊ณ )
* ์์ฉ ์๋น์ค์ ์ฌ์ฉ๊ฐ๋ฅํ registry – public cloud provider๋ค์ด ์ ๊ณตํ๋ ์ฟ ๋ฒ๋คํฐ์ค registry๋ค
- ์๋ง์กด์ ECR – Elastic Container Registry / EKS - ์ฟ ๋ฒ๋คํฐ์ค ์๋น์ค
- MS Azure Container Registry / IBM Cloud Container Registry / Google Container Registry – gcr ์ํ๋ค ๋ง์
Chap24. Scale and Rolling Updates
- pod์ ์๋ฅผ ๋๋ฆฌ๊ณ , ์ค์ด๋ Scale / ๋ฒ์ ์
๋ฐ์ดํธ์ ๊ด๋ จ๋ Rolling / ์ด๋ก ์ ๋ณต์กํ์ง๋ง, ๋ช
๋ น์ ๋งค์ฐ ๊ฐ๋จ
* Scaling – ํธ๋ํฝ์ด ์ฆ๊ฐํ๋ฉด, deployment์ replicas ์๋ฅผ ๋ฐ๊พผ๋ค
- ํ๋์ pod์ผ๋ก ๊ตฌ์ฑ๋ ์๋น์ค A์ 3๊ฐ์ Pod๋ฅผ ์ถ๊ฐํ์ฌ scaling up + ๋
ธ๋๋ 2๊ฐ ๋ ์ถ๊ฐ๋ ์ํฉ
- ์ญ์ผ๋ก ์งํ๋๋ ์ค๋ฅธ์ชฝ์์ ์ผ์ชฝ์ด scaling down (pod์ ์๋ฅผ ์ค์ด๋ ๊ฒ)
* Rolling Updates – deployments’ update to take place zero downtime by incrementally updating pods instances with new ones –> updates can be reverted to previous version – pod์ ์๊ฐ ์๋๋ผ ์ฑ์ง(๋ฒ์ )์ด ๋ณํ๋ ๊ฒ!
- ๋ฒ์ ์ด ๋ฐ๋๋ ๊ฒ์ด ๋ฌ๋ผ์ง (์ด๋ก์ -> ๋ณด๋ผ์์ผ๋ก ํ๋ํ๋ ๊ต์ฒด)
- ์ด๋ก ๋ฒ์ ์ผ๋ก ๋์๊ฐ๋ 4๊ฐ์ pod์ ๋ณด๋ผ์ ๋ฒ์ ์ผ๋ก ๋ฐ๊พธ๊ณ ์ถ๋ค
- immutable (๋์ผํ ๋ฒ์ )์ ๋ํ ์ค๊ฐ ๊ณผ์ ์ด ์์ - final์์๋ ๋ชจ๋ ๋ณด๋ผ์์ผ๋ก ๋ณํํจ (smooth)
- ์ธ๋ถ IP๋ ๋ณํ X // ๋ด๋ถ IP๋ ๋ชจ๋ ๋ฐ๋!
* Scaling & Rolling Updates ์ค์ต
- kubectl scale deployments/Kubernetes-bootcamp --replicas=2 // scaling
- kubectl set image deployments/Kubernetes-bootcamp kubernetes-bootcamp=jocatalin/Kubernetes-bootcamp:v2
-> ๋ช
๋ น์ด ํ ์ค์ด์ง๋ง, ์ฟ ๋ฒ๋คํฐ์ค๊ฐ ๋ง์ ์ผ๋ค์ ํ๋ค – image์ ๋ฒ์ ์ ๊ตฌ๊ธ -> ์กฐ์บํ๋ฆฐ์ผ๋ก ๋ฐ๊พผ๋ค๋ ์๋ฏธ
- Rolling - ์๋ก์ด ์ด๋ฏธ์ง๋ฅผ ํ๋ ๋ง๋ฆ, ๊ธฐ์กด ์ด๋ฏธ์ง pod๋ฅผ ํ๋ ์ฃฝ์, ์ ์ด๋ฏธ์ง๋ฅผ ํ๋ ๋๋ฆฌ๊ณ ,
๊ธฐ์กด pod ํ๋ ๋ ์ฃฝ์ฌ์ update๋ฅผ ๋๋ธ๋ค! curl๋ก ๋ถ์ด๋ณด๋ฉด, version์ด 1์์ 2๋ก ๋ฐ๋ ๊ฒ์ ์ ์ ์์
- kubectl rollout history deployment.apps/kubernetes-bootcamp : revision์ ๋ํ ์ด๋ ฅ(๋ก๊ทธ ์ ๋ณด)์ ๋ณผ ์ ์์
- kubectl rollout undo deployment.apps/kubernetes-bootcamp : ์์ ํ๋ rollout ์์
์ ์ทจ์์ํจ๋ค roll-back
- kubectl rollout undo deployment.apps/kubernetes-bootcamp --to-revision=1 // ํน์ ๋จ๊ณ๋ก ๋์๊ฐ๊ณ ์ถ์ผ๋ฉด ๋ช
์
Chap25. Stateless and Stateful Applications
- ์ง๊ธ๊น์ง ์ฐ๋ฆฌ๊ฐ ํ ๊ฑด stateless – ex) ๊ฐ๋จํ ์น์๋ฒ request & response
- stateful - ๋ฉ๋ชจ๋ฆฌ๊ฐ ์์ด์, ์ ๋ณด๊ฐ ์ ์ฅ๋์ด์ผ ํจ -> ๋ฉ๋ชจ๋ฆฌ๊ฐ ์๋ ๊ธฐ์ค์ผ๋ก ํ๋ ์๋น์ค ์๋ฏธ
* Stateless – doesn’t save client data generated in on session for use in the next session with that client
- there is no memory of the past - ์๋ฒ๊ฐ ๊ธฐ์กด ๊ธฐ๋ก์ ๋ฐํ์ผ๋ก ํ๋จ X / ํ์ฌ ์์ ์ ์์ฒญ๋ง์ผ๋ก ํ๋จํ๋ ๊ฒ
* Stateful – saves client data from the activities of one session for use in the next session
- ๊ณผ๊ฑฐ์ ์ผ, ๋ฐ์ดํฐ ์ ์ฅ / ๋ณผ๋ฅจ์ด๋ ์คํ ๋ฆฌ์ง ๋ฑ ๋ฉ๋ชจ๋ฆฌ / ๊ณผ๊ฑฐ ํธ๋์ญ์
์ ์ ๋ณด๊ฐ ๋จ์, ํ์ฌ ํธ๋์ญ์
์ ์ํฅ O
+ stateless - rolling์ ๊ฐ์ , ์ด๋ฏธ์ง update๊ฐ ์์ ๋ก์ / ๊ณผ๊ฑฐ ๋ฐ์ดํฐ๊ฐ ์์ผ๋, ๋ฒ์ ๋ณ๊ฒฝ์ ์ด๋ ค์์ด ์์
- ๊ณผ๊ฑฐ ์ ๋ณด์ ์๋ก์ด ์ ๋ณด๊ฐ ๋
์์ ์ผ๋ก ์ด์ ๊ฐ๋ฅ -> ์ง๊ธ ์ํ์ ์ํด ๊ฒฐ์ ์ด ๋ด๋ ค์ง๋ค.
- ๊ธฐ์กด deployment๋ฅผ new๋ก ๋ฎ์ด๋ฒ๋ฆฌ๋ ๊ฒ ex) nginx 1.14.2 -> 1.16.1 (new version)
- kubectl apply -f https://k8s.io/examples/application/development-update.yaml // ์ ๋ฒ์ ์ผ๋ก ๋ฎ์ธ๋ค
- kubectl apply -f https://k8s.io/examples/application/development-scale.yaml // replica๋ง 2->4 ๋ฐ๋
Chap26. Storage - ๋์ปค์ ๋น์ทํ์ง๋ง, k8s ๋ ๋ค์ํ ๋ณผ๋ฅจ๋ค์ด ์๋ค.
(1) ์ปจํ
์ด๋๋ ๋น์ ์์ ์ผ๋ก ์ฃฝ์๋ค ์ด์๋ค -> ๋ฐ์ดํฐ๋ ์ด์ ๋ถ๋ฆฌ๋๋๋ก – Data persistency
(2) ๊ฐ๋ณ ์ปจํ
์ด๋๋ค์ด file ํํ์ ์ ๋ณด๋ฅผ ๊ณต์ ํจ -> ์ด๋ฅผ ์ํ ์คํ ๋ฆฌ์ง – Shared resources
* Volume -is just a directory, possibly with some data in it, which is accessible to the containers in a pod.
- volume type - ๋ฉ๋ชจ๋ฆฌ, ํ์ผ ๋์คํฌ์ธ์ง ๋ ๊ตฌ์ฒด์ ์ผ๋ก๋ HDD, SSD ๋ฑ // ์ฟ ๋ฒ๋คํฐ์ค์ ์์ญ์ด๋ผ๊ธฐ์๋ ์ณ์ง ์์
- ๋์ปค ์ปจํ
์ด๋ ์์ ์์ ๊ณต๊ฐ : Asset(emptyDir) // host node์ ํน์ ๋๋ ํ ๋ฆฌ๋ฅผ binding : host path (Cache)
+ ์ํํ ์กฐ๊ฑด - ์์ ๋ฆฌํ์คํธ๋ฅผ ์ฒ๋ฆฌํ๋๋ฐ, ๊ฑ๊ฐ ์ฃฝ์ด๋ฒ๋ฆฌ๋ฉด? stateful?
-> ๋ฐ๋์ ๊ฑ ๋ฐ๊นฅ์ ์ ์ฅ์ด ๋์ด์ผ ํจ - ์ด๊ฑด ์ปจํ
์ด๋์ ์์ญ์ ๋ฒ์ด๋๋ ๊ฒ
+ ์ฟ ๋ฒ๋คํฐ์ค์ ์คํ ๋ฆฌ์ง๋ ํ๋์ - persistent volume - ๋ณผ๋ฅจ์ด ํญ์ ์กด์ฌํ๋ค.
* emptyDir – active as long as the Pod is running on that node (๋์ปค์์์ volumes – ๋์ปค ๋ด๋ถ์ ๊ณต๊ฐ)
* hostPath – mounts a file or directory from the host node’s filesystem into your pod (๋์ปค์์์ bind - ๋ง์ดํ
)
* nfs – network file system - ์คํ ๋ฆฌ์ง๋ฅผ ๋ณ๋๋ก ๊ตฌ์ถํ ๋ค์, ๋ฌผ๋ฆฌ์ ์ผ๋ก ๋จ์ด์ง ์ ๋ค์ ๋
ผ๋ฆฌ์ ์ผ๋ก ์ฐ๊ฒฐํด์ ์ฌ์ฉํจ
* PersistentVolumeClaim & PersistentVolume – a piece of storage in a Kubernetes cluster.
+ ์ ๋๋ก ๋ ์๋น์ค๋ฅผ ํ๋ฉด์, ์ด์ ๊ณ ๊ฐ ๊ธฐ์ตํ๊ณ , ํ์ฌ์๋น์ค ํ๋ ค๋ฉด statefulํ๊ณ ์ ํ๋ state๋ ๋ค์ ์์ด์ผ ํ๋ค.
- ๋์ปค๋ ์ฟ ๋ฒ๋คํฐ์ค์ ์์ญ์ด ์๋, ์ 3์ ๊ณต๊ฐ์ ์กด์ฌ -> public cloud ์ ๋ฌธํ๋ ์คํ ๋ฆฌ์ง ๊ธฐ์ (๊ตฌ๊ธ, ์๋ง์กด, MS)
- DB ๊นจ์ง๋ฉด ์ฅ๋ ์๋, 2์ค 3์ค์ผ๋ก ๋ถ๋ฆฌํ๋ ๊ธฐ์ -> ์ฝ์ง ์์ or ๋ณธ์ธ์ ์ ์ฉ ํ์ผ ์๋ฒ๋ฅผ ์ฐ๊ฒฐํ๋ ๊ธฐ์ (nfs)
* PersistentVolumeClaim & PersistentVolume – PV & PVC
1) NFS - network file system
: F ๋๋ ํ ๋ฆฌ ๊ฐ์๊ฒ ์๊น - ๋ง์น ๋ด ๋ฌผ๋ฆฌ์ ์ธ ๋์คํฌ๊ฐ์ง๋ง, ์ค์ ๋ก๋ ๋คํธ์ํฌ๋ฅผ ํตํด read write ํ๋ ๊ฒ
- like Remote Procedure Call (RPC)
- Cluster Admin์ด NFS์ ๊ตฌ์ถํจ
(2) ๋ฌผ๋ฆฌ์ ์ธ node or cloud storage๋ฅผ ์ธ ์ ์๋ ํํ๋ก, ์ฟ ๋ฒ๋คํฐ์ค ์์ผ๋ก ๋์ด๋ค์ธ๋ค - admin(์ด์ํ)์ด ์ฟ ๋ฒ๋คํฐ์ค์ ์ ์๋ ํ์์ผ๋ก PV๋ฅผ ๋ง๋ ๋ค.
(3) User๊ฐ PVC๋ฅผ create – ์๊ธฐ๊ฐ ๋ง๋ค๊ณ ์ถ์๊ฑฐ ์ด์ผ๊ธฐํ๋ฉด ๋จ
(4) ์ฟ ๋ฒ๋คํฐ์ค์ PV๋ฆฌ์คํธ ์ญ ๋ธ - ์ฟ ๋ฒ๋คํฐ์ค๊ฐ ์ ์ ํ PV๋ฅผ ์ฌ์ฉ์์๊ฒ bind ์์ผ์ค๋ค. (bind PVC to PV)
(5) pod์์ volume ํค์๋๋ก ์ ๊ทผํ์ฌ ์ฐ๋ฉด ๋จ – User creates a pod with a volume referencing the PVC
+ Wrap-up – 10๋ง ์ปจํ
์ด๋ ์๋ณ๋ก
- 10๋ง ๊ฐ์ Container๋ฅผ ์์ ์ ์ผ๋ก ์๋น์ค ํ ์ ์๋ ๊ธฐ๋ฐ์ ๋ง๋ค์ด์ผ ํ๋ค (Cloud Native ํ๊ฒฝ)
'ComputerScience > DockerKubernetes' ์นดํ ๊ณ ๋ฆฌ์ ๋ค๋ฅธ ๊ธ
[Kubernetes] ๊ธฐ๋ง๊ณ ์ฌ ์ ๋ฆฌ 1 (0) | 2024.06.25 |
---|---|
[Kubernetes] Desired State and Microservices Architecture (0) | 2024.06.09 |
[Kubernetes] ReplicaSet Controller (0) | 2024.05.27 |
[Kubernetes] Nodes and Pods with Minikube (0) | 2024.05.23 |
[Docker] Dockerfile WebSocket Client/Server Build (0) | 2024.05.16 |