Releases: launchdarkly/ld-relay
Releases · launchdarkly/ld-relay
5.12.0
[5.12.0] - 2020-08-06
Added:
- There is a new configuration option for specifying the lowest allowable TLS version, when using the Relay Proxy as a secure server. This is
MinTlsVersion
in the[Main]
section of the configuration file, or the variableMIN_TLS_VERSION
if using environment variables. For instance, setting this option to1.2
means that all requests from clients must use TLS 1.2 or higher.
5.11.2
[5.11.2] - 2020-08-06
Changed:
- There is a
clientSideAvailability
property which will be sent by LaunchDarkly services in the future as an alternate way of indicating whether a flag is enabled for use by client-side/mobile JavaScript SDKs. Previous versions of the Relay Proxy did not support this property, so the more detailed availability features being added to the LaunchDarkly dashboard would not work for applications that connected through a Relay Proxy. This version adds that support.
5.11.1
[5.11.1] - 2020-07-07
Changed:
- Updated the README to have updated usage guidance and to fix outdated links.
Fixed:
- When proxying events, events that were received from JavaScript browser clients via the special image-loading endpoint (used if the browser does not support CORS) could be lost.
- When Prometheus metrics are enabled, the
/metrics
endpoint that Relay provides for the Prometheus agent to query was being added globally usinghttp.Handle
; that meant that if an application used Relay as a library, and usedhttp.ListenAndServe
with the default handler, it would have a/metrics
endpoint on its own port. This has been fixed so the endpoint is only defined on the Prometheus exporter's port. - Stream reconnections now use a backoff delay with jitter, instead of a fixed delay.
5.11.0
[5.11.0] - 2020-03-17
Added:
- Relay now sets the header
X-Accel-Buffering: no
on all streaming responses. If you are using Nginx as a proxy in front of Relay, this tells Nginx to pass streaming data through without buffering; if you are not using Nginx, it has no effect. (#90)
Fixed:
- When using a persistent data store such as Redis, if the database was unavailable when Relay initially started and made its first stream connection, a bug caused Relay to give up on retrying and remain in a failed state. This has been fixed so that it will retry the stream connection once it detects that the database is available again (or, if using infinite caching mode, it will leave the same stream connection open and write the already-cached data to the database).
- When Prometheus metrics were enabled, Relay was exposing
/debug/pprof/
endpoints from Go'snet/http/pprof
on the port used by the Prometheus exporter (prior to v5.6.0, these were also exposed on the main port). These were not part of the Prometheus integration and have been removed, and Relay no longer usesnet/http/pprof
. - CI builds now verify that Relay builds correctly in all supported Go versions (1.8 through 1.14).
5.10.0
[5.10.0] - 2020-01-22
Added:
- When forwarding events, Relay is now able to forward diagnostic data that is sent by newer versions of the SDKs. This has no effect on its behavior with older SDKs.
Fixed:
- Updated to Go SDK 4.14.2 to fix a bug that could cause spurious "feature store query returned unexpected type" errors to be logged.
5.9.4
[5.9.4] - 2020-01-15
Fixed:
- For connections from JavaScript browser SDK versions 2.16.1 and above, Relay now supports CORS requests that include new request headers sent by those SDK versions.
- When forwarding events, Relay now specifies a uniquely identifiable request header when sending events to LaunchDarkly to ensure that events are only processed once, even if Relay sends them two times due to a failed initial attempt.
5.9.3
[5.9.3] - 2020-01-14
Fixed:
- When running Relay as a systemd service, the
ld-relay.service
file incorrectly specified the process start-up type asforking
. Relay does not fork; the correct type issimple
.
5.9.2
[5.9.2] - 2020-01-09
Fixed:
- Relay's logging format was extremely inconsistent: depending on whether a message was related to a specific environment or not, the fields would be in different order and the timestamp was not always at the beginning of the line. This has been normalized so the timestamp (with microseconds) is always first, followed by a tag that is either
[env: name-of-environment]
or[main]
, then a level such asINFO:
, and then the message. (#85) - The proxy URL parameter was not working in the case of a regular HTTP/HTTPS proxy, as opposed to an NTLM proxy. The standard Go environment variable
HTTPS_PROXY
did work. Both are now usable.
5.9.1
[5.9.1] - 2020-01-06
Fixed:
- When forwarding events from the PHP SDK, Relay was not preserving additional information related to experimentation features (supported in PHP SDK 3.6.0 and above). As a result, some flag rules might be included in experimentation data in the LaunchDarkly UI when those rules were not selected to be included. Events from other SDKs were not affected.