Service Mesh ์์๋ณด๊ธฐ
- [Service Mesh] 1. Service Mesh๋?
- [Service Mehs] 2. Envoy Proxy
- [Service Mesh] 3. Istio?
- [Service Mesh] 4. Istio Traffic Management (1) - Virtual Service & Destination Rule
- [Service Mesh] 5. Istio Traffic Managerment (2) - Gateway & Service Entry
- [Service Mesh] 6. Service Monitoring in Istio
- [Service Mesh] 7. Logging
์ด๋ฒ ๊ธ์์๋ Service Mesh์์ Sidecar๋ก ์ฃผ๋ก ์ฌ์ฉ๋๊ณ ์๋ Envoy Proxy์ ๋ํด์ ์์๋ณด๊ฒ ์ต๋๋ค.
Envoy?
Envoy๋ L7 ํ๋ก์๋ก ํ๋์ ์๋น์ค ๊ธฐ๋ฐ ์ํคํ ์ฒ๋ฅผ ์ํด ๋ง๋ค์ด์ก์ต๋๋ค. Envoy๋ ๋ค์๊ณผ ๊ฐ์ ๊ธฐ๋ฅ์ ์ ๊ณตํ์ฌ ์ดํ๋ฆฌ์ผ์ด์ ์ ๋ํ ํฌ๋ช ํ ๋คํธ์ํฌ๋ฅผ ์ ๊ณตํฉ๋๋ค.
Out of Process Architecture
Envoy๋ ์ดํ๋ฆฌ์ผ์ด์
์๋ฒ์ ํจ๊ป ์คํ๋๋๋ก ์ค๊ณ๋ self-contained ํ๋ก์ธ์ค์
๋๋ค. ๊ฐ Envoy๋ ํฌ๋ช
ํ ๋คํธ์ํฌ๋ฅผ ํ์ฑํ๊ณ ๊ฐ ์ ํ๋ฆฌ์ผ์ด์
์ Localhost๊ณผ ๋ฉ์ธ์ง๋ฅผ ์ฃผ๊ณ ๋ฐ์ต๋๋ค. ์ด ๋, ์ ํ๋ฆฌ์ผ์ด์
์ ๋คํธ์ํฌ ํ ํด๋ก์ง์ ๋ํด ์์ง ๋ชปํ ์ํ์
๋๋ค. Out of Process ์ํคํ
์ฒ๋ ๋ค์๊ณผ ๊ฐ์ ์ฅ์ ์ ๊ฐ์ง ์ ์์ต๋๋ค.
- Envoy๋ ์ ํ๋ฆฌ์ผ์ด์ ์ ์ฌ์ฉ๋ ์ธ์ด์ ์๊ด์์ด ๋์ํ๊ฒ ๋ฉ๋๋ค.
- Envoy๋ ๋น ๋ฅด๊ฒ ๋ฐฐํฌ๋๊ณ ์ ๊ทธ๋ ์ด๋ ๋ ์ ์์ต๋๋ค.
L3/L4 Filter Architecture
Envoy์ ํต์ฌ์ L3/L4 ๋คํธ์ํฌ ํ๋ก์์
๋๋ค. ํ๋ฌ๊ทธ์ธ ๋ฐฉ์์ ํํฐ ์ฒด์ธ์ ํตํด TCP/UDP ํ๋ก์ ์์
์ ์ํ ๋ฐ ์ฝ์
ํ ์ ์์ต๋๋ค.
HTTP L7 Filter Architecture
Envoy๋ L3/L4 ๊ณ์ธต ์ด์ธ์๋ L7 ๋คํธ์ํฌ ํ๋ก์๋ ์ง์ํฉ๋๋ค. ์ด๋ฅผ ํตํด QoS์ ๊ฐ์ ์ข ๋ ์ธ๋ฐํ ์ ์ด๊ฐ ๊ฐ๋ฅํฉ๋๋ค.
HTTP/2 & gRPC
HTTP/2 ๋ฐ gRPC๋ฅผ ์ง์ํจ์ผ๋ก์จ ์์ฒญ๊ณผ ์๋ต์ ๋ฉํฐํ๋ ์ฑํ ์ ์๋ ํ๊ฒฝ์ ์ ๊ณตํฉ๋๋ค.
Service Discovery & Dynamic Configuration
๋์ ์ผ๋ก ๋ณ๊ฒฝํ๋ ๋คํธ์ํฌ ํ๊ฒฝ์ ๋ํ ๋์ ์ค์ ๋ฐ ์ด๋ฅผ ํตํ ์๋น์ค ๋์ค์ปค๋ฒ๋ฆฌ๋ฅผ ์ ๊ณตํฉ๋๋ค.
์๋ ๋ฐฉ์
๋ค์์ผ๋ก ๋ฉ์ธ์ง ์ฒ๋ฆฌ ๊ตฌ์กฐ๋ฅผ ๊ฐ๋จํ๊ฒ ์ดํด๋ณด๊ฒ ์ต๋๋ค. Envoy๋ ๋ค์๊ณผ ๊ฐ์ ์์๋ก ๋ฉ์ธ์ง๋ฅผ ์ฒ๋ฆฌํฉ๋๋ค.
Downstream โ Listener โ Filter โ Cluster(Upstream)
- Downstream : Envoy์๊ฒ ์์ฒญ์ ๋ณด๋ด๋ ํธ์คํธ๋ฅผ ์๋ฏธํฉ๋๋ค.
- Listener : Downstream์๊ฒ ์์ฒญ์ ๋ฐ๋ ๋ถ๋ถ์ ์๋ฏธํฉ๋๋ค. Envoy๋ ํ๋ ์ด์์ Listener์ ๋ ธ์ถํ์ฌ Downstream๊ณผ ์ฐ๊ฒฐ๋ฉ๋๋ค.
- Filter : ์์ ๋ ๋ฉ์์ง์ ๋ํด ๋ผ์ฐํ , ํ๋กํ ์ฝ ๋ณํ, ํต๊ณ ์์ฑ๊ณผ ๊ฐ์ ๋ค์ํ ์์ ์ ์ํํ๋ ๋ถ๋ถ์ ์๋ฏธํฉ๋๋ค.
- Upstream : Envoy๊ฐ ์์ฒญ์ ๋ณด๋ด๋ ํธ์คํธ๋ฅผ ์๋ฏธํฉ๋๋ค.
- Cluster : Upstream ํธ์คํธ์ ๊ทธ๋ฃน์ ์๋ฏธํฉ๋๋ค.
Envoy ์คํ (Docker)
Docker๋ฅผ ํตํด Envoy Proxy๋ฅผ ๊ฐ๋จํ๊ฒ ์คํ์์ผ ๋ณด๋๋ก ํ๊ฒ ์ต๋๋ค. Docker Image๋ฅผ ํตํด Envoy๋ฅผ ์ฝ๊ฒ ์คํํ ์ ์์ต๋๋ค. ๋จผ์ Envoy Docker Image๋ฅผ Pull ๋ฐ์ต๋๋ค. ์ด ๋, latest tag๊ฐ ์กด์ฌํ์ง ์์ผ๋ Envoy ๋ฌธ์๋ฅผ ํ์ธํ์ฌ ํ์ํ ํ๊ทธ๋ช ์ ์ฌ์ฉํ์๊ธธ ๋ฐ๋๋๋ค.
> docker pull envoyproxy/envoy:v1.16-latest
๋ค์์ผ๋ก Envoy ์คํ์ ์ฌ์ฉ๋๋ envoy.yaml ํ์ผ์ ํ์ธํด๋ณด๋ฉด ๋ค์๊ณผ ๊ฐ๋ค.
admin:
access_log_path: /tmp/admin_access.log
address:
socket_address:
protocol: TCP
address: 0.0.0.0
port_value: 9901
static_resources:
listeners:
- name: listener_0
address:
socket_address:
address: 0.0.0.0
port_value: 10000
filter_chains:
- filters:
- name: envoy.filters.network.http_connection_manager
typed_config:
"@type": type.googleapis.com/envoy.extensions.filters.network.http_connection_manager.v3.HttpConnectionManager
stat_prefix: ingress_http
access_log:
- name: envoy.access_loggers.file
typed_config:
"@type": type.googleapis.com/envoy.extensions.access_loggers.file.v3.FileAccessLog
path: /dev/stdout
http_filters:
- name: envoy.filters.http.router
route_config:
name: local_route
virtual_hosts:
- name: local_service
domains: ["*"]
routes:
- match:
prefix: "/"
route:
host_rewrite_literal: www.envoyproxy.io
cluster: service_envoyproxy_io
clusters:
- name: service_envoyproxy_io
connect_timeout: 30s
type: LOGICAL_DNS
# Comment out the following line to test on v6 networks
dns_lookup_family: V4_ONLY
load_assignment:
cluster_name: service_envoyproxy_io
endpoints:
- lb_endpoints:
- endpoint:
address:
socket_address:
address: www.envoyproxy.io
port_value: 443
transport_socket:
name: envoy.transport_sockets.tls
typed_config:
"@type": type.googleapis.com/envoy.extensions.transport_sockets.tls.v3.UpstreamTlsContext
sni: www.envoyproxy.io
๊ฐ๋จํ๊ฒ ์ค์ ๋ด์ฉ์ ์ดํด๋ณด๋๋ก ํ๊ฒ ์ต๋๋ค.
- admin
envoy admin ํ์ด์ง ์ค์ ์ผ๋ก address๋ฅผ ํตํด ์ ์ ๊ฐ๋ฅํ IP๋ฅผ, port๋ฅผ ํตํด admin page์ port๋ฅผ ์ค์ ํฉ๋๋ค.
docker๋ฅผ ํตํด ์คํํ ๊ฒฝ์ฐ, 127.0.0.1์ bridge network์ localhost๋ฅผ ์๋ฏธํ๊ธฐ ๋๋ฌธ์ ๋ชจ๋ IP๋ฅผ ํ์ฉํ๋ 0.0.0.0๋ก ๋ณ๊ฒฝํ์์ต๋๋ค.
- listeners
๋ฆฌ์ค๋๊ฐ ์์ ํ ํฌํธ์ ์ฃผ์์ ๋ํ ์ค์ ์ ๋ํ๋ ๋๋ค. - filter_chains
์์ ํ ๋ฉ์ธ์ง๋ฅผ ์ฒ๋ฆฌํ filter์ ๋ํ ์ค์ ๊ฐ์ผ๋ก ํ์ฌ ์ค์ ๊ฐ์ / ๊ฒฝ๋ก๋ก ๊ฐ๋ ๋ชจ๋ ์์ฒญ์ service_envoyproxy_io๋ก ๋ผ์ฐํ ํ๊ฒ ๋ฉ๋๋ค. - clusters
envoy๊ฐ ์์ฒญ์ ๋ณด๋ผ ํธ์คํธ๋ก ํ์ฌ ์ค์ ๊ฐ์ envoyproxy.com์ผ๋ก ๋ผ์ฐํ ํ๋๋ก ์ค์ ๋์ด ์์ต๋๋ค.
Envoy Container ์คํ
์์์ ์ ์ฉํ๋ admin ๋ณ๊ฒฝ ์ฌํญ์ ์ ์ฉํ ์ค์ ํ์ผ์ ๋ง์ดํธํ์ฌ ์ปจํ ์ด๋๋ฅผ ์คํํฉ๋๋ค. ์ ๋ docker run์ -v ์ต์ ์ผ๋ก ๋ง์ดํธ๋ฅผ ์๋ํ์ผ๋ envoy์ ๋ํ ์ค์ ๊ฐ ์์น๋ฅผ ์ฐพ๋ ๊ฒ์ด ๋ฒ๊ฑฐ๋ก์ ์๋ก์ด ์ด๋ฏธ์ง๋ฅผ ๋ง๋ค์ด์ ์งํํ์์ต๋๋ค.
Dockerfile
FROM envoyproxy/envoy:v1.16-latest
COPY envoy.yaml /etc/envoy/envoy.yaml
RUN chmod go+r /etc/envoy/envoy.yaml
Image Build & Run
> docker build -t envoy:local .
> docker run --rm -d -p 10000:10000 -p 9901:9901 envoy:local
localhost:10000(Envoy Listener)์ผ๋ก ์ ์ํ ๊ฒฐ๊ณผ๋ ๋ค์๊ณผ ๊ฐ์ต๋๋ค. ์์ ์ค์ ์์ /์ผ๋ก ๋ณด๋ด์ง๋ ๋ชจ๋ ์์ฒญ์ envoyproxy.io๋ก ๋ณด๋ด๋๋ก ์ค์ ํ์๊ธฐ ๋๋ฌธ์ envoyproxy.io ํํ์ด์ง๊ฐ ๋์จ ๋ชจ์ต์ ํ์ธํ ์ ์์ต๋๋ค.

localhost:9901(Envoy Admin)์ ์ ์ํ ๊ฒฐ๊ณผ๋ ๋ค์๊ณผ ๊ฐ์ต๋๋ค.

์ด๋ฒ ๊ธ์์๋ Service Mesh์์ Sidecar Proxy๋ก ์ฌ์ฉ๋๋ Envoy์ ๋ํด์ ์์๋ณด๊ณ ๊ฐ๋จํ๊ฒ Docker๋ฅผ ์ฌ์ฉํ์ฌ ์คํ์์ผ ๋ณด์์ต๋๋ค. ๋ค์ ๊ธ์์๋ Service Mesh ํ๋ซํผ์ธ Istio์ ๋ํด์ ์์๋ณด๋๋ก ํ๊ฒ ์ต๋๋ค.
์ฐธ๊ณ ์๋ฃ
'๐ Service Mesh' ์นดํ ๊ณ ๋ฆฌ์ ๋ค๋ฅธ ๊ธ
[Service Mesh] 6. Service Monitoring in Istio (0) | 2021.01.19 |
---|---|
[Service Mesh] 5. Istio Traffic Management (2) - Gateway & Service Entry (0) | 2021.01.16 |
[Service Mesh] 4. Istio Traffic Management (1) - Virtual Service & Destination Rule (0) | 2021.01.14 |
[Service Mesh] 3. Istio? (0) | 2020.12.22 |
[Service Mesh] 1. Service Mesh๋? (0) | 2020.12.20 |
๋๊ธ