kkumtree

Kubernetes Service(3): Ingress(ingress-nginx) w/k3s

  • kkumtree

2024-10-10T22:12:57+09:00

์ง€๋‚œ ํฌ์ŠคํŒ…, Kubernetes Service(2): LoadBalancer(MetalLB)์— ์ด์–ด Ingress Type์„ ๊ฐ€๋ณ๊ฒŒ ์‚ดํŽด๋ณด๊ณ , Ingress-Nginx๋ฅผ ๊ฐ€๋ณ๊ฒŒ ๋ถ™์—ฌ๋ณด๊ฒ ์Šต๋‹ˆ๋‹ค. CloudNet@์—์„œ ์ง„ํ–‰ํ•˜๊ณ  ์žˆ๋Š” K8s Advanced Network Study(์ดํ•˜, KANS)๋ฅผ ํ†ตํ•ด ํ•™์Šตํ•œ ๋‚ด์šฉ์„ ์ •๋ฆฌํ•ฉ๋‹ˆ๋‹ค. 1. Ingress Type ์ด์ œ, ์‹ ๊ทœ ๊ธฐ๋Šฅ(New feature)์€ Gateway API์— ์ถ”๊ฐ€๋œ๋‹ค๊ณ  ํ•ฉ๋‹ˆ๋‹ค. ์šฐ์„ , Kubernetes๊ฐ€ ํ—ท๊ฐˆ๋ฆฌ๋Š” ๊ฒƒ ์ค‘ ํ•˜๋‚˜๊ฐ€, Ingress Type ๊ณผ LoadBalancer Type์˜ ๋ช…ํ™•ํ•œ ์ฐจ์ด๊ฐ€ ๋ญ˜๊นŒ...? ๋ผ๋Š” ์ ์ด๋ผ๊ณ  ๋ด…๋‹ˆ๋‹ค. ๋ฌผ๋ก , ๊ทธ๊ฑฐ ์™ธ์—๋„ k8s์—๋Š” ์•Œ์ญ๋‹ฌ์ญํ•œ ๊ฒƒ๋“ค์ด ์•„-์ฃผ ๋งŽ์ง€๋งŒ์š”. ์นœ์ ˆํ•œ Docs์— ๋”ฐ๋ฅด๋ฉด, ํด๋Ÿฌ์Šคํ„ฐ ์™ธ๋ถ€๋กœ ํด๋Ÿฌ์Šคํ„ฐ ๋‚ด๋ถ€ ์„œ๋น„์Šค์— ๋Œ€ํ•œ HTTP ๋ฐ HTTPS ๋ผ์šฐํŒ…์„ ๋…ธ์ถœํ•˜๋Š” ๊ฒƒ์ด๋ผ๊ณ  ํ•ฉ๋‹ˆ๋‹ค.

Kubernetes Service(2): LoadBalancer(MetalLB)

  • kkumtree

2024-10-02T12:54:17+09:00

์ง€๋‚œ ํฌ์ŠคํŒ…, Kubernetes Service(1): ClusterIP/NodePort์— ์ด์–ด LoadBalancer Type์„ ๊ฐ€๋ณ๊ฒŒ ์‚ดํŽด๋ณด๊ณ , MetalLB๋ฅผ ๊ฐ€๋ณ๊ฒŒ ๋ถ™์—ฌ๋ณด๊ฒ ์Šต๋‹ˆ๋‹ค. CloudNet@์—์„œ ์ง„ํ–‰ํ•˜๊ณ  ์žˆ๋Š” K8s Advanced Network Study(์ดํ•˜, KANS)๋ฅผ ํ†ตํ•ด ํ•™์Šตํ•œ ๋‚ด์šฉ์„ ์ •๋ฆฌํ•ฉ๋‹ˆ๋‹ค. 1. LoadBalancer Type Service(1)์—์„œ ์–ธ๊ธ‰๋œ ๋ถ€๋ถ„์€ ๊ฑฐ๋‘์ ˆ๋ฏธํ•˜๊ณ , ์ถ”๊ฐ€๋กœ ์ ์„ ์ˆ˜ ์žˆ๋Š” ๋ถ€๋ถ„์ด ์žˆ๋‹ค๋ฉด, ์•„๋ž˜ ํ•œ ์ค„์ด ์žˆ์Šต๋‹ˆ๋‹ค. You can define a LoadBalancer Service by disabling the load balancer NodePort allocation. ๊ธ€์ž ๊ทธ๋Œ€๋กœ LB์˜ NodePort ํ• ๋‹น์„ ๋น„ํ™œ์„ฑํ•˜์—ฌ, LoadBalancer Service๋ฅผ ์ •์˜ํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค. Disabling load balancer NodePort allocation ๋ฌธ์„œ๋ฅผ ์‚ดํŽด๋ณด๋‹ˆ,

iptables monitoring with Grafana (Not Completed)

  • kkumtree

2024-09-29T13:35:13+09:00

iptables๋ฅผ ์ˆ˜์ง‘ํ•˜์—ฌ Grafana๋กœ ํ‘œํ˜„ํ•˜๋Š” ๋ฐฉ๋ฒ•์„ ์•Œ์•„๋ด…๋‹ˆ๋‹ค. CloudNet@์—์„œ ์ง„ํ–‰ํ•˜๊ณ  ์žˆ๋Š” K8s Advanced Network Study(์ดํ•˜, KANS)๋ฅผ ํ†ตํ•ด ํ•™์Šตํ•œ ๋‚ด์šฉ์„ ์ •๋ฆฌํ•ฉ๋‹ˆ๋‹ค. 0. ํ™˜๊ฒฝ ๊ตฌ์„ฑ (kind) ์ž‘์„ฑ์‹œ๊ฐ„ ์ด์Šˆ๋กœ featureGates, ConfigPatches, networking ์„ค์ • ์„ค๋ช…์€ ์Šคํ‚ต…ํ•ฉ๋‹ˆ๋‹ค. a. 1 Master, 3 Slave ํ™˜๊ฒฝ ๊ตฌ์„ฑ cat <<EOT> kind-svc-1w.yaml kind: Cluster apiVersion: kind.x-k8s.io/v1alpha4 featureGates: "InPlacePodVerticalScaling": true "MultiCIDRServiceAllocator": true nodes: - role: control-plane labels: mynode: control-plane topology.kubernetes.io/zone: ap-northeast-2a extraPortMappings: - containerPort: 30000 hostPort: 30000 - containerPort: 30001 hostPort: 30001 - containerPort: 30002 hostPort: 30002 kubeadmConfigPatches: - | kind: ClusterConfiguration apiServer: extraArgs: runtime-config: api/all=true controllerManager: extraArgs: bind-address: 0.

Kubernetes Service(1): ClusterIP/NodePort

  • kkumtree

2024-09-27T21:28:17+09:00

Kubernetes์˜ (์ปจ์…‰, ํ˜น์€ ์ฝ˜์…‰ํŠธ๋ผ ๋ถˆ๋ฆฌ๋Š”) Concepts ์ค‘์—์„œ Service์˜ ์ฃผ์ œ๋ฅผ ๋‹ค๋ค„๋ด…๋‹ˆ๋‹ค. CloudNet@์—์„œ ์ง„ํ–‰ํ•˜๊ณ  ์žˆ๋Š” K8s Advanced Network Study(์ดํ•˜, KANS)๋ฅผ ํ†ตํ•ด ํ•™์Šตํ•œ ๋‚ด์šฉ์„ ์ •๋ฆฌํ•ฉ๋‹ˆ๋‹ค. Service Docs์— ๋ช…๋ฃŒํ•˜๊ฒŒ ์ ํ˜€์žˆ๊ธด ํ•˜์ง€๋งŒ, ๋‹จ์œ„ ๊ธฐ๋Šฅ์œผ๋กœ ์ž˜๊ฒŒ ์ชผ๊ฐ  Pod๋Š” ๊ฒฐ๊ตญ ๊ฐœ๋ณ„์ ์ธ IP๋ฅผ ๊ฐ–๊ฒŒ๋˜๋Š”๋ฐ, Blue/Green ์ด๋ฏธ์ง€ ์—…๋ฐ์ดํŠธ๋ฅผ ๋น„๋กฏํ•ด์„œ ๊ฐ™์€ ๊ธฐ๋Šฅ์„ ํ•˜๋Š” ์ƒˆ๋กœ์šด Pod์˜ IP๋ฅผ ๋‹ค๋ฅธ Pod๊ฐ€ IP์ฃผ์†Œ ๊ทธ๋Œ€๋กœ ์ ‘๊ทผํ•˜๊ธฐ ์–ด๋ ค์›Œ ์ค‘๊ฐ„์— ๋‘” ๊ฒƒ์œผ๋กœ ์ดํ•ด๋ฅผ ํ•ด๋ณด์•˜์Šต๋‹ˆ๋‹ค. ์ง€๊ธˆ ๋ ˆ๋ฒจ์—์„œ๋Š” ๊ฐ€์ •์šฉ ๊ณต์œ ๊ธฐ์—์„œ ๋™์ IP ํ™˜๊ฒฝ์— ๋Œ€์‘ํ•˜๊ธฐ ์œ„ํ•ด, DDNS๋ฅผ ์‚ฌ์šฉํ•˜๋Š” ๊ฒƒ๊ณผ, MAC ADDR ๊ธฐ์ค€์œผ๋กœ Static IP(DHCP๋ชจ๋“œ์‹œ ํ™œ์šฉ)๋ฅผ ์˜ˆ์•ฝํ•˜๋Š” ๊ฒƒ์„ ์„ž์€ ๊ทธ ์–ด๋”˜๊ฐ€๋กœ ๋‚ฉ๋“ํ•˜๊ณ  ๊ณ„์† ์จ๋ณด๋„๋ก ํ•˜๊ฒ ์Šต๋‹ˆ๋‹ค.

Calico Installation in Operator Mode

  • kkumtree

2024-09-18T20:52:16+09:00

CloudNet@์—์„œ ์ง„ํ–‰ํ•˜๊ณ  ์žˆ๋Š” K8s Advanced Network Study(์ดํ•˜, KANS)๋ฅผ ํ†ตํ•ด ํ•™์Šตํ•œ ๋‚ด์šฉ์„ ์ •๋ฆฌํ•ฉ๋‹ˆ๋‹ค. ์Šคํ„ฐ๋”” ์ง„ํ–‰ ์‹œ, Manifests๋ฅผ ์‚ฌ์šฉํ•˜์—ฌ Calico๋ฅผ ์„ค์น˜ํ•˜์˜€์œผ๋‚˜, Operator๋ฅผ ์‚ฌ์šฉํ•˜์—ฌ ์„ค์น˜ํ•˜๋Š” ๋ฐฉ๋ฒ•์„ ์ •๋ฆฌํ•ฉ๋‹ˆ๋‹ค. ๊ณผ์ œ๋Š” ์•„๋‹ˆ์—ˆ์ง€๋งŒ, ์š”์ƒˆ ๋‹ค๋“ค Operator Framework๋ฅผ ์‚ฌ์šฉํ•ด์„œ ๋งˆ๋ผ์ƒน๊ถˆ ๋ณถ๋“ฏ์ด Operator๋ฅผ ์ง€์ง€๊ณ  ๋ณถ๋Š” ๊ฒƒ ๊ฐ™์•„์„œ ํ˜ธ๊ธฐ์‹ฌ์— ์ •๋ฆฌํ•ด๋ณด์•˜์Šต๋‹ˆ๋‹ค. ์ฐธ๊ณ ๋กœ Manifests๋ฅผ ์‚ฌ์šฉํ•˜์—ฌ ์„ค์น˜ ์‹œ, 50๊ฐœ์˜ ๋…ธ๋“œ[1]๋ฅผ ์ดˆ๊ณผํ•˜๋Š” ๊ฒฝ์šฐ Typha๋ฅผ ๊ตฌ์„ฑํ•˜์—ฌ์•ผ ํ•ฉ๋‹ˆ๋‹ค. Calico ์„ค์น˜ ํ™˜๊ฒฝ : AWS EC2(No EKS), kubeadm[2], pod-network-cidr=172.16.0.0/16, IPIP Mode 1. Calico Routing Mode ์œ„์— ์–ธ๊ธ‰๋œ IPIP Mode๋ฅผ ์ดํ•ดํ•˜๋ ค๋ฉด Calico์˜ Routing Mode๋ฅผ ํ›‘์„ ํ•„์š”์„ฑ์ด ์žˆ์—ˆ์Šต๋‹ˆ๋‹ค.

  1. <<
  2. <
  3. 1
  4. 2
  5. 3
  6. 4
  7. 5
  8. 6
  9. โ€ฆ
  10. 12
  11. >
  12. >>

kkumtree

Source code on GitHub

ยฉ 2025 kkumtree and contributors All rights reserved.
Licensed under
CC BY-NC-ND 4.0