Installing Flyte
First, add the Flyte chart repo to Helm:
helm repo add flyteorg https://flyteorg.github.io/flyte
Then download and update a values file:
curl -sL https://raw.githubusercontent.com/flyteorg/flyte/master/charts/flyte-binary/eks-starter.yaml
Both the flyte-binary and flyte-core charts include example YAML values files for different cloud environments.
You can provide your own values file overriding the base config. The minimum information required for each chart is detailed in the following table:
Required config | flyte-binary key |
flyte-core key |
Notes |
---|---|---|---|
Database password | configuration.database.password |
userSettings.dbPassword |
Default Postgres username: postgres |
Database server | configuration.database.host |
userSettings.dbHost (GCP and Azure), userSettings.rdsHost (EKS) |
Default DB name: flyteadmin |
S3 storage bucket | configuration.storage.metadataContainer / configuration.storage.userDataContainer |
userSettings.bucketName / userSettings.rawDataBucketName |
You can use the same bucket for both |
Once adjusted your values file, install the chart:
Example:
helm install flyte-backend flyteorg/flyte-binary \
--dry-run --namespace flyte --values eks-starter.yaml
When ready to install, remove the --dry-run
switch.
Verify the Installation
The base values files provide only the simplest installation of Flyte. The core functionality and scalability of Flyte will be there but not Ingress, authentication or DNS/SSL is configured.
Port Forward Flyte Service
To verify the installation you can to port forward the Kubernetes service:
Example:
kubectl -n flyte port-forward service/flyte-binary-http 8088:8088
kubectl -n flyte port-forward service/flyte-binary-grpc 8089:8089
You should be able to navigate to http://localhost:8088/console
.
The Flyte server operates on two different ports, one for HTTP
traffic and the other for gRPC
, which is why we port forward both.
Connect to your Flyte instance
- Generate a new configuration file (in case you don’t have one already) using
flytectl config init
.
This will produce a file like the following:
admin:
# For GRPC endpoints you might want to use dns:///flyte.myexample.com
endpoint: dns:///localhost:8089 #the gRPC endpoint
authType: Pkce
insecure: true
logger:
show-source: true
level: 0
- Test your connection using:
flytectl get projects
From this point on you can start running workflows!