From ea556246b5d0395db01a2ebdcca1298b0e41ec01 Mon Sep 17 00:00:00 2001 From: Mark Phelps <209477+markphelps@users.noreply.github.com> Date: Thu, 15 Feb 2024 17:30:05 -0500 Subject: [PATCH 1/2] chore: update clickhouse docs --- configuration/analytics.mdx | 54 ++++++++++++++++++++++++++++++------- configuration/storage.mdx | 24 ++++++++--------- operations/production.mdx | 20 +++++++------- 3 files changed, 66 insertions(+), 32 deletions(-) diff --git a/configuration/analytics.mdx b/configuration/analytics.mdx index f561be2e..e005a602 100644 --- a/configuration/analytics.mdx +++ b/configuration/analytics.mdx @@ -5,36 +5,70 @@ description: This document describes various configuration mechanisms for contro ## Analytics -Since [v1.37.0](https://github.com/flipt-io/flipt/releases/tag/v1.37.0) Flipt includes functionality for reporting analytical data to a configurable storage engine. +As of [v1.37.0](https://github.com/flipt-io/flipt/releases/tag/v1.37.0), Flipt includes functionality for reporting analytical data to a configurable storage engine. -Currently, Flipt has support for collecting data into: +Currently, Flipt has support for collecting data into the following storage engines: -- [Clickhouse](https://clickhouse.com/) +- [ClickHouse](https://clickhouse.com/) The data that gets collected currently includes: - Flag Evaluation Count -Once a storage backend is configured, these analytics are viewable in the UI allowing users to visualize up to 24 hours of data for each metric. +Once a storage engine is configured, these analytics are viewable in the UI allowing users to visualize up to 24 hours of data for each metric. ![UI For Analytics](/images/configuration/analytics_quick_view.png) The image above shows the past 30 minutes of the flag `flag1` evaluation counts. -## Considerations +### Origin -### Database +Analytics are currently only collected as they pass through the evaluation server. This means that analytics will be captured if you are using the REST or GRPC APIs via one of our [Server SDKs](/integration/server/rest) or [GRPC SDKs](/integration/server/grpc) for evaluations. + +We have plans to support collecting analytics for [Client-Side](/integration/client) evaluations in the future. + +## ClickHouse + +You can use a self-hosted ClickHouse instance or a [managed instance](https://clickhouse.com/cloud/) to store your analytics data. We highly **recommend** using a separate database for analytics produced by Flipt. This ensures that Flipt analytic data can be logically isolated from the rest of your Clickhouse data. The analytics database must be created before Flipt will be able to write analytical data and run any migrations. See our - [migration](/configuration/storage#migrations) section for more info. + [migration](/configuration/storage#migrations) + section for more info. -### Origin of Analytics +To create a database for Flipt analytics, you can use the following SQL: -Analytics are currently only collected as they pass through the evaluation server. This means that analytics will be captured if you are using the REST or GRPC APIs via one of our [Server SDKs](/integration/server/rest) or [GRPC SDKs](/integration/server/grpc) for evaluations. +```sql +CREATE DATABASE IF NOT EXISTS flipt_analytics; +``` -We have plans to support collecting analytics for [Client-Side](/integration/client) evaluations in the future. +See the [ClickHouse documentation](https://clickhouse.com/docs) for more information on how to get started with ClickHouse. + +### Configuration + +To configure Flipt to use ClickHouse for analytics, you will need to add the following configuration to your `config.yml` file or environment variables: + + + + + ```bash + FLIPT_ANALYTICS_CLICKHOUSE_ENABLED=true + FLIPT_ANALYTICS_CLICKHOUSE_URL=clickhouse://clickhouse:9000/flipt_analytics + ``` + + + + + ```yaml + analytics: + clickhouse: + enabled: true + url: clickhouse://clickhouse:9000/flipt_analytics + ``` + + + diff --git a/configuration/storage.mdx b/configuration/storage.mdx index 1786df17..932ef69e 100644 --- a/configuration/storage.mdx +++ b/configuration/storage.mdx @@ -153,7 +153,7 @@ This is particularly useful for local development and validation of flag state c Flipt will periodically rebuild its state from the local disk every 10 seconds. - + ```bash FLIPT_STORAGE_TYPE="local" @@ -161,7 +161,7 @@ Flipt will periodically rebuild its state from the local disk every 10 seconds. ``` - + ```yaml storage: @@ -184,7 +184,7 @@ This cadence is also configurable and defaults to 30 seconds. Flipt will follow the configured reference (e.g. branch name) and keep up to date with new changes. - + ```bash FLIPT_STORAGE_TYPE="git" @@ -197,7 +197,7 @@ Flipt will follow the configured reference (e.g. branch name) and keep up to dat ``` - + ```yaml storage: @@ -302,7 +302,7 @@ The AWS S3 backend can be configured to serve state from a single bucket from a The following is an example of how to configure Flipt to leverage this backend type: - + ```bash FLIPT_STORAGE_TYPE="object" @@ -317,7 +317,7 @@ The following is an example of how to configure Flipt to leverage this backend t ``` - + ```yaml storage: @@ -356,7 +356,7 @@ The Azure Blob Storage backend can be configured to serve state from a single co The following is an example of how to configure Flipt to leverage this backend type: - + ```bash FLIPT_STORAGE_TYPE="object" @@ -368,7 +368,7 @@ The following is an example of how to configure Flipt to leverage this backend t ``` - + ```yaml storage: @@ -414,7 +414,7 @@ The Google Cloud Storage backend can be configured to serve state from a single The following is an example of how to configure Flipt to leverage this backend type: - + ```bash FLIPT_STORAGE_TYPE="object" @@ -426,7 +426,7 @@ The following is an example of how to configure Flipt to leverage this backend t ``` - + ```yaml storage: @@ -462,7 +462,7 @@ Since `v1.31.0`, Flipt supports using any [OCI](https://opencontainers.org/) com Flipt has its own custom OCI manifest format (we call them `bundles`), which can be built and managed using the [Flipt CLI](/cli/commands/bundle). - + ```bash FLIPT_STORAGE_TYPE="oci" @@ -476,7 +476,7 @@ Flipt has its own custom OCI manifest format (we call them `bundles`), which can ``` - + ```yaml storage: diff --git a/operations/production.mdx b/operations/production.mdx index 7d518a30..51b9513d 100644 --- a/operations/production.mdx +++ b/operations/production.mdx @@ -19,14 +19,14 @@ You should tweak that number to be above 0, and to whatever fits your use case. This can be altered either via the Flipt configuration file or environment variables: - + ```bash FLIPT_DB_MAX_OPEN_CONN=5 ``` - + ```yaml db: @@ -45,14 +45,14 @@ If MaxOpenConns is greater than 0 but less than the new MaxIdleConns, then the n Keep in mind that tuning `MaxOpenConn` may lead to tuning `MaxIdleConn` as well. - + ```bash FLIPT_DB_MAX_IDLE_CONN=5 ``` - + ```yaml db: @@ -71,14 +71,14 @@ For instance, PGBouncer doesn't support prepared statements in its [transaction You can disable prepared statements for the database client using: - + ```bash FLIPT_DB_PREPARED_STATEMENTS_ENABLED=false ``` - + ```yaml db: @@ -95,14 +95,14 @@ Debug logging can be useful if you are actively developing or trying to fix prob It's recommended to disable Flipt's debug logging in a production environment by increasing the log level: - + ```bash FLIPT_LOG_LEVEL=info ``` - + ```yaml log: @@ -119,14 +119,14 @@ Flipt exposes profiling endpoints (`/debug/pprof`) that can be useful for debugg You can disable these endpoints by setting the following configuration options: - + ```bash FLIPT_DIAGNOSTICS_PROFILING_ENABLED=false ``` - + ```yaml diagnostics: From d370b9e5c2f5f80f271ab48b3da2969e67931568 Mon Sep 17 00:00:00 2001 From: markphelps Date: Thu, 15 Feb 2024 22:31:11 +0000 Subject: [PATCH 2/2] chore: format code --- configuration/analytics.mdx | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/configuration/analytics.mdx b/configuration/analytics.mdx index e005a602..2fc3ef2b 100644 --- a/configuration/analytics.mdx +++ b/configuration/analytics.mdx @@ -36,8 +36,7 @@ We highly **recommend** using a separate database for analytics produced by Flip The analytics database must be created before Flipt will be able to write analytical data and run any migrations. See our - [migration](/configuration/storage#migrations) - section for more info. + [migration](/configuration/storage#migrations) section for more info. To create a database for Flipt analytics, you can use the following SQL: