-
Notifications
You must be signed in to change notification settings - Fork 406
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
1 changed file
with
74 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,74 @@ | ||
--- | ||
title: Self-hosting real-time flag updates | ||
sidebar_label: Real-time flags | ||
sidebar_position: 30 | ||
--- | ||
|
||
If you are self-hosting Flagsmith, using [real-time flag updates](/advanced-use/real-time-flags.md) requires deploying | ||
additional infrastructure. This document describes how to deploy, scale and monitor the infrastructure required for | ||
using real-time flags. | ||
|
||
## Prerequisites | ||
|
||
Real-time flag updates require an Enterprise subscription. | ||
|
||
This document assumes you already have the [Flagsmith API](/deployment/hosting/locally-api.md) deployed to your | ||
infrastructure. | ||
|
||
## Limitations | ||
|
||
The [Flagsmith Helm chart](/deployment/hosting/kubernetes) does not support deploying the infrastructure required for | ||
real-time flag updates. | ||
|
||
The Redis server must not require authentication for the `default` user. | ||
|
||
## Architecture | ||
|
||
Self-hosting real-time flags requires two additional infrastructure components: | ||
|
||
- Server-sent events (SSE) service containers, running the `flagsmith/sse` Docker image. | ||
- Redis or Redis-compatible key-value store, such as Valkey. All | ||
[currently-supported Redis versions](https://redis.io/docs/latest/operate/rs/installing-upgrading/product-lifecycle/) | ||
are supported. | ||
|
||
The following sequence diagram describes how Flagsmith clients, the Flagsmith API and real-time components interact to | ||
deliver real-time flag updates. "Client" refers to any Flagsmith SDK that supports real-time updates. | ||
|
||
```mermaid | ||
sequenceDiagram | ||
Client->>API: Fetch environment state | ||
API->>Client: #nbsp | ||
Client->>SSE service: Subscribe to environment updates | ||
SSE service->>Client: #nbsp | ||
Administrator->>API: Update environment state | ||
API->>Administrator: #nbsp | ||
API->>SSE service: Notify environment updated | ||
SSE service->>API: #nbsp | ||
SSE service->>Redis: Store environment's latest update timestamp | ||
loop Every second, for every subscriber | ||
SSE service->>Redis: Check environment's latest update timestamp | ||
Redis->>SSE service: #nbsp | ||
SSE service-->>Client: Notify environment subscribers | ||
end | ||
Client->>API: Fetch environment state | ||
API->>Client: #nbsp | ||
Client-->Client: Store latest update timestamp | ||
``` | ||
|
||
## Server-sent events (SSE) service | ||
|
||
The `flagsmith/sse` service provides the following HTTP endpoints: | ||
|
||
| Method | Route | Called by | Description | Authentication | | ||
| ------ | ---------------------------------------------- | ------------------- | -------------------------------------------------------------- | -------------------------- | | ||
| GET | `/sse/environments/{environment}/stream` | Client applications | Subscribe to an SSE stream for the given environment. | None | | ||
| POST | `/sse/environments/{environment}/queue-change` | Flagsmith API | Notify the SSE service that the given environment was updated. | `SSE_AUTHENTICATION_TOKEN` | | ||
|
||
### Configuration | ||
|
||
`flagsmith/sse` uses the following environment variables for configuration: | ||
|
||
| Variable name | Description | Default | Example | | ||
| ------------- | ------------------------------------------- | ------------ | ----------- | | ||
| `REDIS_HOST` | Hostname of the Redis server to use to | **Required** | `localhost` | | ||
| `REDIS_PORT` | Port number to use when connecting to Redis | | | |