-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathenvoy.yaml
73 lines (70 loc) · 2.44 KB
/
envoy.yaml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
# https://cloudnative.to/envoy/api-v3/config/route/v3/route_components.proto.html#config-route-v3-routeaction-hashpolicy
# https://stackoverflow.com/questions/69033708/how-to-set-hash-key-value-in-envoy-proxy-for-ring-hash-load-balancing
# https://www.redhat.com/en/blog/configuring-envoy-auto-discover-pods-kubernetes
admin:
address:
access_log_path: /dev/stdout
socket_address: { 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
codec_type: AUTO
route_config:
name: envoy_pgw_route
virtual_hosts:
- name: envoy_pgw_service
domains: ["*"]
routes:
- match: { prefix: "/" }
route:
cluster: pgw_service
hash_policy:
- header:
header_name: ":path" # https://datatracker.ietf.org/doc/html/rfc7540#section-8.1.2.3
http_filters:
- name: envoy.filters.http.router
typed_config:
"@type": type.googleapis.com/envoy.extensions.filters.http.router.v3.Router
clusters:
- name: pgw_service
connect_timeout: 0.25s
type: STATIC
lb_policy: MAGLEV # https://static.googleusercontent.com/media/research.google.com/en//pubs/archive/44824.pdf
load_assignment:
cluster_name: pgw_service
endpoints:
- lb_endpoints:
- endpoint:
address:
socket_address:
address: 172.16.123.177
port_value: 9091
- endpoint:
address:
socket_address:
address: 172.16.123.177
port_value: 9092
- endpoint:
address:
socket_address:
address: 172.16.123.177
port_value: 9093
layered_runtime:
layers:
- name: static_layer_0
static_layer:
envoy:
resource_limits:
listener:
example_listener_name:
connection_limit: 10000
overload:
global_downstream_max_connections: 50000