Rancher Desktop is an open-source project to bring Kubernetes and container management to the desktop. Windows, macOS and Linux versions of Rancher Desktop are available for download, though do note that the Linux version is considered a tech preview.
Rancher Desktop provides the following features in the form of a desktop application:
- The version of Kubernetes you choose
- Ability to test upgrading Kubernetes to a new version and see how your workloads respond
- Run containers, and build, push, and pull images (powered by nerdctl)
- Expose an application in Kubernetes for local access
All of this is wrapped in an open-source application.
You can download the application for macOS, Windows and Linux on the releases page.
Running on Windows requires Windows Subsystem for Linux (WSL2). This will be installed automatically during Rancher Desktop installation.
Note, development builds are available from the CI system. Development builds are not signed.
For Linux, you will find both .DEB and .RPM packages attached as an asset for the most recent version.
Recommended
OS | Memory | CPU |
---|---|---|
macOS | 8GB | 4CPU |
Windows | 8GB | 4CPU |
Linux | 8GB | 4CPU |
OS versions we're currently using for development/testing:
OS | Version |
---|---|
macOS | Catalina 10.15 or higher |
Windows | Home build 1909 or higher |
Ubuntu | Ubuntu 20.04 or higher |
openSUSE | Leap 15.3 or higher |
Fedora | Fedora 33 or higher |
Note: Feel free to use a different OS version that haven't been listed. We are currently developing/testing Rancher Desktop on the listed OS and you can use it as a reference.
Rancher Desktop is an Electron application with the primary business logic written in TypeScript and JavaScript. It leverages several other pieces of technology to provide the platform elements which include k3s, kubectl, nerdctl WSL, qemu, and more. The application wraps numerous pieces of technology to provide one cohesive application.
Rancher can be built from source on macOS, Windows or Linux. Cross-compilation is currently not supported. The following provides some detail on building.
Rancher Desktop is an Electron and Node.js application. Node.js v16 is recommended to build the source. On Windows, Go is also required. On Linux, QEMU is required at runtime.
There are two options for building from source on Windows: with a Development VM Setup or Manual Development Environment Setup with an existing Windows installation.
-
Download a Microsoft Windows 10 development virtual machine.
-
Open a PowerShell prompt (hit Windows Key +
X
and openWindows PowerShell
). -
Run the automated setup script:
Set-ExecutionPolicy RemoteSigned -Scope CurrentUser iwr -useb 'https://github.com/rancher-sandbox/rancher-desktop/raw/main/scripts/windows-setup.ps1' | iex
-
Close the privileged PowerShell prompt.
-
Ensure
msbuild_path
andmsvs_version
are configured correctly in.npmrc
file. Run the following commands to set these properties:npm config set msvs_version <visual-studio-version-number> npm config set msbuild_path <path/to/MSBuild.exe>
You are now ready to clone the repository and run npm install
.
-
Install Windows Subsystem for Linux (WSL) on your machine. Skip this step, if WSL is already installed.
-
Open a PowerShell prompt (hit Windows Key +
X
and openWindows PowerShell
). -
Install Scoop via
iwr -useb get.scoop.sh | iex
. -
Install git, go, nvm, and unzip via
scoop install git go nvm python unzip
. Check node version withnvm list
. If node v16 is not installed or set as the current version, then install usingnvm install 16
and set as current usingnvm use 16.xx.xx
. -
Install Visual Studio 2017 or higher. Make sure you have the
Windows SDK
component installed. This Visual Studio docs describes steps to install components. -
Ensure
msbuild_path
andmsvs_version
are configured correctly in.npmrc
file. Run the following commands to set these properties:npm config set msvs_version <visual-studio-version-number> npm config set msbuild_path <path/to/MSBuild.exe>
Use the following commands. The former is needed the first time or after an update is pulled from upstream. The latter is needed for follow-up starts.
npm install
npm run dev
To build the distributable (application bundle on macOS, installer on Windows),
run npm run build
.
On Linux npm run build
produces a zip file including the built binaries. To build the
distributable artifacts (RPM, Deb or AppImage) the Open Build Service is used.
OBS makes use of the packaging recipes under packaging/linux
folder of this
repository together with the zip file including all built binaries.
Use the following commands to run unit tests and e2e tests.
npm test
npm run test:e2e