You're reading the documentation for an older, but still supported, version of ROS 2. For information on the latest version, please have a look at Iron.
Options for installing ROS 2 Foxy Fitzroy:
Binaries are only created for the Tier 1 operating systems listed in REP-2000. If you are not running any of the following operating systems you may need to build from source or use a container solution to run ROS 2 on your platform.
We provide ROS 2 binary packages for the following platforms:
Ubuntu Linux - Focal Fossa (20.04)
Debian packages (recommended)
Building from source
We support building ROS 2 from source on the following platforms:
Which install should you choose?
Installing from binary packages or from source will both result in a fully-functional and usable ROS 2 install. Differences between the options depend on what you plan to do with ROS 2.
Binary packages are for general use and provide an already-built install of ROS 2. This is great for people who want to dive in and start using ROS 2 as-is, right away.
Linux users have two options for installing binary packages:
Installing from Debian packages is the recommended method. It’s more convenient because it installs its necessary dependencies automatically. It also updates alongside regular system updates.
However, you need root access in order to install Debian packages. If you don’t have root access, the “fat” archive is the next best choice.
macOS and Windows users who choose to install from binary packages only have the “fat” archive option (Debian packages are exclusive to Ubuntu/Debian).
Building from source is meant for developers looking to alter or explicitly omit parts of ROS 2’s base. It is also recommended for platforms that don’t support binaries. Building from source also gives you the option to install the absolute latest version of ROS 2.
Contributing to ROS 2 core?
If you plan to contribute directly to ROS 2 core packages, you can install the latest development from source which shares installation instructions with the Rolling distribution.