1.14.0 (April 8, 2020)

    • access log: added support for access log formatters.

    • access log: fixed %DOWSTREAM_DIRECT_REMOTE_ADDRESS% when used with PROXY protocol listener filter.

    • access log: introduced .

    • adaptive concurrency: fixed bug that allowed concurrency limits to drop below the configured minimum.

    • adaptive concurrency: minRTT is now triggered when the minimum concurrency is maintained for 5 consecutive sampling intervals.

    • admin: added support for displaying ip address subject alternate names in certs end point.

    • admin: added endpoint to control log rotation.

    • api: froze v2 xDS API. New feature development in the API should occur in v3 xDS. While the v2 xDS API has been deprecated since 1.13.0, it will continue to be supported by Envoy until EOY 2020. See Supported API versions.

    • aws_lambda: added that converts HTTP requests to Lambda invokes. This effectively makes Envoy act as an egress gateway to AWS Lambda.

    • aws_request_signing: a few fixes so that it works with S3.

    • config: added stat update_time.

    • config: use type URL to select an extension whenever the config type URL (or its previous versions) uniquely identify a typed extension, see .

    • datasource: added retry policy for remote async data source.

    • dns: added support for dns_failure_refresh_rate for the to set the DNS refresh rate during failures.

    • dns: the STRICT_DNS cluster now only resolves to 0 hosts if DNS resolution successfully returns 0 hosts.

    • eds: added hostname field for endpoints and field for endpoint’s health check config. This enables auto host rewrite and customizing the host header during health checks for eds endpoints.

    • ext_authz: disabled the use of lowercase string matcher for headers matching in HTTP-based ext_authz. Can be reverted temporarily by setting runtime feature envoy.reloadable_features.ext_authz_http_service_enable_case_sensitive_string_matcher to false.

    • fault: added support for controlling abort faults with HTTP header fault configuration to the HTTP fault filter.

    • grpc-json: added support for building HTTP request into .

    • grpc-stats: added option to limit which messages stats are created for.

    • http: added HTTP/1.1 flood protection. Can be temporarily disabled using the runtime feature envoy.reloadable_features.http1_flood_protection.

    • http: added headers_with_underscores_action setting to control how client requests with header names containing underscore characters are handled. The options are to allow such headers, reject request or drop headers. The default is to allow headers, preserving existing behavior.

    • http: added to specify the duration of existing streams. See connection and stream timeouts.

    • http: fixed a bug that could send extra METADATA frames and underflow memory when encoding METADATA frames on a connection that was dispatching data.

    • http: fixing a bug in HTTP/1.0 responses where Connection: keep-alive was not appended for connections which were kept alive.

    • http: http filter extensions use the “envoy.filters.http” name space. A mapping of extension names is available in the documentation.

    • http: the runtime feature http.connection_manager.log_flood_exception is removed and replaced with a connection access log response code.

    • http: upgrade parser library, which removes support for “identity” transfer-encoding value.

    • listener filters: listener filter extensions use the “envoy.filters.listener” name space. A mapping of extension names is available in the deprecated documentation.

    • listeners: added to disable individual listener filter on matching downstream connections.

    • loadbalancing: added support for using hostname for consistent hash loadbalancing via consistent_hash_lb_config.

    • loadbalancing: added support for in conjunction with consistent hashing load balancers (ring hash and maglev).

    • lua: added a parameter to httpCall that makes it possible to have the call be asynchronous.

    • lua: added moonjit support.

    • mongo: the stat emitted for queries without a max time set in the MongoDB filter was modified to emit correctly for Mongo v3.2+.

    • network filters: added a .

    • network filters: network filter extensions use the “envoy.filters.network” name space. A mapping of extension names is available in the deprecated documentation.

    • rbac: added and direct_remote_ip for matching downstream remote IP address.

    • rbac: deprecated with direct_remote_ip and .

    • request_id_extension: added an ability to extend request ID handling at HTTP connection manager.

    • retry: added a retry predicate that .

    • router: added ability to set attempt count in downstream response, see virtual host’s include response attempt count config.

    • router: added additional stats for .

    • router: added auto_san_validation to support overrriding SAN validation to transport socket for new upstream connections based on the downstream HTTP host/authority header.

    • router: added the ability to match a route based on whether a downstream TLS connection certificate has been .

    • router: added support for regex_rewrite for path rewriting using regular expressions and capture groups.

    • router: added support for %DOWNSTREAM_LOCAL_PORT% .

    • router: don’t ignore per_try_timeout when the is disabled.

    • router: strip whitespace for retry_on, and retry-on header.

    • runtime: integer values may now be parsed as booleans.

    • sds: added support for certificates in static resources.

    • server: the SIGUSR1 access log reopen warning now is logged at info level.

    • stat sinks: stat sink extensions use the “envoy.stat_sinks” name space. A mapping of extension names is available in the deprecated documentation.

    • thrift_proxy: added router filter stats to docs.

    • tls: added configuration to disable stateless TLS session resumption .

    • tracing: added gRPC service configuration to the OpenCensus Stackdriver and OpenCensus Agent tracers.

    • tracing: tracer extensions use the “envoy.tracers” name space. A mapping of extension names is available in the deprecated documentation.

    • upstream: added upstream_rq_retry_limit_exceeded to , and virtual cluster stats.

    • upstream: changed load distribution algorithm when all priorities enter .

    • upstream: combined HTTP/1 and HTTP/2 connection pool code. This means that circuit breaker limits for both requests and connections apply to both pool types. Also, HTTP/2 now has the option to limit concurrent requests on a connection, and allow multiple draining connections. The old behavior is deprecated, but can be used during the deprecation period by disabling runtime feature or envoy.reloadable_features.new_http2_connection_pool_behavior and then re-configure your clusters or restart Envoy. The behavior will not switch until the connection pools are recreated. The new circuit breaker behavior is described here.

    • zlib: by default zlib is initialized to use its default strategy (Z_DEFAULT_STRATEGY) instead of the fixed one (Z_FIXED). The difference is that the use of dynamic Huffman codes is enabled now resulting in better compression ratio for normal data.

    Deprecated

    • The previous behavior for upstream connection pool circuit breaking described here has been deprecated in favor of the new behavior described .

    • Access Logger, Listener Filter, HTTP Filter, Network Filter, Stats Sink, and Tracer names have been deprecated in favor of the extension name from the envoy build system. Disable the runtime feature “envoy.deprecated_features.allow_deprecated_extension_names” to disallow the deprecated names. Use of these extension names generates a log message and increments the “deprecated_feature_use” metric in stats.

      Note

      Some renamed filters produce metadata using their filter name as the metadata namespace:

      • Mongo Proxy Filter

      • Zookeeper Filter

      The metadata generated by these filters may be consumed by the following extensions, whose configurations may need to be adjusted to use the new names.

      • Access Loggers

      • HTTP and Network Ext Authz filters

      • HTTP and Network RBAC filters

      • Tracers

    • The previous behavior of auto ignoring case in headers matching: allowed_headers, , and allowed_client_headers of HTTP-based ext_authz has been deprecated in favor of explicitly setting the field.

    • The header_fields, custom_header_fields, and additional_headers fields for the route checker tool have been deprecated in favor of request_header_fields, response_header_fields, additional_request_headers, and .

    • The content_length, content_type, disable_on_etag_header and remove_accept_encoding_header fields in HTTP Gzip filter config have been deprecated in favor of compressor.

    • The statistics counter header_gzip in has been deprecated in favor of header_compressor_used.

    • Support for the undocumented HTTP/1.1 :no-chunks pseudo-header has been removed. If an extension was using this it can achieve the same behavior via the new API.

    • The source_ip field in has been deprecated in favor of direct_remote_ip and .