Other Rust Installation Methods
Which installer should you use?
Rust runs on many platforms, and there are many ways to install Rust. If you want to install Rust in the most straightforward, recommended way, then follow the instructions on the main installation page.
That page describes installation via rustup
, a tool that manages multiple
Rust toolchains in a consistent way across all platforms Rust supports. Why
might one not want to install using those instructions?
- Offline installation.
rustup
downloads components from the internet on demand. If you need to install Rust without access to the internet,rustup
is not suitable. - Preference for the system package manager. On Linux in particular, but also on macOS with Homebrew, MacPorts or pkgsrc, and Windows with Chocolatey or Scoop, developers sometimes prefer to install Rust with their platform’s package manager.
- Preference against
curl | sh
. On Unix, we usually installrustup
by running a shell script viacurl
. Some have concerns about the security of this arrangement and would prefer to download and run the installer themselves. - Validating signatures. Although
rustup
performs its downloads over HTTPS, the only way to verify the signatures of Rust installers today is to do so manually with the standalone installers. - GUI installation and integration with “Add/Remove Programs” on Windows.
rustup
runs in the console and does not register its installation like typical Windows programs. If you prefer a more typical GUI installation on Windows there are standalone.msi
installers. In the futurerustup
will also have a GUI installer on Windows.
Rust’s platform support is defined in three tiers, which correspond closely
with the installation methods available: in general, the Rust project provides
binary builds for all tier 1 and tier 2 platforms, and they are all installable
via rustup
. Some tier 2 platforms though have only the standard library
available, not the compiler itself; that is, they are cross-compilation targets
only; Rust code can run on those platforms, but they do not run the compiler
itself. Such targets can be installed with the rustup target add
command.
Other ways to install rustup
The way to install rustup
differs by platform:
- On Unix, run
curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh
in your shell. This downloads and runsrustup-init.sh
, which in turn downloads and runs the correct version of therustup-init
executable for your platform. - On Windows, download and run
rustup-init.exe
.
rustup-init
can be configured interactively, and all options can additionally
be controlled by command-line arguments, which can be passed through the shell
script. Pass --help
to rustup-init
as follows to display the arguments
rustup-init
accepts:
curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh -s -- --help
If you prefer not to use the shell script, you may directly download
rustup-init
for the platform of your choice:
- aarch64-linux-android
- aarch64-unknown-linux-gnu
- aarch64-unknown-linux-musl
- arm-linux-androideabi
- arm-unknown-linux-gnueabi
- arm-unknown-linux-gnueabihf
- armv7-linux-androideabi
- armv7-unknown-linux-gnueabihf
- i686-apple-darwin
- i686-linux-android
- i686-pc-windows-gnu
- i686-pc-windows-msvc
- i686-unknown-linux-gnu
- loongarch64-unknown-linux-gnu
- mips-unknown-linux-gnu
- mips64-unknown-linux-gnuabi64
- mips64el-unknown-linux-gnuabi64
- mipsel-unknown-linux-gnu
- powerpc-unknown-linux-gnu
- powerpc64-unknown-linux-gnu
- powerpc64le-unknown-linux-gnu
- s390x-unknown-linux-gnu
- x86_64-apple-darwin
- x86_64-linux-android
- x86_64-pc-windows-gnu
- x86_64-pc-windows-msvc
- x86_64-unknown-freebsd
- x86_64-unknown-illumos
- x86_64-unknown-linux-gnu
- x86_64-unknown-linux-musl
- x86_64-unknown-netbsd
Standalone installers
The official Rust standalone installers contain a single release of Rust, and
are suitable for offline installation. They come in three forms: tarballs
(extension .tar.xz
), that work in any Unix-like environment, Windows
installers (.msi
), and Mac installers (.pkg
). These installers come with
rustc
, cargo
, rustdoc
, the standard library, and the standard
documentation, but do not provide access to additional cross-targets like
rustup
does.
The most common reasons to use these are:
- Offline installation
- Preferring a more platform-integrated, graphical installer on Windows
Each of these binaries is signed with the Rust signing key, which is
available on keybase.io, by the Rust build infrastructure, with GPG. In the
tables below, the .asc
files are the signatures.
Past releases can be found in the archive.
Source code
If you want to build the Rust toolchain from source code, you can use the following links to download source code tarballs.
Channel | Archives + Signatures |
---|---|
stable (1.82.0) | tar.xz tar.xz.asc |
beta | tar.xz tar.xz.asc |
nightly | tar.xz tar.xz.asc |
If you want to make sure that the published source tarball matches what is in the
rust
git repository, you can use the following script as a template:
Script for reproducing source tarball contents
#!/bin/bash
set -e
# You can use either a commit SHA or a stable release version (e.g. 1.XY.Z)
TAG=a8cfc83801301c2b4f0fd030192e268eeb15d473
# TAG=1.77.1
# Clone Rust toolchain repository from GitHub
git clone https://github.com/rust-lang/rust
cd rust
git reset --hard ${TAG}
cat >config.toml << EOF
[rust]
# Use for a commit SHA
channel = "nightly"
# Use for a stable release
# channel = "stable"
[dist]
compression-formats = ["xz"]
compression-profile = "fast"
EOF
# Build the source tarball from git into build/dist/
./x dist rustc-src
# Download source tarball for a commit SHA
wget https://ci-artifacts.rust-lang.org/rustc-builds/${TAG}/rustc-nightly-src.tar.xz
# Download a source tarball for a stable release
# wget https://static.rust-lang.org/dist/rustc-${TAG}-src.tar.xz
# Decompress the tarballs and check if they're the same
xz --decompress rustc-*-src.tar.xz
xz --decompress build/dist/rustc-*-src.tar.xz
diff rustc-*-src.tar build/dist/rustc-*-src.tar