Available as of Rancher v2.5
Fleet is GitOps at scale. Fleet is designed to manage up to a million clusters. It’s also lightweight enough that it works great for a single cluster too, but it really shines when you get to a large scale. By large scale we mean either a lot of clusters, a lot of deployments, or a lot of teams in a single organization.
Fleet is a separate project from Rancher, and can be installed on any Kubernetes cluster with Helm.
For information about how Fleet works, see this page.
Accessing Fleet in the Rancher UI
Fleet comes preinstalled in Rancher v2.5. Users can leverage continuous delivery to deploy their applications to the Kubernetes clusters in the git repository without any manual operation by following gitops practice. For additional information on Continuous Delivery and other Fleet troubleshooting tips, refer here.
Follow the steps below to access Continuous Delivery in the Rancher UI:
Click Cluster Explorer in the Rancher UI.
In the top left dropdown menu, click Cluster Explorer > Continuous Delivery.
Select your namespace at the top of the menu, noting the following:
By default, fleet-default is selected which includes all downstream clusters that are registered through Rancher.
You may switch to fleet-local, which only contains the local cluster, or you may create your own workspace to which you may assign and move clusters.
You can then manage clusters by clicking on Clusters on the left navigation bar.
Click on Gitrepos on the left navigation bar to deploy the gitrepo into your clusters in the current workspace.
Once the gitrepo is deployed, you can monitor the application through the Rancher UI.
Available as of v2.5.6
For details on support for clusters with Windows nodes, see this page.
The Fleet Helm charts are available here.
Using Fleet Behind a Proxy
Available as of v2.5.8
For details on using Fleet behind a proxy, see this page.
Helm Chart Dependencies
In order for Helm charts with dependencies to deploy successfully, you must run a manual command (as listed below), as it is up to the user to fulfill the dependency list. If you do not do this and proceed to clone your repository and run
helm install, your installation will fail because the dependencies will be missing.
The Helm chart in the git repository must include its dependencies in the charts subdirectory. You must either manually run
helm dependencies update $chart OR run
helm dependencies build $chart locally, then commit the complete charts directory to your git repository. Note that you will update your commands with the applicable parameters
Known Issue: Fleet becomes inoperable after a restore using the backup-restore-operator. We will update the community once a permanent solution is in place.
- Find the two service account tokens listed in the fleet-controller and the fleet-controller-bootstrap service accounts. These are under the fleet-system namespace of the local cluster.
- Remove the non-existent token secret. Doing so allows for only one entry to be present for the service account token secret that actually exists.
- Delete the fleet-controller Pod in the fleet-system namespace to reschedule.
- After the service account token issue is resolved, you can force redeployment of the fleet-agents. In the Rancher UI, go to ☰ > Cluster Management, click on Clusters page, then click Force Update.
- If the fleet-agent bundles remain in a
Modifiedstate after Step 4, update the field
spec.forceSyncGenerationfor the fleet-agent bundle to force re-creation.
Known Issue: clientSecretName and helmSecretName secrets for Fleet gitrepos are not included in the backup nor restore created by the backup-restore-operator. We will update the community once a permanent solution is in place.
Temporary Workaround: By default, user-defined secrets are not backed up in Fleet. It is necessary to recreate secrets if performing a disaster recovery restore or migration of Rancher into a fresh cluster. To modify resourceSet to include extra resources you want to backup, refer to docs here.
The Fleet documentation is at https://fleet.rancher.io/.