The Relay Proxy is typically deployed in proxy mode.
In this mode, several Relay Proxy instances deploy in a high-availability configuration behind a load balancer. Relay Proxy nodes do not need to communicate with each other, and there is no master or cluster. This makes it easy to scale the Relay Proxy horizontally by deploying more nodes behind the load balancer.
You must configure your SDKs to point to the location of the Relay Proxy, so that they connect to it instead of connecting to LaunchDarkly.
To learn more, read Configuring an SDK to use the Relay Proxy.
For a list of all of the service endpoints that Relay Proxy implements for use by the SDKs, read Endpoints.
If you want SDKs to connect to the Relay Proxy securely, read Using TLS.
If an SDK connects to the Relay Proxy while the Relay Proxy is starting up and waiting for a connection to LaunchDarkly, the response is a 503
error. This indicates that the Relay Proxy isn't ready yet. All LaunchDarkly SDKs will retry after a backoff delay in this case.
Eventually, the Relay Proxy stops waiting for the connection. The length of this wait depends on the configuration option initTimeout
(default value: 10 seconds). Continue reading for what happens after that point.
By default, if the initialization timeout elapses and the Relay Proxy has not yet received flag data from LaunchDarkly, it will give up and shut down completely. However, if the configuration option ignoreConnectionErrors
is set to true
, it will stay running and keep trying to connect to LaunchDarkly.
If the Relay Proxy receives requests from SDKs at this point, the behavior depends on whether there is any source of last known flag data:
-
If the Relay Proxy is configured to use persistent storage and there is already flag data in the database from a previous time, then it will provide that data to SDKs. Later, if it finally does receive current flag data from LaunchDarkly, it will provide the current data to all currently connected SDKs as well as all subsequent requests.
-
If it does not have persistent storage, or if the database was never populated, then it will respond to all polling requests from SDKs with a
503
error. This indicates that they should try again later because there is no data yet. All streaming requests from SDKs will be accepted, but will not receive any data until the Relay Proxy has received flag data from LaunchDarkly.
In automatic configuration, the first thing the Relay Proxy does on startup is to request the configuration data from LaunchDarkly. During this time, it does not yet know what the configured environments are, so it has no way to know if an SDK key or other credential in a request is valid. Therefore it returns a 503
error for all requests, indicating that it isn't ready yet. All LaunchDarkly SDKs will retry after a backoff delay in this case.
If a server-side or mobile SDK connects to the Relay Proxy with an invalid SDK key or mobile key, the response is a 401 error.
If a client-side SDK such as the JavaScript SDK connects to the Relay Proxy with an invalid client-side environment ID, the response is a 404 error. This slightly different error behavior corresponds to how the LaunchDarkly service endpoints for those SDKs work.
All LaunchDarkly SDKs will give up with no retries in this case.