|
|
@@ -0,0 +1,128 @@
|
|
|
+apiVersion: v1
|
|
|
+kind: Service
|
|
|
+metadata:
|
|
|
+ labels:
|
|
|
+ app: envoy-proxy
|
|
|
+ name: envoy-proxy
|
|
|
+spec:
|
|
|
+ ports:
|
|
|
+ - name: http-debug
|
|
|
+ port: 8080
|
|
|
+ protocol: TCP
|
|
|
+ - name: admin-debug
|
|
|
+ port: 9901
|
|
|
+ protocol: TCP
|
|
|
+ selector:
|
|
|
+ app: envoy-proxy
|
|
|
+---
|
|
|
+apiVersion: apps/v1
|
|
|
+kind: StatefulSet
|
|
|
+metadata:
|
|
|
+ labels:
|
|
|
+ app: envoy-proxy
|
|
|
+ name: envoy-proxy
|
|
|
+spec:
|
|
|
+ serviceName: envoy-proxy
|
|
|
+ replicas: 1
|
|
|
+ selector:
|
|
|
+ matchLabels:
|
|
|
+ app: envoy-proxy
|
|
|
+ template:
|
|
|
+ metadata:
|
|
|
+ labels:
|
|
|
+ app: envoy-proxy
|
|
|
+ spec:
|
|
|
+ containers:
|
|
|
+ - name: envoy-proxy
|
|
|
+ image: envoyproxy/envoy:v1.17.0@sha256:80df344b5651c57265a03b47f583c139d3ce955415746c00cf5aff08c7e78e44
|
|
|
+ volumeMounts:
|
|
|
+ - name: config-volume
|
|
|
+ mountPath: /etc/envoy/envoy.yaml
|
|
|
+ subPath: envoy.yaml
|
|
|
+ command: [
|
|
|
+ "/usr/local/bin/envoy",
|
|
|
+ "-c",
|
|
|
+ "/etc/envoy/envoy.yaml",
|
|
|
+ "-l",
|
|
|
+ "trace",
|
|
|
+ "--log-path",
|
|
|
+ "/tmp/envoy_info.log"]
|
|
|
+ ports:
|
|
|
+ - containerPort: 8080
|
|
|
+ name: http-debug
|
|
|
+ protocol: TCP
|
|
|
+ - containerPort: 9901
|
|
|
+ name: admin-debug
|
|
|
+ protocol: TCP
|
|
|
+ volumes:
|
|
|
+ - name: config-volume
|
|
|
+ configMap:
|
|
|
+ name: envoy-proxy
|
|
|
+---
|
|
|
+kind: ConfigMap
|
|
|
+apiVersion: v1
|
|
|
+metadata:
|
|
|
+ name: envoy-proxy
|
|
|
+ labels:
|
|
|
+ app: envoy-proxy
|
|
|
+selector:
|
|
|
+ matchLabels:
|
|
|
+ app: envoy-proxy
|
|
|
+data:
|
|
|
+ envoy.yaml: |
|
|
|
+ admin:
|
|
|
+ access_log_path: /tmp/admin_access.log
|
|
|
+ address:
|
|
|
+ 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: 8080 }
|
|
|
+ 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
|
|
|
+ codec_type: auto
|
|
|
+ stat_prefix: ingress_http
|
|
|
+ route_config:
|
|
|
+ name: local_route
|
|
|
+ virtual_hosts:
|
|
|
+ - name: local_service
|
|
|
+ domains: ["*"]
|
|
|
+ routes:
|
|
|
+ - match: { prefix: "/" }
|
|
|
+ route:
|
|
|
+ cluster: echo_service
|
|
|
+ timeout: 0s
|
|
|
+ max_stream_duration:
|
|
|
+ grpc_timeout_header_max: 0s
|
|
|
+ cors:
|
|
|
+ allow_origin_string_match:
|
|
|
+ - prefix: "*"
|
|
|
+ allow_methods: GET, PUT, DELETE, POST, OPTIONS
|
|
|
+ allow_headers: keep-alive,user-agent,cache-control,content-type,content-transfer-encoding,custom-header-1,x-accept-content-transfer-encoding,x-accept-response-streaming,x-user-agent,x-grpc-web,grpc-timeout
|
|
|
+ max_age: "1728000"
|
|
|
+ expose_headers: custom-header-1,grpc-status,grpc-message
|
|
|
+ http_filters:
|
|
|
+ - name: envoy.filters.http.grpc_web
|
|
|
+ - name: envoy.filters.http.cors
|
|
|
+ - name: envoy.filters.http.router
|
|
|
+ clusters:
|
|
|
+ - name: echo_service
|
|
|
+ connect_timeout: 0.25s
|
|
|
+ type: logical_dns
|
|
|
+ http2_protocol_options: {}
|
|
|
+ lb_policy: round_robin
|
|
|
+ load_assignment:
|
|
|
+ cluster_name: cluster_0
|
|
|
+ endpoints:
|
|
|
+ - lb_endpoints:
|
|
|
+ - endpoint:
|
|
|
+ address:
|
|
|
+ socket_address:
|
|
|
+ address: guardian
|
|
|
+ port_value: 7070
|
|
|
+---
|