This guide can help you if you are a new Dash Enterprise customer looking to start with a Dash Enterprise 5 installation, or if you are upgrading from Dash Enterprise 4.X.
Dash Enterprise puts data and AI into action with the creation of production-grade data apps for your business. Python is the premier language of AI and data and Dash Enterprise is the leading vehicle for delivering Python-based, interactive insights and analytics to business users.
Dash Enterprise pricing is based on the number of instances and license seats that your organization requires.
Exact pricing is established via private offer. There are no optional features.
Plotly also offers paid Professional Services hours where app developers can
receive direct assistance to develop data apps that meet their users’ needs.
These hours are negotiated and billed separately from Dash Enterprise.
Installing Dash Enterprise is an automated process. You use a bootstrap node to run a Plotly-provided script that creates a Kubernetes cluster using kURL and installs Dash Enterprise on your bare metal server. A bootstrap node is a machine whose purpose is to run the script. If you choose a short-lived machine for this task, you can stop or decommission it after the installation.
You’ll be installing Dash Enterprise as the single tenant on the cluster—that is, no other software is installed on the cluster (except mandatory supporting software). Single-tenancy is well-suited for Dash Enterprise because it is a complex platform, organizing resources on the fly when developers perform tasks like deploying Dash apps and creating databases. Multi-tenancy is not currently supported.
Plotly uses Replicated to package and deliver Dash Enterprise. You’ll be interacting with the KOTS Admin Console, part of the Replicated toolset, in the configuration step of this installation. After the installation, you’ll continue to use the KOTS Admin Console for system administration such as performing Dash Enterprise upgrades.
Here are some important notices and details about supported configurations before you get started.
Before committing to an airgapped Dash Enterprise installation, make sure your organization can provide an internal index. Dash Enterprise requires that the index have a TLS/SSL certificate from a globally trusted certificate authority (CA). A common strategy is to create a mirror of pypi.org.
Important: Apps deployed to Dash Enterprise use Python 3.10.11 by default, though developers can change the Python version. For a full list of supported versions, see the App Structure page.
Similarly, if Dash app developers plan to deploy apps that depend on APT packages, you’ll need to prepare a custom APT repository with a TLS/SSL certificate from a globally trusted certificate authority (CA).
Restarting the server: Stopping and restarting the server that Dash Enterprise is installed on (often called parking) is not supported. The server must be left on for Dash Enterprise to remain in a healthy state.
Changing the server IP: Changing the internal and/or public IP of the server after installation is not supported.
Load balancing: Dash Enterprise on a single server does not come with a load balancer. If you need to place a load balancer in front of the server, make sure that it supports websocket connections.
Minimum specifications for the bare metal server change depending on which offering of Dash Enterprise your organization has purchased.
Domain/Port | Purpose | When | I/O |
---|---|---|---|
*.kurl.sh 443 |
Download kURL | Installation | Outbound |
*.docker.com 443 |
Download Docker | Installation | Outbound |
*.k8s.io 443 |
Download kubectl |
Installation | Outbound |
storage.googleapis.com 443 |
Download kubectl |
Installation | Outbound |
github.com 443 |
Download Cert Manager | Installation | Outbound |
*.githubusercontent.com 443 |
Download ImageSwap | Installation | Outbound |
*.docker.io 443 |
Download Weave and Docker images | Installation | Outbound |
quay.io |
Download Cert Manager and ImageSwap | Installation | Outbound |
*.quay.io |
Download Cert Manager and ImageSwap | Installation | Outbound |
kots.io 443 |
Download the KOTS plug-in | Installation | Outbound |
*.redhat.com 443 (RHEL server only) |
Download yum-utils |
Installation | Outbound |
*.microsoft.com 443 (RHEL server only) |
Download yum-utils |
Installation | Outbound |
vault.centos.org 443 (RHEL server only) |
Download semanage |
Installation | Outbound |
dl.plotly.com 443 |
Download the Dash Enterprise upgrade tool | Upgrade | Outbound |
A workstation with internet access, a web browser, and 20 GB of free disk space (only required if your bootstrap node does not have a web browser)
A wildcard or multi-domain TLS/SSL full certificate chain and unencrypted, 2048-bit private key. The full certificate chain must be a .pem
file in the following format:
txt
-----BEGIN CERTIFICATE-----
<Your>
-----END CERTIFICATE-----
-----BEGIN CERTIFICATE-----
<Your>
-----END CERTIFICATE-----
-----BEGIN CERTIFICATE-----
<Your>
-----END CERTIFICATE-----
The root certificate can be issued by an external/globally-trusted CA or by a CA that is internal to your organization.
Important: Dash Enterprise cannot integrate with an external identity provider (IdP) that uses a root certificate issued by a CA that is internal to your organization. If your organization uses an internal root CA across all its services, consider using it for Dash Enterprise and choosing native Keycloak authentication as your authentication method.
If you obtained your certificate chain as multiple files, you need to combine them into a single .pem
file. You can do this with cat server.pem intermediate.pem trustedroot.pem > fullchain.pem
on Linux or copy server.pem+intermediate.pem+trustedroot.pem fullchain.pem
on Windows, replacing the file names if yours are different. Using multiple certificates or self-signed certificates are not supported.
You’ll upload the full certificate chain and unencrypted private key during the configuration, and they will be used to terminate TLS/SSL.
Name | Type | Value |
---|---|---|
<base-domain> |
A record | <server-ip> |
api-<base-domain> |
CNAME | <base-domain> |
ws-<base-domain> |
CNAME | <base-domain> |
git-<base-domain> |
CNAME | <base-domain> |
registry-<base-domain> |
CNAME | <base-domain> |
auth-<base-domain> |
CNAME | <base-domain> |
admin-<base-domain> |
CNAME | <base-domain> |
where <base-domain>
is a fully qualified domain name (FQDN) that you want to use as the base domain for your Dash Enterprise instance and <server-ip>
is the IP address of your bare metal server.
Contact our Customer Success team to get started. We’ll ask you:
When we have this information, we’ll send you a tailor-made installation script as well as a link and password to a download portal from which you’ll need to download airgap bundles. Your Installation Plan is tailor-made based on your conversation with Customer Success and contains everything you need to install Dash Enterprise for your organization.
Your Installation Plan contains:
install_de_ss_airgap.sh
, which creates the Kubernetes cluster and installs Dash Enterprise as well as supporting software.config.local.sh
which contains variables used by the scripts. You’ll define some of these variables as part of the install preparation.Unzip your Installation Plan and open the config file. Edit the following variable values:
ADMIN_PASSWORD
: The password you want to set for the KOTS Admin Console.About storing and resetting this password: We recommend storing this password in your organization’s password manager, and giving access to any other members of your team who will be managing the Dash Enterprise system (notably performing upgrades and obtaining support bundles). This password is not retrievable with a
kubectl
command. It can be changed in the Admin Console UI by anyone who is able to log in with the current password. If lost, reset it by downloading the KOTS CLI and runningkubectl kots reset-password -n plotly-system
.
HOST_INTERNAL_REGISTRY
: The URL to the private container registry you are using for Dash Enterprise images, including the desired namespace.HOST_INTERNAL_REGISTRY_USER
: The username for the account you’ll use to pull and push images to your private container registry.HOST_INTERNAL_REGISTRY_PASSWORD
: The password for the account you’ll use to pull and push images to your private container registry.AUTH_REGISTRY_PULLS
: Leave false
if the private container registry does not require authentication to pull images. If authentication is required to pull images, change to true
.HOST_INTERNAL_REGISTRY_BASE
: If AUTH_REGISTRY_PULLS
is set to true
, provide the URL to the private container registry without namespaces. Otherwise, leave empty.INSTANCE_SSH_TARGET
: The IP address of your bare metal server (used by the installation script to SSH into the server).INSTANCE_SSH_PORT
: The port that you want to use for SSH on your server, which corresponds to the rule that you optionally added when you provisioned your server. This will be used by the installation script to remap the Linux OpenSSH daemon (sshd
) on your server to your chosen port. Remapping the sshd
is required in order for it to not conflict with the Git SSH port. If you plan to customize the Git SSH port when configuring Dash Enterprise, then there will be no conflict, and you can set INSTANCE_SSH_PORT
to 22.INSTANCE_SSH_USERNAME
: The username for the bare metal server (used by the installation script to SSH into the server).INSTANCE_SSH_IDENTITY
: The path to the SSH private key on your bootstrap node (used by the installation script to SSH into the server).SKIP_PUSH_IMAGES
: Set to true
if you have retrieved the Dash Enterprise images into your private container registry before the installation. Otherwise, leave false
.SKIP_REGISTRY_CHECK
: Set to true
if you have retrieved the Dash Enterprise images into your private container registry before the installation. Otherwise, leave false
.INSTALL_ISTIO
: Leave false
unless instructed to modify this (and allowing access to istio.io
over 443
on your bootstrap node) by our Customer Success team.KURL_PRIVATE_IP
: If your bare metal server has more than one network interface, specify the IP address for kURL to use when creating the Kubernetes cluster. If your server has a single network interface, leave this blank.If your organization uses its own custom CA (with the internal root CA certificate installed on users’ systems), you can add the internal root CA certificate to Dash Enterprise with INTERNAL_CA_CERTIFICATE
. It must be a .crt
file and contain the root certificate only—not the full chain. Provide it as follows:
INTERNAL_CA_CERTIFICATE
(optional): The path to your organization’s internal root CA certificate on the bootstrap node. If using, you’ll move the internal root CA certificate to the home directory of the bootstrap node, so set INTERNAL_CA_CERTIFICATE
to the corresponding path, taking care to include the full name of the certificate, including its .crt
extension.In this step, you’ll download the airgap bundle required to install Dash Enterprise. Note that the Dash Enterprise airgap bundle is approximately 15 GB.
To download the airgap bundle:
In this step, you’ll run the installation script from your bootstrap node. This script does the following:
INSTANCE_SSH_PORT
.kURL
and moves it to your bare metal server to create the Kubernetes cluster.plotly-system
namespace, in which the core system components of Dash Enterprise will be installed.~/.kube/config
) to run kubectl
commands against the Kubernetes cluster.To create the cluster and port-forward the KOTS Admin Console:
sudo bash install_de_ss_airgap.sh
kots
install location by Enter installation path (leave blank for /usr/local/bin)
, press Enter
to accept the default./usr/local/bin
, press y
(you will not be prompted for a password).The script takes several minutes to complete. Continue when you see the message Forwarding from 0.0.0.0:8800 -> 3000
(do not exit yet).
If you exit by mistake, restart the port-forward with
kubectl port-forward -n plotly-system svc/kotsadm --address 0.0.0.0 8800:3000
.
Now that your cluster is created, you’re ready to install Dash Enterprise on it. The KOTS Admin Console will take you through uploading your Dash Enterprise license and airgap bundle.
Note: If using a bootstrap node with a web browser for this step and the following step, you’ll need to move your Dash Enterprise license file, Dash Enterprise airgap bundle, and TLS/SSL certificate and key to your bootstrap node.
To access the KOTS Admin Console and install Dash Enterprise:
http://<bootstrap-ip>:8800
, where <bootstrap-ip>
is the external IP address of your bootstrap node.http://localhost:8800
.ADMIN_PASSWORD
in Defining Variables in the Scripts; then select Log in. You are prompted to upload your license..airgap
file you downloaded earlier.SKIP_PUSH_IMAGES
and SKIP_REGISTRY_CHECK
are false
in your config file), clear the Disable Pushing Images to Registry checkbox. (Note that this setting will be saved and applied when you upgrade Dash Enterprise. Change it in the Admin Console registry settings if you don’t want to keep this workflow for Dash Enterprise upgrades).When the upload is complete, the KOTS Admin Console opens to the Configure Dash Enterprise page.
Now that Dash Enterprise is installed, you’re ready for configuration. The KOTS Admin Console will take you through uploading your TLS/SSL certificate and running preflight checks.
On the Configure Dash Enterprise page, do the following:
<img>
Ctrl+C
to disconnect from the Admin Console.You can now access the Admin Console using its sub-domain: https://admin-<your-dash-enterprise-server>
.
Before you can log in to Dash Enterprise at https://<your-dash-enterprise-server>
, you’ll need to create a Dash Enterprise user in Keycloak. Keycloak is the identity and access management solution for Dash Enterprise.
In this step, you’ll retrieve the Keycloak password that is stored as a secret in your cluster and save it according to your organization’s best practices.
To obtain and store the Keycloak password:
sh
kubectl get secret keycloak-secrets -n plotly-system -o jsonpath='{.data.KEYCLOAK_PASSWORD}' | base64 -d && echo
Important: Changing this password requires Plotly support. Do not rotate it without contacting us.
In this step, you’ll log in to Keycloak using the stored credentials and create a new user with the admin
role. The admin
role grants access to the Admin section of the Dash Enterprise App Manager, which you’ll use to configure system limits
in a later step. Learn more about the admin role.
To access Keycloak and create your admin user:
https://auth-<your-dash-enterprise-server>
<img>
Make sure dash is selected in the realm list in the top left corner.
Select Users > Add User.
admin
role:dash
admin”. Note that if you intend on deploying apps, you’ll also need the “dash
licensed_user” role, and assigning this role consumes a license seat.To log into Dash Enterprise with this user, go to https://<your-dash-enterprise-server>
and enter the credentials that you saved in Keycloak. Dash Enterprise opens to the Portal. Go to the App Manager by selecting Apps > App Manager.
<img>
In this step, you’ll safeguard Dash Enterprise against usage that would cause the Kubernetes cluster to exceed the resources it can support. Specifically, you’ll add limits to the amount of pods and volumes (PVC) that can exist, temporarily preventing app developers from performing actions that would create more pods and volumes on the cluster when the limit is reached. To do so, you’ll use the System Limits setting in the Admin section of the App Manager. To learn how to calculate and set limits that are appropriate for your cluster, go to Pod and Volume Limits.
In order to upgrade Dash Enterprise, you’ll need a laptop or VM with internet access from which to run Plotly-provided, kubectl
-based scripts. The bootstrap node that you used as part of the installation already meets these requirements, so while it is safe to delete or decommission it, your organization may want to reuse it for upgrades. If reusing the bootstrap node, be sure to leave your config file on it (upgrade scripts will source it) and, if applicable, keep the outbound rule for dl.plotly.com
.
If you’re deleting or decommissioning the bootstrap node, keep a copy of your config file that you can move to a new bootstrap node when performing upgrades, and remember to allow communication to dl.plotly.com
on it.