Introduction and Prerequisites
In this tutorial, you will install the GNU Compiler Collection 8.2 from the Red Hat Developer Toolset (DTS) and build a simple C++ Hello World application. This tutorial should take less than 30 minutes to complete.
Before you begin, you will need a current Red Hat Enterprise Linux 7 workstation or server subscription that allows you to download software and get updates from Red Hat. If you don’t have an active subscription, register and obtain the RHEL Developer Suite (includes RHEL server) from here.
If you encounter difficulties at any point, see Troubleshooting and FAQ.
1. Enable necessary software repositories
In this step, you will configure your system to obtain software, including the Red Hat DTS, latest dynamic languages, and open source databases from the Red Hat Software Collection repository by using the command line interface.
You can add or remove software repositories from the command line using the subscription-manager
tool as the root user. Use the --list
option to view the available software repositories and verify that you have access to RHSCL, which includes DTS:
$ su - # subscription-manager repos --list | egrep devtools
If you don’t see any RHSCL repositories in the list, your subscription might not include it. See Troubleshooting and FAQ for more information.
If you are using a desktop edition of Red Hat Enterprise Linux, change -server-
to -desktop-
in the following commands:
# subscription-manager repos --enable rhel-server-devtools-7-rpms # subscription-manager repos --enable rhel-7-server-optional-rpms
2. Setup your development environment
In this next step you will use a single command to download and install GCC 8.2, and other development tools that are part of Red Hat Developer Toolset. The length of time this step takes depends on the speed of your Internet connection and your system. With a reasonably fast connection, this step should complete in well under 5 minutes.
To install all components, type:
$ su - # yum install devtoolset-8
If you want to install a subset of components, see the instructions here.
Note: You will still use devtoolset-8 as the name of the software collection in all scl commands. Only the name of the meta-package to be installed by yum changes.
3. Hello World and your first application
Using DTS C++ from the command line
The GNU C++ compiler is run with the command, g++. You need to add DTS to your environment with scl enable in a Terminal
window. Also see Permanently adding DTS to your Development Environment for more information.
$ scl enable devtoolset-8 bash
Now create hello.cpp
using a text editor such as vi
, nano
, or gedit
with the following content:
hello.cpp
#include <iostream>
using namespace std;
int main(int argc, char *argv[]) {
cout << "Hello, Red Hat Developer Program World!" << endl;
return 0;
}
Now compile and run the program:
$ g++ -o hello hello.cpp $ ./hello Hello, Red Hat Developer Program World!
For more information, see the GNU C++ Compiler section of the Red Hat Developer Toolset 8 User Guide.
Docker-formatted container images
Docker-formatted container
images can be used to run Red Hat Developer Toolset components inside virtual software containers, thus isolating them from the host system and allowing for their rapid deployment. For detailed description of the Red Hat Developer Toolset docker-formatted container images and Red Hat Developer Toolset dockerfiles
, see Using Red Hat Software Collections Container Images.
Working with the Red Hat Developer Toolset and Software Collection packages
The Red Hat Developer Toolset is delivered as a set of packages in the Red Hat Software Collection. The software packages in RHSCL are designed to allow multiple versions of software to be installed concurrently. To accomplish this, the desired package is added to your runtime environment as needed with the scl enable
command. When scl enable
runs, it modifies environment variables and then runs the specified command. The environmental changes only affect the command that is run by scl
and any processes that are run from that command. The steps in this tutorial run the command bash
to start a new interactive shell to work in the updated environment. The changes aren’t permanent. Typing exit
will return to the original shell with the original environment. Each time you login, or start a new terminal session, scl enable
needs to be run again.
While it is possible to change the system profile to make RHSCL packages part of the system’s global environment, this is not recommended. Doing this can cause conflicts and unexpected problems with other applications because the system version of the package is obscured by having the RHSCL version in the path first.
Permanently adding DTS to your development environment
To make DTS a permanent part of your development environment, you can add it to the login script for your specific user ID. This is the recommend approach for development, because only processes run under your user ID will be affected.
Using your preferred text editor, add the following line to the end of ~/.bashrc
:
source scl_source enable devtoolset-8
After logging out and logging back in again, you can verify that the DTS GCC is in your path by running which g++
or g++ --version
.
$ which g++ /opt/rh/devtoolset-4/root/usr/bin/g++
$ g++ -v g++ (GCC) 8.2 20181112 (Red Hat 8.2.1-0)
Working with Software Collection packages
These tools are packaged as software collections which are designed to allow multiple versions of software to be installed concurrently. To accomplish this, the desired package is added to your runtime environment as needed with the scl enable
command. When scl enable
runs, it modifies environment variables and then runs the specified command. The environmental changes only affect the command that is run by scl
and any processes that are run from that command. The steps in this tutorial run the command bash
to start a new interactive shell to work in the updated environment. The changes aren’t permanent. Typing exit
will return to the original shell with the original environment. Each time you login, or start a new terminal session, scl enable
needs to be run again.
While it is possible to change the system profile to make RHSCL packages part of the system’s global environment, this is not recommended. Doing this can cause conflicts and unexpected problems with other applications because the system version of the package is obscured by having the RHSCL version in the path first.
Learn more about Red Hat Software Collections
Red Hat Software Collections deliver the latest stable versions of dynamic languages, open source databases, and web development tools that can be deployed alongside those included in Red Hat Enterprise Linux. Red Hat Software Collections is available with select Red Hat Enterprise Linux subscriptions and has a three-year life cycle to allow rapid innovation without sacrificing stability. For more information:
-
Red Hat Software Collections Packaging Guide — The packaging guide for Red Hat Software Collections explains the concept of software collections, documents the scl utility, and provides a detailed explanation of how to create a custom software collection or extend an existing one.
-
Red Hat Software Collections Release Notes — The release notes for Red Hat Software Collections document known problems, possible issues, and other important information available at the time of release of the content set. They also contain useful information on installing, rebuilding, and migrating.
-
How to use Red Hat Software Collections (RHSCL), Red Hat Developer Subscriptions, or Clang/LLVM, Go, Rust compilers — This article lists which Red Hat Enterprise Linux subscriptions include access to Red Hat Software Collections, Developer Toolset (with GCC), Clang/LLVM, Go, and Rust.
You can view the list of packages available in RHSCL by running:
$ yum --disablerepo="*" --enablerepo="rhel-server-rhscl-7-rpms" list available
Developing with Red Hat Enterprise Linux
Red Hat Enterprise Linux 7 Developer Guide — The developer guide for Red Hat Enterprise Linux 7 provides an introduction to application development tools and using source code management tools such as Git in Red Hat Enterprise Linux 7.
Become a Red Hat developer and join the Red Hat Developer Program
Red Hat delivers the resources and ecosystem of experts to help you be more productive and build great solutions. Register for free at developers.redhat.com.
Troubleshooting and FAQ
-
As a developer, how can I get a Red Hat Enterprise Linux subscription that includes the Clang/LLVM, Go, or Rust Compilers?
Developers can get a no-cost Red Hat Enterprise Linux Developer subscription for development purposes by registering and downloading through developers.redhat.com. We recommend you follow our Getting Started Guide which covers downloading and installing Red Hat Enterprise Linux on a physical system or virtual machine (VM) using your choice of VirtualBox, VMware, Microsoft Hyper-V, or Linux KVM/Libvirt. For more information, see Frequently asked questions: no-cost Red Hat Enterprise Linux Developer subscription.
-
I can’t find the devtools or RHSCL repository on my system.
Some Red Hat Enterprise Linux subscriptions do not include access to Software Collections or development tools. For a list of what subscriptions are included see How to use Red Hat Software Collections (RHSCL), Red Hat Developer Toolset (DTS, etc.).
The name of the repository depends on whether you have a server or workstation version of Red Hat Enterprise Linux installed. You can use subscription-manager to view the available software repositories and verify that you have access to RHSCL and devtools:
$ su - # subscription-manager repos --list | egrep rhscl # subscription-manager repos --list | egrep devtools
-
When I run yum install package (go-toolset-7, llvm-toolset-7, rust-toolset-7), it fails due to a missing dependency.
Some software collections require packages that are in the devtools RPMs repository, which is not enabled by default. See Step 1 above, for how to enable both the applicable RPMs and repositories.
-
How can I view the Go manual pages?
The Go compiler help command provides information on its usage. To show the help index:
$ scl enable go-toolset-7 'go help'
-
How can I find out what RHSCL packages are installed?
scl --list
will show the list of RHSCL packages that have been installed, whether they are enabled or not.
$ scl --list