11 ways not to get hacked
Last updated
Was this helpful?
Last updated
Was this helpful?
https://kubernetes.io/blog/2018/07/18/11-ways-not-to-get-hacked/ ์์ฝ
psp๊ด๋ จ ๋ด์ฉ์ ์ญ์
Kubernetes ๋ณด์์ ํ๋ก์ ํธ๊ฐ ์์๋ ์ดํ๋ก ๋จผ ๊ธธ์ ๊ฑธ์ด์์ง๋ง ์ฌ์ ํ ๋ช ๊ฐ์ง ๋ฌธ์ ๊ฐ ์์ต๋๋ค. ์ปจํธ๋กค ํ๋ ์ธ์์ ์์ํ์ฌ ์ํฌ๋ก๋ ๋ฐ ๋คํธ์ํฌ ๋ณด์์ ํตํด ๊ตฌ์ถํ๊ณ ๋ณด์์ ๋ฏธ๋์ ๋ํ ์์ธก์ผ๋ก ๋ง๋ฌด๋ฆฌํ๋ ๋ค์์ ํด๋ฌ์คํฐ๋ฅผ ๊ฐํํ๊ณ ์์๋ ๊ฒฝ์ฐ ๋ณต์๋ ฅ์ ๋์ด๋ ๋ฐ ๋์์ด ๋๋ ์ ์ฉํ ํ ๋ชฉ๋ก์ ๋๋ค.
control plane์ Kubernetes์ ๋๋์ ๋๋ค. ํด๋ฌ์คํฐ์์ ์คํ ์ค์ธ ๋ชจ๋ ์ปจํ ์ด๋์ ํฌ๋์ ๋ํ ์ ์ฒด ๋ณด๊ธฐ๊ฐ ์๊ณ ์ ํฌ๋(๋ถ๋ชจ ๋ ธ๋์ ๋ํ ๋ฃจํธ ์ก์ธ์ค ๊ถํ์ด ์๋ ์ปจํ ์ด๋๋ฅผ ํฌํจํ ์ ์์)๋ฅผ ์์ฝํ ์ ์์ผ๋ฉฐ ํด๋ฌ์คํฐ์ ์ ์ฅ๋ ๋ชจ๋ ๋น๋ฐ์ ์ฝ์ ์ ์์ต๋๋ค. ์ด ๊ท์คํ ๊ฒ์ ์ ๊ทผํ ๋๋, ์ ์ฅ๋์ด ์์ ๋๋, ๋คํธ์ํฌ๋ฅผ ํตํด ์ด์ก๋ ๋๋ ์ฐ๋ฐ์ ์ธ ๋์ถ ๋ฐ ์ ์์ ์ธ ์๋๋ก๋ถํฐ ๋ณดํธํด์ผ ํฉ๋๋ค.
ํธ๋ํฝ ์ค๋ํ์ ๋ฐฉ์งํ๊ณ , ์๋ฒ์ ID๋ฅผ ํ์ธํ๊ณ , (์ํธ TLS์ ๊ฒฝ์ฐ) ํด๋ผ์ด์ธํธ์ ID๋ฅผ ํ์ธํ๋ ค๋ฉด TLS๋ฅผ ์ง์ํ๋ ๋ชจ๋ ๊ตฌ์ฑ ์์์ ๋ํด TLS๋ฅผ ํ์ฑํํด์ผ ํฉ๋๋ค.
Source
Lucas Kรคldstrรถm์ด ์์ฑํ ์ด ๋คํธ์ํฌ ๋ค์ด์ด๊ทธ๋จ์ TLS๊ฐ ์ด์์ ์ผ๋ก ์ ์ฉ๋์ด์ผ ํ๋ ์ผ๋ถ ์์น, ์ฆ ๋ง์คํฐ์ ๋ชจ๋ ๊ตฌ์ฑ์์ ์ฌ์ด, Kubelet๊ณผ API ์๋ฒ ์ฌ์ด๋ฅผ ๋ณด์ฌ์ค๋๋ค.
Role-based access control์ ๋ค์์คํ์ด์ค ์ก์ธ์ค์ ๊ฐ์ ๋ฆฌ์์ค์ ๋ํ ์ฌ์ฉ์ ์ก์ธ์ค์ ๋ํ ์ธ๋ถํ๋ ์ ์ฑ ๊ด๋ฆฌ๋ฅผ ์ ๊ณตํฉ๋๋ค.
Kubernetes์ ABAC(์์ฑ ๊ธฐ๋ฐ ์ก์ธ์ค ์ ์ด)๋ ๋ฆด๋ฆฌ์ค 1.6๋ถํฐ RBAC๋ก ๋์ฒด๋์์ผ๋ฉฐ API ์๋ฒ์์ ํ์ฑํํ๋ฉด ์ ๋ฉ๋๋ค. ๋์ RBAC๋ฅผ ์ฌ์ฉํ์ญ์์ค.
์์ง ๋ง์ธ์: ์ด๋ฌํ ๋ก๊ทธ๋ฅผ ํด๋ฌ์คํฐ ๋ด๋ถ์ ๋ณด๊ดํ๋ ๊ฒ์ ์นจํด ์ ๋ณด์ ์ํ์ด ๋ฉ๋๋ค. ์ด๋ ๋ค๋ฅธ ๋ชจ๋ ๋ณด์์ ๋ฏผ๊ฐํ ๋ก๊ทธ์ ๋ง์ฐฌ๊ฐ์ง๋ก ์๋ฐ ์ ๋ณ์กฐ๋ฅผ ๋ฐฉ์งํ๊ธฐ ์ํด ํด๋ฌ์คํฐ ์ธ๋ถ๋ก ์ ์ก๋์ด์ผ ํฉ๋๋ค.
์กฐ์ง ์ ์ฒด์์ ์ธ์ฆ ๋ฐ ๊ถํ ๋ถ์ฌ(Single Sign On์ด๋ผ๊ณ ๋ ํจ)๋ฅผ ์ค์ ์ง์คํํ๋ฉด ์ฌ์ฉ์์ ๋ํ ์จ๋ณด๋ฉ, ์คํ๋ณด๋ฉ ๋ฐ ์ผ๊ด๋ ๊ถํ์ด ๋์์ด ๋ฉ๋๋ค.
Kubernetes๋ฅผ ํ์ฌ ์ธ์ฆ ์ ๊ณต์(์: Google ๋๋ GitHub)์ ํตํฉํ๋ฉด ์๊ฒฉ ํ๋ซํผ์ ID ๋ณด์ฆ(2FA์ ๊ฐ์ ๊ฒ์ผ๋ก ๋ฐฑ์ ๋จ)์ ์ฌ์ฉํ๊ณ ๊ด๋ฆฌ์๊ฐ ์ฌ์ฉ์๋ฅผ ์ถ๊ฐํ๊ฑฐ๋ ์ ๊ฑฐํ๊ธฐ ์ํด Kubernetes API ์๋ฒ๋ฅผ ์ฌ๊ตฌ์ฑํด์ผ ํ๋ ๊ฒ์ ๋ฐฉ์งํฉ๋๋ค.
etcd๋ ์ํ ๋ฐ ๋น๋ฐ์ ๋ํ ์ ๋ณด๋ฅผ ์ ์ฅํ๋ฉฐ ์ค์ํ Kubernetes ๊ตฌ์ฑ ์์์ ๋๋ค. ํด๋ฌ์คํฐ์ ๋๋จธ์ง ๋ถ๋ถ๊ณผ ๋ค๋ฅด๊ฒ ๋ณดํธํด์ผ ํฉ๋๋ค.
API ์๋ฒ์ etcd์ ๋ํ ์ฐ๊ธฐ ์ก์ธ์ค๋ ์ ์ฒด ํด๋ฌ์คํฐ์์ ๋ฃจํธ๋ฅผ ์ป๋ ๊ฒ๊ณผ ๋์ผํ๋ฉฐ ์ฝ๊ธฐ ์ก์ธ์ค๋ฅผ ์ฌ์ฉํ์ฌ ๊ถํ์ ์๋นํ ์ฝ๊ฒ ์์ค์ปฌ๋ ์ด์ ํ ์ ์์ต๋๋ค.
Kubernetes ์ค์ผ์ค๋ฌ๋ ๋ ธ๋๊ฐ ์๋ ํฌ๋ ์ ์์ ๋ํด etcd๋ฅผ ๊ฒ์ํฉ๋๋ค. ๊ทธ๋ฐ ๋ค์ ์ฐพ์ ํฌ๋๋ฅผ ์์ฝ์ ์ํด ์ฌ์ฉ ๊ฐ๋ฅํ kubelet์ผ๋ก ๋ณด๋ ๋๋ค. ์ ์ถ๋ ํฌ๋์ ๋ํ ์ ํจ์ฑ ๊ฒ์ฌ๋ API ์๋ฒ๊ฐ etcd์ ์ฐ๊ธฐ ์ ์ ์ํํ๋ฏ๋ก etcd์ ์ง์ ์ฐ๋ ์ ์์ ์ธ ์ฌ์ฉ์๋ ๋ง์ ๋ณด์ ๋ฉ์ปค๋์ฆ์ ์ฐํํ ์ ์์ต๋๋ค. ์)PodSecurity์ ์ฑ .
etcd๋ ํผ์ด ๋ฐ ํด๋ผ์ด์ธํธ TLS ์ธ์ฆ์๋ก ๊ตฌ์ฑํ๊ณ ์ ์ฉ ๋ ธ๋์ ๋ฐฐํฌํด์ผ ํฉ๋๋ค. ๊ฐ์ธ ํค๊ฐ ๋๋๋นํ๊ณ ์์ ์ ๋ ธ๋์์ ์ฌ์ฉ๋๋ ๊ฒ์ ๋ฐฉ์งํ๊ธฐ ์ํด ํด๋ฌ์คํฐ๋ฅผ API ์๋ฒ๋ก ๋ฐฉํ๋ฒฝ์ผ๋ก ์ค์ ํ ์๋ ์์ต๋๋ค.
๋ณด์ ๋ชจ๋ฒ ์ฌ๋ก๋ ํค ์์์ "ํญ๋ฐ ๋ฐ๊ฒฝ"์ ์ ํํ๊ธฐ ์ํด ์ํธํ ํค์ ์ธ์ฆ์๋ฅผ ์ ๊ธฐ์ ์ผ๋ก ๊ต์ฒดํ๋ ๊ฒ์ ๋๋ค.
Kubernetes๋ ๊ธฐ์กด ์๊ฒฉ ์ฆ๋ช ์ด ๋ง๋ฃ๋๋ฉด ์ CSR์ ์์ฑํ์ฌ ์ผ๋ถ ์ธ์ฆ์(ํนํ kubelet ํด๋ผ์ด์ธํธ ๋ฐ ์๋ฒ ์ธ์ฆ์)๋ฅผ ์๋์ผ๋ก ๊ต์ฒดํฉ๋๋ค.
๊ทธ๋ฌ๋ API ์๋ฒ๊ฐ etcd ๊ฐ์ ์ํธํํ๋ ๋ฐ ์ฌ์ฉํ๋ ๋์นญ ์ํธํ ํค๋ ์๋์ผ๋ก ์ํ๋์ง ์์ผ๋ฉฐ ์๋์ผ๋ก ์ํํด์ผ ํฉ๋๋ค. ์ด๋ฅผ ์ํด์๋ ๋ง์คํฐ ์ก์ธ์ค๊ฐ ํ์ํ๋ฏ๋ก ๊ด๋ฆฌ ์๋น์ค(์: GKE ๋๋ AKS)๋ ์ด์์๋ก๋ถํฐ ์ด ๋ฌธ์ ๋ฅผ ์ถ์ํํฉ๋๋ค.
์ปจํธ๋กค ํ๋ ์ธ์์ ์ต์ํ์ ์คํ ๊ฐ๋ฅํ ๋ณด์์ผ๋ก ํด๋ฌ์คํฐ๋ ์์ ํ๊ฒ ์๋ํ ์ ์์ต๋๋ค. ๋ฐฐํฌ ์ ์ ๋ขฐํ ์ ์์ง๋ง ์ธํฐ๋ท์ ์ฐ๊ฒฐ๋์ด ์์ผ๋ฉด ๋์ค์ ์ ์ฉ๋ ์ํ์ด ํญ์ ์์ต๋๋ค. ์ต์ํ์ ๊ถํ์ผ๋ก ์ํฌ๋ก๋๋ฅผ ์คํํ๊ณ ๋ฐํ์ ๊ตฌ์ฑ์ ๊ฐํํ๋ฉด ์ด๋ฌํ ์ํ์ ์ํํ๋ ๋ฐ ๋์์ด ๋ ์ ์์ต๋๋ค.
Linux ์ปค๋์๋ ์์ฉ ํ๋ก๊ทธ๋จ์ ์ต์ ๊ถํ์ ์ ๊ณตํ๋๋ก ๊ตฌ์ฑํ ์ ์๋ ์ฌ๋ฌ ์ค์ฒฉ ๋ณด์ ํ์ฅ(๊ธฐ๋ฅ, SELinux, AppArmor, seccomp-bpf)์ด ์์ต๋๋ค.
bane๊ณผ ๊ฐ์ ๋๊ตฌ๋ AppArmor ํ๋กํ์ ์์ฑํ๊ณ seccomp ํ๋กํ์ ์ํ docker-slim์ ์์ฑํ๋ ๋ฐ ๋์์ด ๋ ์ ์์ง๋ง ์ด๋ฌํ ์ ์ฑ ์ ์ฉ์ ๋ถ์์ฉ์ด ์์ต๋๋ค. ์ ํ๋ฆฌ์ผ์ด์ ์ ํฌ๊ด์ ์ธ ํ ์คํธ๋ฅผ ์ฃผ์ํ์ฌ ํ์ญ์์ค.
Sensitive information should not be stored in pod-type YAML resource (deployments, pods, sets, etc.), and sensitive configmaps and secrets should be encrypted with tools such as vault (with CoreOS's operator), git-crypt, sealed secrets, or cloud provider KMS.
Static analysis of YAML configuration can be used to establish a baseline for runtime security. kubesec
generates risk scores for resources:
And kubetest
is a unit test framework for Kubernetes configurations:
๋ฃจํธ๋ก ์คํ๋๋ ์ปจํ ์ด๋๋ ์์ ๋ถํ๊ฐ ์๊ตฌํ๋ ๊ฒ๋ณด๋ค ํจ์ฌ ๋ ๋ง์ ๊ถํ์ ๊ฐ๊ณ ์์ผ๋ฉฐ, ์ด๋ ์์๋ ๊ฒฝ์ฐ ๊ณต๊ฒฉ์๊ฐ ๊ณต๊ฒฉ์ ๊ณ์ํ๋ ๋ฐ ๋์์ด ๋ ์ ์์ต๋๋ค.
Kubernetes์์ ์ฌ์ฉ์ ๋ค์์คํ์ด์ค๊ฐ ํ์ฑํ๋์ด ์์ง ์์ต๋๋ค. ์ฆ, ์ปจํ ์ด๋์ ์ฌ์ฉ์ ID ํ ์ด๋ธ์ด ํธ์คํธ์ ์ฌ์ฉ์ ํ ์ด๋ธ์ ๋งคํ๋๊ณ ์ปจํ ์ด๋ ๋ด์์ ๋ฃจํธ ์ฌ์ฉ์๋ก ํ๋ก์ธ์ค๋ฅผ ์คํํ๋ฉด ํธ์คํธ์์ ๋ฃจํธ๋ก ์คํ๋ฉ๋๋ค. ์ปจํ ์ด๋ ๋ธ๋ ์ดํฌ์์์ ๋ฐฉ์งํ๊ธฐ ์ํด ๊ณ์ธตํ๋ ๋ณด์ ๋ฉ์ปค๋์ฆ์ด ์์ง๋ง ์ปจํ ์ด๋ ๋ด๋ถ์์ ๋ฃจํธ๋ก ์คํํ๋ ๊ฒ์ ์ฌ์ ํ ๊ถ์ฅ๋์ง ์์ต๋๋ค.
๋ง์ ์ปจํ ์ด๋ ์ด๋ฏธ์ง๋ ๋ฃจํธ ์ฌ์ฉ์๋ฅผ ์ฌ์ฉํ์ฌ PID 1์ ์คํํฉ๋๋ค. ํด๋น ํ๋ก์ธ์ค๊ฐ ์์๋๋ฉด ๊ณต๊ฒฉ์๊ฐ ์ปจํ ์ด๋์ ๋ฃจํธ๋ฅผ ๊ฐ๊ฒ ๋๋ฉฐ ์๋ชป๋ ๊ตฌ์ฑ์ ์ ์ฉํ๊ธฐ๊ฐ ํจ์ฌ ์ฌ์์ง๋๋ค.
๋ฃจํธ๊ฐ ์๋ ์ปจํ ์ด๋๋ 1024 ๋ฏธ๋ง์ ๊ถํ ์๋ ํฌํธ์ ๋ฐ์ธ๋ฉํ ์ ์์ง๋ง(์ด๊ฒ์ CAP_NET_BIND_SERVICE ์ปค๋ ๊ธฐ๋ฅ์ ์ํด ์ ์ด๋จ) ์๋น์ค๋ฅผ ์ฌ์ฉํ์ฌ ์ด ์ฌ์ค์ ์์ฅํ ์ ์์ต๋๋ค. ์ด ์์์ ๊ฐ์์ MyApp ์ ํ๋ฆฌ์ผ์ด์ ์ ์ปจํ ์ด๋์ ํฌํธ 8443์ ๋ฐ์ธ๋ฉ๋์ง๋ง ์๋น์ค๋ targetPort์ ๋ํ ์์ฒญ์ ํ๋ก์ํ์ฌ 443์์ ์ด๋ฅผ ๋ ธ์ถํฉ๋๋ค.
๋ฃจํธ๊ฐ ์๋ ์ฌ์ฉ์๋ก ์ํฌ๋ก๋๋ฅผ ์คํํด์ผ ํ๋ ๊ฒ์ ์ฌ์ฉ์ ๋ค์์คํ์ด์ค๋ฅผ ์ฌ์ฉํ ์ ์๊ฑฐ๋ ๋ฃจํธ๊ฐ ์๋ ์ปจํ ์ด๋๋ฅผ ์คํํ๊ธฐ ์ํ ์ง์์ ์ธ ์์ ์ด ์ปจํ ์ด๋ ๋ฐํ์์ ์์ ๋๊น์ง ๋ณ๊ฒฝ๋์ง ์์ต๋๋ค.
Kubernetes๋ ๋ชจ๋ ์์คํ ์ํ๋ฅผ etcd์ ์ ์ฅํ๋ฏ๋ก CNI ๋คํธ์ํน ํ๋ฌ๊ทธ์ธ์์ ์ง์ํ๋ ๊ฒฝ์ฐ ๋์ ๋ฐฉํ๋ฒฝ์ ๊ตฌ์ฑํ ์ ์์ต๋๋ค.
Calico, Cilium, kube-router, Romana ๋ฐ Weave Net์ ๋ชจ๋ Network Policy
์ ์ง์ํฉ๋๋ค.
Kubernetes ๋คํธ์ํฌ ์ ์ฑ ์ DNS ์ด๋ฆ์ ์ ์ฉํ ์ ์์ต๋๋ค. ๊ณ ์ IP ๋๋ podSelector(๋์ Kubernetes IP์ ๊ฒฝ์ฐ)์๋ง ๋คํธ์ํฌ ์ ์ฑ ์ ์ ์ฉํ ์ ์๊ธฐ ๋๋ฌธ์ ๋๋ค.
๋ชจ๋ฒ ์ฌ๋ก๋ ๋ค์์คํ์ด์ค์ ๋ํ ๋ชจ๋ ํธ๋ํฝ์ ๊ฑฐ๋ถํ๋ ๊ฒ์ผ๋ก ์์ํ๊ณ ์ ํ๋ฆฌ์ผ์ด์ ์ด ์๋ฝ ํ ์คํธ ์ ํ๊ตฐ์ ํต๊ณผํ ์ ์๋๋ก ๊ฒฝ๋ก๋ฅผ ์ ์ง์ ์ผ๋ก ์ถ๊ฐํ๋ ๊ฒ์ ๋๋ค.
์น ์๋ฒ๋ ์ธ๋ถ์์ http/https๋ฅผ ํตํด์ pod๋ด๋ถ์ฝ๋๋ฅผ ์คํํ ์ ์์
์ด๋ฏธ์ง ์ค์บํ๋ฉด ๊ณต๊ฒฉ์๊ฐ ์ปจํ ์ด๋์ ์๊ฒฉ ์ก์ธ์คํ๊ธฐ ์ํด ์ ์ฉํ ์ ์๋ ์๋ ค์ง ์ทจ์ฝ์ ์ด ์๋์ง ํ์ธํฉ๋๋ค.
IDS(์นจ์ ํ์ง ์์คํ )์ ์ฌ์ฉํฉ๋๋ค.
์ด๋ฌํ ์นํ ์ ์ปจํ ์ด๋ ์ด๋ฏธ์ง ์ค์บ ๋๊ตฌ์์ ์ด๋ฏธ์ง๋ฅผ ํด๋ฌ์คํฐ์ ๋ฐฐํฌํ๊ธฐ ์ ์ ์ ํจ์ฑ์ ๊ฒ์ฌํ๋ ๋ฐ ์ฌ์ฉํ ์ ์์ต๋๋ค. ๊ฒ์ฌ์ ์คํจํ ์ด๋ฏธ์ง๋ ์ ์ฅ์ด ๊ฑฐ๋ถ๋ ์ ์์ต๋๋ค.
์๋ ค์ง ์ทจ์ฝ์ ์ ๋ํด ์ปจํ ์ด๋ ์ด๋ฏธ์ง๋ฅผ ์ค์บํ๋ฉด ๊ณต๊ฒฉ์๊ฐ ๊ณต๊ฐ๋ CVE๋ฅผ ์ ์ฉํ ์ ์๋ ์๊ฐ์ ์ค์ผ ์ ์์ต๋๋ค. CoreOS์ Clair ๋ฐ Aqua์ Micro Scanner์ ๊ฐ์ ๋ฌด๋ฃ ๋๊ตฌ๋ ๋ฐฐํฌ ํ์ดํ๋ผ์ธ์์ ์ฌ์ฉ๋์ด ์ค์ํ๊ณ ์ ์ฉ ๊ฐ๋ฅํ ์ทจ์ฝ์ ์ด ์๋ ์ด๋ฏธ์ง์ ๋ฐฐํฌ๋ฅผ ๋ฐฉ์งํด์ผ ํฉ๋๋ค.
Grafeas
์ ๊ฐ์ ๋๊ตฌ๋ ์ปจํ
์ด๋์ ๊ณ ์ ์๋ช
(์ฝํ
์ธ ์ฃผ์ ์ง์ ๊ฐ๋ฅ ํด์)์ ๋ํ ์ง์์ ์ธ ๊ท์ ์ค์ ๋ฐ ์ทจ์ฝ์ฑ ๊ฒ์ฌ๋ฅผ ์ํด ์ด๋ฏธ์ง ๋ฉํ๋ฐ์ดํฐ๋ฅผ ์ ์ฅํ ์ ์์ต๋๋ค. ์ฆ, ํด๋น ํด์๋ฅผ ์ฌ์ฉํ์ฌ ์ปจํ
์ด๋ ์ด๋ฏธ์ง๋ฅผ ์ค์บํ๋ ๊ฒ์ ํ๋ก๋์
์ ๋ฐฐํฌ๋ ์ด๋ฏธ์ง๋ฅผ ์ค์บํ๋ ๊ฒ๊ณผ ๋์ผํ๋ฉฐ ํ๋ก๋์
ํ๊ฒฝ์ ์ก์ธ์คํ ํ์ ์์ด ๊ณ์ ์ํํ ์ ์์ต๋๋ค.
์๋ ค์ง์ง ์์ Zero Day ์ทจ์ฝ์ ์ ํญ์ ์กด์ฌํ๋ฏ๋ก Twistlock, Aqua ๋ฐ Sysdig Secure์ ๊ฐ์ ์นจ์ ํ์ง ๋๊ตฌ๋ฅผ Kubernetes์ ๋ฐฐํฌํด์ผ ํฉ๋๋ค.
IDS๋ ์ปจํ ์ด๋์์ ๋น์ ์์ ์ธ ๋์์ ๊ฐ์งํ๊ณ ์ด๋ฅผ ์ผ์ ์ค์งํ๊ฑฐ๋ ์ข ๋ฃํฉ๋๋ค. Sysdig์ Falco๋ ์คํ ์์ค ๊ท์น ์์ง์ด๋ฉฐ ์ด ์ํ๊ณ์ ์ถ๋ฐ์ ์ ๋๋ค.
๋ณด์์ "ํด๋ผ์ฐ๋ ๋ค์ดํฐ๋ธ ์งํ"์ ๋ค์ ๋จ๊ณ๋ ์๋น์ค ๋ฉ์๋ก ๋ณด์ด์ง๋ง ์ฑํ์๋ ์๊ฐ์ด ๊ฑธ๋ฆด ์ ์์ต๋๋ค. ๋ง์ด๊ทธ๋ ์ด์ ์๋ ์ ํ๋ฆฌ์ผ์ด์ ์์ ๋ฉ์ ์ธํ๋ผ๋ก์ ๋ณต์ก์ฑ ์ด๋์ด ํฌํจ๋๋ฉฐ ์กฐ์ง์ ๋ชจ๋ฒ ์ฌ๋ก๋ฅผ ์ดํดํ๊ธฐ๋ฅผ ์ด๋งํ ๊ฒ์ ๋๋ค.
์๋น์ค ๋ฉ์๋ Envoy ๋ฐ Linkerd์ ๊ฐ์ ๊ณ ์ฑ๋ฅ "์ฌ์ด๋์นด" ํ๋ก์ ์๋ฒ ๊ฐ์ ๋ง๋ค์ด์ง ์ํธํ๋ ์๊ตฌ ์ฐ๊ฒฐ์ ์น์ ๋๋ค. ๋ง์ดํฌ๋ก์๋น์ค ๋ณ๊ฒฝ ์์ด ํธ๋ํฝ ๊ด๋ฆฌ, ๋ชจ๋ํฐ๋ง ๋ฐ ์ ์ฑ ์ ์ถ๊ฐํฉ๋๋ค.
๋ง์ดํฌ๋ก์๋น์ค ๋ณด์ ๋ฐ ๋คํธ์ํน ์ฝ๋๋ฅผ ๊ณต์ ํ๊ณ ์ ํฌ ํ ์คํธ๋ฅผ ๊ฑฐ์น ๋ผ์ด๋ธ๋ฌ๋ฆฌ ์ธํธ๋ก ์คํ๋ก๋ํ๋ ๊ฒ์ Linkerd๋ฅผ ํตํด ์ด๋ฏธ ๊ฐ๋ฅํ์ผ๋ฉฐ Google, IBM ๋ฐ Lyft์ Istio ๋์ ์ผ๋ก ์ด ๋ถ์ผ์ ๋์์ด ์ถ๊ฐ๋์์ต๋๋ค. ํฌ๋๋น ์ํธํ ID๋ฅผ ์ํ SPIFFE ๋ฐ ๊ธฐํ ๋ค์ํ ๊ธฐ๋ฅ์ ์ถ๊ฐํจ์ผ๋ก์จ Istio๋ ์ฐจ์ธ๋ ๋คํธ์ํฌ ๋ณด์์ ๋ฐฐํฌ๋ฅผ ๋จ์ํํ ์ ์์ต๋๋ค.
"์ ๋ก ํธ๋ฌ์คํธ" ๋คํธ์ํฌ์์๋ ๋ชจ๋ ์ํธ ์์ฉ์ด mTLS(์ํธ TLS)๋ฅผ ํตํด ๋ฐ์ํ๋ฏ๋ก ๊ธฐ์กด ๋ฐฉํ๋ฒฝ์ด๋ Kubernetes ๋คํธ์ํฌ ์ ์ฑ ์ด ํ์ํ์ง ์์ ์ ์์ต๋๋ค.
์ ํต์ ์ธ ๋คํธ์ํน์์ ํด๋ผ์ฐ๋ ๋ค์ดํฐ๋ธ ๋ณด์ ์์น์ผ๋ก์ ์ด๋ฌํ ์ ํ์ ์ ํต์ ์ธ ๋ณด์ ์ฌ๊ณ ๋ฐฉ์์ ๊ฐ์ง ์ฌ๋๋ค์๊ฒ ์ฝ์ง ์์ ๊ฒ์ผ๋ก ์์๋๋ฉฐ SPIFFE์ Evan Gilman์ด ์ด Zero Trust Networking ์ฑ ์ ์ด ๋ฉ์ง ์ ์ธ๊ณ๋ฅผ ์๊ฐํ๋ ๋ฐ ์ ๊ทน ๊ถ์ฅ๋ฉ๋๋ค.
Istio LTS๊ฐ ์ถ์๋์์ผ๋ฉฐ ํ๋ก์ ํธ๋ 1.0 ๋ฆด๋ฆฌ์ค์ ๋น ๋ฅด๊ฒ ์ ๊ทผํ๊ณ ์์ต๋๋ค. ์์ ์ฑ ๋ฒ์ ๊ด๋ฆฌ๋ Kubernetes ๋ชจ๋ธ๊ณผ ๋์ผํฉ๋๋ค. ๊ฐ๋ณ API๊ฐ ์์ฒด ์ํ/๋ฒ ํ ์์ ์ฑ ๋ค์์คํ์ด์ค์์ ์์ ์ ์๋ณํ๋ ์์ ์ ์ธ ์ฝ์ด์ ๋๋ค. ์์ผ๋ก ๋ช ๋ฌ ๋์ Istio ์ฑํ์ด ์ฆ๊ฐํ ๊ฒ์ผ๋ก ์์๋ฉ๋๋ค.
๊ธฐ๋ณธ์ ์ผ๋ก Kubernetes ๋คํธ์ํน์ ๋ชจ๋ ํฌ๋ ๊ฐ ํธ๋ํฝ์ ํ์ฉํฉ๋๋ค. ์ด๊ฒ์ `Network Policy`์ ์ฌ์ฉํ์ฌ ์ ํํ ์ ์์ต๋๋ค.