-
Notifications
You must be signed in to change notification settings - Fork 13.8k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
chore(docs): create architecture page (#28481)
Co-authored-by: Evan Rusackas <[email protected]>
- Loading branch information
Showing
7 changed files
with
79 additions
and
19 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 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,68 @@ | ||
--- | ||
title: Architecture | ||
hide_title: true | ||
sidebar_position: 1 | ||
version: 1 | ||
--- | ||
|
||
import useBaseUrl from "@docusaurus/useBaseUrl"; | ||
|
||
# Architecture | ||
|
||
This page is meant to give new administrators an understanding of Superset's components. | ||
|
||
## Components | ||
|
||
A Superset installation is made up of these components: | ||
1. The Superset application itself | ||
2. A metadata database | ||
3. A caching layer (optional, but necessary for some features) | ||
4. A worker & beat (optional, but necessary for some features) | ||
|
||
### Optional components and associated features | ||
|
||
The optional components above are necessary to enable these features: | ||
- [Alerts and Reports](/docs/configuration/alerts-reports) | ||
- [Caching](/docs/configuration/cache) | ||
- [Async Queries](/docs/configuration/async-queries-celery/) | ||
- [Dashboard Thumbnails](/docs/configuration/cache/#caching-thumbnails) | ||
|
||
If you install with Kubernetes or Docker Compose, all of these components will be created. | ||
|
||
However, installing from PyPI only creates the application itself. Users installing from PyPI will need to configure a caching layer, worker, and beat on their own if they wish to enable the above features. Configuration of those components for a PyPI install is not currently covered in this documentation. | ||
|
||
Here are further details on each component. | ||
|
||
### The Superset Application | ||
|
||
This is the core application. Superset operates like this: | ||
- A user visits a chart or dashboard | ||
- That triggers a SQL query to the data warehouse holding the underlying dataset | ||
- The resulting data is served up in a data visualization | ||
- The Superset application is comprised of the Python (Flask) backend application (server), API layer, and the React frontend, built via Webpack, and static assets needed for the application to work | ||
|
||
### Metadata Database | ||
|
||
This is where chart and dashboard definitions, user information, logs, etc. are stored. Superset is tested to work with PostgreSQL and MySQL databases as the metadata database (not be confused with a data source like your data warehouse, which could be a much greater variety of options like Snowflake, Redshift, etc.). | ||
|
||
Some installation methods like our Quickstart and PyPI come configured by default to use a SQLite on-disk database. And in a Docker Compose installation, the data would be stored in a PostgresQL container volume. Neither of these cases are recommended for production instances of Superset. | ||
|
||
For production, a properly-configured, managed, standalone database is recommended. No matter what database you use, you should plan to back it up regularly. | ||
|
||
### Caching Layer | ||
|
||
The caching layer serves two main functions: | ||
- Store the results of queries to your data warehouse so that when a chart is loaded twice, it pulls from the cache the second time, speeding up the application and reducing load on your data warehouse. | ||
- Act as a message broker for the worker, enabling the Alerts & Reports, async queries, and thumbnail caching features. | ||
|
||
Most people use Redis for their cache, but Superset supports other options too. See the [cache docs](/docs/configuration/cache/) for more. | ||
|
||
### Worker and Beat | ||
|
||
This is one or more workers who execute tasks like run async queries or take snapshots of reports and send emails, and a "beat" that acts as the scheduler and tells workers when to perform their tasks. Most installations use Celery for these components. | ||
|
||
## Other components | ||
|
||
Other components can be incorporated into Superset. The best place to learn about additional configurations is the [Configuration page](/docs/configuration/configuring-superset). For instance, you could set up a load balancer or reverse proxy to implement HTTPS in front of your Superset application, or specify a Mapbox URL to enable geospatial charts, etc. | ||
|
||
Superset won't even start without certain configuration settings established, so it's essential to review that page. |
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 |
---|---|---|
@@ -1,7 +1,7 @@ | ||
--- | ||
title: Docker Builds | ||
hide_title: true | ||
sidebar_position: 5 | ||
sidebar_position: 6 | ||
version: 1 | ||
--- | ||
|
||
|
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 |
---|---|---|
@@ -1,7 +1,7 @@ | ||
--- | ||
title: Docker Compose | ||
hide_title: true | ||
sidebar_position: 3 | ||
sidebar_position: 4 | ||
version: 1 | ||
--- | ||
|
||
|
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 |
---|---|---|
@@ -1,7 +1,7 @@ | ||
--- | ||
title: Kubernetes | ||
hide_title: true | ||
sidebar_position: 1 | ||
sidebar_position: 2 | ||
version: 1 | ||
--- | ||
|
||
|
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 |
---|---|---|
@@ -1,7 +1,7 @@ | ||
--- | ||
title: PyPI | ||
hide_title: true | ||
sidebar_position: 2 | ||
sidebar_position: 3 | ||
version: 1 | ||
--- | ||
|
||
|
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 |
---|---|---|
@@ -1,7 +1,7 @@ | ||
--- | ||
title: Upgrading Superset | ||
hide_title: true | ||
sidebar_position: 4 | ||
sidebar_position: 5 | ||
version: 1 | ||
--- | ||
|
||
|