-
Story
-
Resolution: Won't Do
-
Major
-
None
-
None
-
8
-
False
-
False
-
Undefined
-
Currently, when pushing Wasm filter configuration to proxies, we're sending a RemoteFetch configuration, which means that Envoy will go and fetch the Wasm module itself from the URL we're providing. The RemoteFetch is problematic though, because Envoy will just NACK the configuration the first time we send it, because it first has to download the Wasm module. By default, Istio would now get stuck until the next full push, rendering the proxy unusable. To avoid this, we implemented a workaround that looks at the reason for the NACK and retries pushing the configuration if it was a transient error (ie Envoy is still downloading the module). That is not very intelligent behaviour, but it got the job done for the tech preview.
For GA, we'll need to revisit this. We should do what upstream does and use the proxy to intercept the RemoteFetch configuration in the istio-agent, download the Wasm module themselves, and then replace it using a LocalFile configuration, just like the WasmPlugin implementation.
Acceptance Criteria:
- Remove the workaround
- Use ECDS to transmit Extension Configurations, same as for WasmPlugin
- incorporates
-
OSSM-264 Support WebAssembly Extensions to Envoy/Proxy
- Closed