-
-
Notifications
You must be signed in to change notification settings - Fork 153
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Signed-off-by: Thomas Poignant <[email protected]>
- Loading branch information
1 parent
cad7efd
commit 44ebfd9
Showing
88 changed files
with
828 additions
and
1,840 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
This file was deleted.
Oops, something went wrong.
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
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,56 @@ | ||
--- | ||
sidebar_position: 40 | ||
description: What is the GO Feature Flag architecture | ||
--- | ||
|
||
# 🏗️ Architecture | ||
|
||
## Overview | ||
GO Feature Flag is a feature flagging system that allows you to manage feature flags in your application. | ||
The architecture is really simple and efficient with the goal to be easy to use and let you experiment with feature flags in your application as fast as possible. | ||
|
||
In most cases you have 1 microservice running the `relay-proxy` and multiple applications running the SDKs, nothing else. | ||
|
||
:::note | ||
GO Feature Flag can also be run without the `relay-proxy` if you only use the GO Module. | ||
|
||
The relay-proxy is an API layer on top of the GO Module, so it has the same logic inside. | ||
::: | ||
|
||
## Architecture concepts | ||
|
||
![GO Feature Flag architecture](../../static/docs/openfeature/architecture.svg) | ||
|
||
### 🧩 OpenFeature Providers | ||
GO Feature Flag is working in collaboration with OpenFeature to be integrated with all the languages supported by GO Feature Flag. | ||
To achieve this goal, we have created the OpenFeature providers that combines with OpenFeature SDKs to allow you to use GO Feature Flag in your application. | ||
|
||
> **OpenFeature Providers** | ||
> An SDK-compliant implementation which resolves flag values from a particular flag management system, allowing the use of the Evaluation API as an abstraction for the system in question. | ||
This is what developers will use to interact with GO Feature Flag in their application. | ||
|
||
### ↔️ Relay-Proxy | ||
The relay-proxy is the only component you have to run in your infrastructure to use GO Feature Flag with the different SDKs. | ||
This is a standalone GO binary that you can run in your infrastructure to expose the GO Feature Flag API to your applications. | ||
|
||
:::info | ||
Want to know more about the relay-proxy? [Check the relay-proxy documentation](../relay-proxy). | ||
::: | ||
|
||
The relay-proxy is designed to be simple, lightweight, and stateless. It operates without the need for any databases or complex systems, as it loads feature flag configuration files from a specified location and stores them in memory. | ||
|
||
### ⬇️ Internal concepts | ||
**You have 3 main concepts in GO Feature Flag architecture:** | ||
- [retrievers](./retriever): This is the component in charge of fetching the feature flag configuration. | ||
- [notifiers](./notifier): This is the component in charge of notifying external systems that a flag configuration has changed. | ||
- [exporters](./exporter): This is the component in charge of exporting the flag evaluation results for analytics or monitoring. | ||
|
||
Those 3 concepts are the core of GO Feature Flag and allows you to integrate GO Feature Flag in your current ecosystem with a minimum of effort. | ||
Every component is designed to be as lightweight as possible and to be easy to configure. | ||
|
||
## 🧑💻 Technologies | ||
|
||
- GO Feature Flag is written in `golang`. | ||
- The `retrievers`, `notifiers`, and `exporters` are using official libraries to interact with external systems. | ||
- Providers are written in the language of the system they are interacting with and we are limiting the dependencies to the minimum to be as lightweight as possible. |
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
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
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
This file was deleted.
Oops, something went wrong.
Oops, something went wrong.