Chapter 3. Usage


This chapter describes the necessary steps for using Red Hat Software Collections 3.8, and deploying applications that use Red Hat Software Collections.

3.1. Using Red Hat Software Collections

To run an executable from a particular Software Collection, type the following command at a shell prompt:
scl enable software_collection... 'command...'scl enable software_collection... 'command...'scl enable software_collection... 'command...'scl enable software_collection... 'command...'scl enable software_collection... 'command...'
Copy to Clipboard Toggle word wrap
Or, alternatively, use the following command:
scl enable software_collection... -- command...scl enable software_collection... -- command...scl enable software_collection... -- command...scl enable software_collection... -- command...scl enable software_collection... -- command...
Copy to Clipboard Toggle word wrap
Replace software_collection with a space-separated list of Software Collections you want to use and command with the command you want to run. For example, to execute a Perl program stored in a file named hello.pl with the Perl interpreter from the perl526 Software Collection, type:
~]$ scl enable rh-perl526 'perl hello.pl'
Hello, World!
Copy to Clipboard Toggle word wrap
You can execute any command using the scl utility, causing it to be run with the executables from a selected Software Collection in preference to their possible Red Hat Enterprise Linux system equivalents. For a complete list of Software Collections that are distributed with Red Hat Software Collections, see Table 1.1, “Red Hat Software Collections Components”.
To start a new shell session with executables from a selected Software Collection in preference to their Red Hat Enterprise Linux equivalents, type the following at a shell prompt:
scl enable software_collection... bashscl enable software_collection... bashscl enable software_collection... bash
Copy to Clipboard Toggle word wrap
Replace software_collection with a space-separated list of Software Collections you want to use. For example, to start a new shell session with the python27 and rh-postgresql12 Software Collections as default, type:
~]$ scl enable python27 rh-postgresql12 bash
Copy to Clipboard Toggle word wrap
The list of Software Collections that are enabled in the current session is stored in the $X_SCLS environment variable, for instance:
~]$ echo $X_SCLS
python27 rh-postgresql12
Copy to Clipboard Toggle word wrap
For a complete list of Software Collections that are distributed with Red Hat Software Collections, see Table 1.1, “Red Hat Software Collections Components”.
In Red Hat Enterprise Linux 7, init scripts have been replaced by systemd service unit files, which end with the .service file extension and serve a similar purpose as init scripts. To start a service in the current session, execute the following command as root:
systemctl start software_collection-service_name.servicesystemctl start software_collection-service_name.servicesystemctl start software_collection-service_name.servicesystemctl start software_collection-service_name.servicesystemctl start software_collection-service_name.service
Copy to Clipboard Toggle word wrap
Replace software_collection with the name of the Software Collection and service_name with the name of the service you want to start.
To configure this service to start automatically at boot time, type the following command as root:
systemctl enable software_collection-service_name.servicesystemctl enable software_collection-service_name.servicesystemctl enable software_collection-service_name.servicesystemctl enable software_collection-service_name.servicesystemctl enable software_collection-service_name.service
Copy to Clipboard Toggle word wrap
For example, to start the postgresql service from the rh-postgresql12 Software Collection and enable it at boot time, type as root:
~]# systemctl start rh-postgresql12-postgresql.service
~]# systemctl enable rh-postgresql12-postgresql.service
Copy to Clipboard Toggle word wrap
For more information on how to manage system services in Red Hat Enterprise Linux 7, refer to the Red Hat Enterprise Linux 7 System Administrator's Guide. For a complete list of Software Collections that are distributed with Red Hat Software Collections, see Table 1.1, “Red Hat Software Collections Components”.
Every Software Collection contains a general manual page that describes the content of this component. Each manual page has the same name as the component and it is located in the/opt/rh directory.
To read a manual page for a Software Collection, type the following command:
scl enable software_collection 'man software_collection'scl enable software_collection 'man software_collection'scl enable software_collection 'man software_collection'scl enable software_collection 'man software_collection'scl enable software_collection 'man software_collection'
Copy to Clipboard Toggle word wrap
Replace software_collection with the particular Red Hat Software Collections component. For example, to display the manual page for rh-mariadb105, type:
~]$ scl enable rh-mariadb105 "man rh-mariadb105"
Copy to Clipboard Toggle word wrap
In general, you can use one of the following two approaches to deploy an application that depends on a component from Red Hat Software Collections in production:
  • Install all required Software Collections and packages manually and then deploy your application, or
  • Create a new Software Collection for your application and specify all required Software Collections and other packages as dependencies.
For more information on how to manually install individual Red Hat Software Collections components, see Section 2.2, “Installing Red Hat Software Collections”. For further details on how to use Red Hat Software Collections, see Section 3.1, “Using Red Hat Software Collections”. For a detailed explanation of how to create a custom Software Collection or extend an existing one, read the Red Hat Software Collections Packaging Guide.
Container images based on Red Hat Software Collections include applications, daemons, and databases. The images can be run on Red Hat Enterprise Linux 7 Server and Red Hat Enterprise Linux Atomic Host. For information about their usage, see Using Red Hat Software Collections 3 Container Images. For details regarding container images based on Red Hat Software Collections versions 2.4 and earlier, see Using Red Hat Software Collections 2 Container Images.
Note that only the latest version of each container image is supported.
The following container images are available with Red Hat Software Collections 3.8:
  • rhscl/devtoolset-12-toolchain-rhel7 (available since November 2022)
  • rhscl/devtoolset-12-perftools-rhel7 (available since November 2022)
  • rhscl/nginx-120-rhel7
  • rhscl/redis-6-rhel7
The following container images are based on Red Hat Software Collections 3.7:
  • rhscl/mariadb-105-rhel7
  • rhscl/postgresql-13-rhel7
  • rhscl/ruby-30-rhel7
The following container images are based on Red Hat Software Collections 3.6:
  • rhscl/httpd-24-rhel7
  • rhscl/nodej-14-rhel7
  • rhscl/perl-530-rhel7
  • rhscl/php-73-rhel7
The following container images are based on Red Hat Software Collections 3.5:
  • rhscl/python-38-rhel7
  • rhscl/varnish-6-rhel7
The following container image is based on Red Hat Software Collections 3.4:
  • rhscl/postgresql-12-rhel7
The following container image is based on Red Hat Software Collections 3.2:
  • rhscl/mysql-80-rhel7
The following container image is based on Red Hat Software Collections 3.1:
  • rhscl/postgresql-10-rhel7
The following container image is based on Red Hat Software Collections 2:
  • rhscl/s2i-base-rhel7
Back to top
Red Hat logoGithubredditYoutubeTwitter

Learn

Try, buy, & sell

Communities

About Red Hat Documentation

We help Red Hat users innovate and achieve their goals with our products and services with content they can trust. Explore our recent updates.

Making open source more inclusive

Red Hat is committed to replacing problematic language in our code, documentation, and web properties. For more details, see the Red Hat Blog.

About Red Hat

We deliver hardened solutions that make it easier for enterprises to work across platforms and environments, from the core datacenter to the network edge.

Theme

© 2025 Red Hat