Administering Red Hat Satellite
A guide to administering Red Hat Satellite.
Abstract
Providing Feedback on Red Hat Documentation
We appreciate your feedback on our documentation. Let us know how we can improve it.
Use the Create Issue form in Red Hat Jira to provide your feedback. The Jira issue is created in the Red Hat Satellite Jira project, where you can track its progress.
Prerequisites
- Ensure you have registered a Red Hat account.
Procedure
- Click the following link: Create Issue. If Jira displays a login error, log in and proceed after you are redirected to the form.
- Complete the Summary and Description fields. In the Description field, include the documentation URL, chapter or section number, and a detailed description of the issue. Do not modify any other fields in the form.
- Click Create.
Chapter 1. Accessing Red Hat Satellite
After Red Hat Satellite has been installed and configured, use the Satellite web UI interface to log in to Satellite for further configuration.
1.1. Importing the Katello Root CA Certificate
The first time you log in to Satellite, you might see a warning informing you that you are using the default self-signed certificate and you might not be able to connect this browser to Satellite until the root CA certificate is imported in the browser. Use the following procedure to locate the root CA certificate on Satellite and to import it into your browser.
To use the CLI instead of the Satellite web UI, see CLI Procedure.
Prerequisite
- Your Red Hat Satellite is installed and configured.
Procedure
Identify the fully qualified domain name of your Satellite Server:
# hostname -f
Access the
pub
directory on your Satellite Server using a web browser pointed to the fully qualified domain name:https://satellite.example.com/pub
- When you access Satellite for the first time, an untrusted connection warning displays in your web browser. Accept the self-signed certificate and add the Satellite URL as a security exception to override the settings. This procedure might differ depending on the browser being used. Ensure that the Satellite URL is valid before you accept the security exception.
-
Select
katello-server-ca.crt
. - Import the certificate into your browser as a certificate authority and trust it to identify websites.
CLI procedure
From the Satellite CLI, copy the
katello-server-ca.crt
file to the machine you use to access the Satellite web UI:# scp /var/www/html/pub/katello-server-ca.crt username@hostname:remotefile
-
In the browser, import the
katello-server-ca.crt
certificate as a certificate authority and trust it to identify websites.
1.2. Logging in to Satellite
Use the web user interface to log in to Satellite for further configuration.
Prerequisite
- Ensure that the Katello root CA certificate is installed in your browser. For more information, see Section 1.1, “Importing the Katello Root CA Certificate”.
Procedure
Access Satellite Server using a web browser pointed to the fully qualified domain name:
https://satellite.example.com/
- Enter the user name and password created during the configuration process. If a user was not created during the configuration process, the default user name is admin. If you have problems logging in, you can reset the password. For more information, see Section 1.8, “Resetting the Administrative User Password”.
1.3. Using Red Hat Identity Management credentials to log in to the Satellite Hammer CLI
This section describes how to log in to your Satellite Hammer CLI with your Red Hat Identity Management (IdM) login and password.
Prerequisites
- You have enrolled your Satellite Server into Red Hat Identity Management and configured it to use Red Hat Identity Management for authentication. More specifically, you have enabled access both to the Satellite web UI and the Satellite API. For more information, see Using Red Hat Identity Management in Installing Satellite Server in a Connected Network Environment.
- The host on which you run this procedure is configured to use Red Hat Identity Management credentials to log users in to your Satellite Hammer CLI. For more information, see Configuring the Hammer CLI to Use Red Hat Identity Management User Authentication in Installing Satellite Server in a Connected Network Environment.
- The host is an Red Hat Identity Management client.
- An Red Hat Identity Management server is running and reachable by the host.
Procedure
Obtain a Kerberos ticket-granting ticket (TGT) on behalf of a Satellite user:
$ kinit idm_user
WarningIf, when you were setting Red Hat Identity Management to be the authentication provider, you enabled access to both the Satellite API and the Satellite web UI, an attacker can now obtain an API session after the user receives the Kerberos TGT. The attack is possible even if the user did not previously enter the Satellite login credentials anywhere, for example in the browser.
If automatic negotiate authentication is not enabled, use the TGT to authenticate to Hammer manually:
$ hammer auth login negotiate
Optional: Destroy all cached Kerberos tickets in the collection:
$ kdestroy -A
You are still logged in, even after destroying the Kerberos ticket.
Verification
Use any
hammer
command to ensure that the system does not ask you to authenticate again:$ hammer host list
To log out of Hammer, enter: hammer auth logout
.
1.4. Using Red Hat Identity Management credentials to log in to the Satellite web UI with a Firefox browser
This section describes how to use the Firefox browser to log in to your Satellite web UI with your Red Hat Identity Management (IdM) login and password.
Prerequisites
- You have enrolled your Satellite Server into Red Hat Identity Management and configured the server to use Red Hat Identity Management for authentication. For more information, see Using Red Hat Identity Management in Installing Satellite Server in a Connected Network Environment.
- The host on which you are using a Firefox browser to log in to the Satellite web UI is an Red Hat Identity Management client.
- You have a valid Red Hat Identity Management login and password.
- Red Hat recommends using the latest stable Firefox browser.
- Your Firefox browser is configured for Single Sign-On (SSO). For more information, see Configuring Firefox to use Kerberos for single sign-on in Configuring authentication and authorization in Red Hat Enterprise Linux.
- An Red Hat Identity Management server is running and reachable by the host.
Procedure
Obtain the Kerberos ticket granting ticket (TGT) for yourself using your Red Hat Identity Management credentials:
$ kinit idm_user Password for idm_user@EXAMPLE.COM:
In your browser address bar, enter the URL of your Satellite Server.
You are logged in automatically.
Alternatively, you can skip the first two steps and enter your login and password in the fields displayed on the Satellite web UI. This is also the only option if the host from which you are accessing the Satellite web UI is not an Red Hat Identity Management client.
1.5. Using Red Hat Identity Management credentials to log in to the Satellite web UI with a Chrome browser
This section describes how to use a Chrome browser to log in to your Satellite web UI with your Red Hat Identity Management login and password.
Prerequisites
- You have enrolled your Satellite Server into Red Hat Identity Management and configured the server to use Red Hat Identity Management for authentication. For more information, see Using Red Hat Identity Management in Installing Satellite Server in a Connected Network Environment.
- The host on which you are using the Chrome browser to log in to the Satellite web UI is an Red Hat Identity Management client.
- You have a valid Red Hat Identity Management login and password.
- Red Hat recommends using the latest stable Chrome browser.
- An Red Hat Identity Management server is running and reachable by the host.
Procedure
Enable the Chrome browser to use Kerberos authentication:
$ google-chrome --auth-server-whitelist=".example.com" --auth-negotiate-delegate-whitelist=”.example.com"
NoteInstead of allowlisting the whole domain, you can also allowlist a specific Satellite Server.
Obtain the Kerberos ticket-granting ticket (TGT) for yourself using your Red Hat Identity Management credentials:
$ kinit idm_user Password for idm_user@_EXAMPLE.COM:
In your browser address bar, enter the URL of your Satellite Server.
You are logged in automatically.
Alternatively, you can skip the first three steps and enter your login and password in the fields displayed on the Satellite web UI. This is also the only option if the host from which you are accessing the Satellite web UI is not an Red Hat Identity Management client.
1.7. Changing the Password
These steps show how to change your password.
Procedure
- Click your user name at the top right corner.
- Select My Account from the menu.
- In the Current Password field, enter the current password.
- In the Password field, enter a new password.
- In the Verify field, enter the new password again.
- Click the Submit button to save your new password.
1.8. Resetting the Administrative User Password
Use the following procedures to reset the administrative password to randomly generated characters or to set a new administrative password.
To Reset the Administrative User Password
- Log in to the base operating system where Satellite Server is installed.
Enter the following command to reset the password:
# foreman-rake permissions:reset Reset to user: admin, password: qwJxBptxb7Gfcjj5
- Use this password to reset the password in the Satellite web UI.
Edit the
~/.hammer/cli.modules.d/foreman.yml
file on Satellite Server to add the new password:# vi ~/.hammer/cli.modules.d/foreman.yml
Unless you update the ~/.hammer/cli.modules.d/foreman.yml
file, you cannot use the new password with Hammer CLI.
To Set a New Administrative User Password
- Log in to the base operating system where Satellite Server is installed.
To set the password, enter the following command:
# foreman-rake permissions:reset password=new_password
Edit the
~/.hammer/cli.modules.d/foreman.yml
file on Satellite Server to add the new password:# vi ~/.hammer/cli.modules.d/foreman.yml
Unless you update the ~/.hammer/cli.modules.d/foreman.yml
file, you cannot use the new password with Hammer CLI.
1.9. Setting a Custom Message on the Login Page
Procedure
- In the Satellite web UI, navigate to Administer > Settings, and click the General tab.
- Click the edit button next to Login page footer text, and enter the desired text to be displayed on the login page. For example, this text may be a warning message required by your company.
- Click Save.
- Log out of the Satellite web UI and verify that the custom text is now displayed on the login page below the Satellite version number.
Chapter 2. Starting and Stopping Red Hat Satellite
Satellite provides the satellite-maintain service
command to manage Satellite services from the command line. This is useful when creating a backup of Satellite. For more information on creating backups, see Chapter 12, Backing Up Satellite Server and Capsule Server.
After installing Satellite with the satellite-installer
command, all Satellite services are started and enabled automatically. View the list of these services by executing:
# satellite-maintain service list
To see the status of running services, execute:
# satellite-maintain service status
To stop Satellite services, execute:
# satellite-maintain service stop
To start Satellite services, execute:
# satellite-maintain service start
To restart Satellite services, execute:
# satellite-maintain service restart
Chapter 3. Cloning Satellite Server
You can clone your Satellite Server to create instances to test upgrades and migration of instances to a different machine or operating system. This is an optional step to provide more flexibility during the upgrade or migration.
You cannot use the Satellite clone tool on a Capsule Server. Instead, you must backup the existing Capsule Server, restore it on the target server, and then reconfigure Capsule Server.
If you create a new instance of the Satellite Server, decommission the old instances after restoring the backup. Cloned instances are not supposed to run in parallel in a production environment.
Terminology
Ensure that you understand the following terms:
- Source server
- The origin of the clone.
- Target server
- The new server that you copy files to and clone the source server to.
3.1. Cloning Process Overview
- Back up the source server.
- Clone the source server to the target server.
- Power off the source server.
- Update the network configuration on the target server to match the target server’s IP address with its new host name.
-
If any content hosts use the deprecated Katello Agent, restart the
goferd
service on all those content hosts and their Capsules to refresh the connection. - Test the new target server.
3.2. Prerequisites
To clone Satellite Server, ensure that you have the following resources available:
- A minimal install of Red Hat Enterprise Linux 8 to become the target server. Do not install Red Hat Enterprise Linux 8 software groups or third-party applications. Ensure that your server complies with all the required specifications. For more information, see Preparing your Environment for Installation in Installing Satellite Server in a Connected Network Environment.
-
A backup of your Satellite Server that you make using the
satellite-maintain backup
script. You can use a backup with or without Pulp data. - A Satellite subscription for the target server.
Before you begin cloning, ensure the following conditions exist:
- The target server is on an isolated network. This avoids unwanted communication with Capsule Servers and hosts.
- The target server has at least the same storage capacity as the source server.
Customized configuration files
If you have any customized configurations on your source server that are not managed by the satellite-installer
tool or Satellite backup process, you must manually back up these files.
3.3. Pulp Data Considerations
You can clone Satellite server without including Pulp data. However, for your cloned environment to work, you do require Pulp data. If the target server does not have Pulp data. it is not a fully working Satellite.
To transfer Pulp data to a target server, you have two options:
- Clone using backup with Pulp data
-
Clone using backup without Pulp data and copy
/var/lib/pulp
manually from the source server.
If your pulp_data.tar
file is greater than 500 GB, or if you use a slow storage system, such as NFS, and your pulp_data.tar
file is greater than 100 GB, do not include pulp_data.tar
in the backup because this can cause memory errors during extraction. Copy the pulp_data.tar
file from the source server to the target server.
To back up without Pulp data
Follow the steps in the procedure in Section 3.4, “Cloning Satellite Server” and replace the steps that involve cloning with Pulp data with the following steps:
Perform a backup with PostgreSQL databases active excluding the Pulp data:
# satellite-maintain backup offline --skip-pulp-content \ --assumeyes /var/backup
Stop and disable Satellite services:
# satellite-maintain service stop # satellite-maintain service disable
Copy the Pulp data to the target server:
# rsync --archive --partial --progress --compress \ /var/lib/pulp/ target_server.example.com:/var/lib/pulp/
Proceed to Section 3.4.2, “Cloning to the Target Server”.
3.4. Cloning Satellite Server
Use the following procedures to clone Satellite Server. Note that because of the high volume of data that you must copy and transfer as part of these procedures, it can take a significant amount of time to complete.
3.4.1. Preparing the source server for cloning
On the source server, complete the following steps:
Verify the Pool ID of your Satellite subscription:
# subscription-manager list --consumed \ --matches 'Red Hat Satellite'|grep "Pool ID:"|awk '{print $3}'
Note the Pool ID for later use.
Remove the Red Hat Satellite subscription:
# subscription-manager remove --serial=$(subscription-manager list \ --consumed \ --matches 'Red Hat Satellite'|grep "Serial:"|awk '{print $2}')
Determine the size of the Pulp data:
# du -sh /var/lib/pulp/
If you have less than 500 GB of Pulp data, perform a backup with PostgreSQL databases active including the Pulp data. If you have more than 500 GB of Pulp data, skip the following steps and complete the steps in Section 3.3, “Pulp Data Considerations” before you continue.
# satellite-maintain backup offline --assumeyes /var/backup
Stop and disable Satellite services:
# satellite-maintain service stop # satellite-maintain service disable
Proceed to Section 3.4.2, “Cloning to the Target Server”.
3.4.2. Cloning to the Target Server
To clone your server, complete the following steps on your target server:
-
The
satellite-clone
tool defaults to using/backup/
as the backup folder. If you copy to a different folder, update thebackup_dir
variable in the/etc/satellite-clone/satellite-clone-vars.yml
file. -
Place the backup files from the source Satellite in the
/backup/
folder on the target server. You can either mount the shared storage or copy the backup files to the/backup/
folder on the target server. - Power off the source server.
Enter the following commands to register to the Customer Portal, attach subscriptions, and enable only the required subscriptions:
# subscription-manager register your_customer_portal_credentials # subscription-manager attach --pool=pool_ID # subscription-manager repos --disable=* # subscription-manager repos --enable=rhel-8-for-x86_64-appstream-rpms \ --enable=rhel-8-for-x86_64-baseos-rpms \ --enable=satellite-maintenance-6.13-for-rhel-8-x86_64-rpms # dnf module enable satellite-maintenance:el8
Install the
satellite-clone
package:# dnf install satellite-clone
After you install the
satellite-clone
tool, you can adjust any configuration to suit your own deployment in the/etc/satellite-clone/satellite-clone-vars.yml
file.Run the
satellite-clone
tool:# satellite-clone
- Reconfigure DHCP, DNS, TFTP, and remote execution services. The cloning process disables these services on the target Satellite Server to avoid conflict with the source Satellite Server.
- Reconfigure and enable DHCP, DNS, and TFTP in the Satellite web UI. For more information, see Configuring External Services on Satellite Server in Installing Satellite Server in a Connected Network Environment.
-
Log in to the Satellite web UI, with the username
admin
and the passwordchangeme
. Immediately update the admin password to secure credentials. - Ensure that the correct organization is selected.
- In the Satellite web UI, navigate to Content > Subscriptions, then click Manage Manifest.
- Click the Refresh button, then click Close to return to the list of subscriptions.
- Verify that the available subscriptions are correct.
-
Follow the instructions in the
/usr/share/satellite-clone/logs/reassociate_capsules.txt
file to restore the associations between Capsules and their lifecycle environments. -
Update your network configuration, for example, DNS, to match the target server’s IP address with its new host name. The
satellite-clone
tool changes the host name to the source server’s host name. If you want to change the host name to something different, you can use thesatellite-change-hostname
tool. For more information, see Renaming a Satellite or Capsule Server in Administering Red Hat Satellite. -
If the source server uses the
virt-who
daemon, install and configure it on the target server. Copy all thevirt-who
configuration files in the/etc/virt-who.d/
directory from the source server to the same directory on the target server. For more information, see Configuring Virtual Machine Subscriptions in Red Hat Satellite. After you perform an upgrade using the following chapters, you can safely decommission the source server.
Chapter 4. Tuning Satellite Server with Predefined Profiles
If your Satellite deployment includes more than 5000 hosts, you can use predefined tuning profiles to improve performance of Satellite.
Note that you cannot use tuning profiles on Capsules.
You can choose one of the profiles depending on the number of hosts your Satellite manages and available hardware resources.
The tuning profiles are available in the /usr/share/foreman-installer/config/foreman.hiera/tuning/sizes
directory.
When you run the satellite-installer
command with the --tuning
option, deployment configuration settings are applied to Satellite in the following order:
-
The default tuning profile defined in the
/usr/share/foreman-installer/config/foreman.hiera/tuning/common.yaml
file -
The tuning profile that you want to apply to your deployment and is defined in the
/usr/share/foreman-installer/config/foreman.hiera/tuning/sizes/
directory -
Optional: If you have configured a
/etc/foreman-installer/custom-hiera.yaml
file, Satellite applies these configuration settings.
Note that the configuration settings that are defined in the /etc/foreman-installer/custom-hiera.yaml
file override the configuration settings that are defined in the tuning profiles.
Therefore, before applying a tuning profile, you must compare the configuration settings that are defined in the default tuning profile in /usr/share/foreman-installer/config/foreman.hiera/tuning/common.yaml
, the tuning profile that you want to apply and your /etc/foreman-installer/custom-hiera.yaml
file, and remove any duplicated configuration from the /etc/foreman-installer/custom-hiera.yaml
file.
- default
Number of managed hosts: 0 – 5000
RAM: 20G
Number of CPU cores: 4
- medium
Number of managed hosts: 5001 – 10000
RAM: 32G
Number of CPU cores: 8
- large
Number of managed hosts: 10001 – 20000
RAM: 64G
Number of CPU cores: 16
- extra-large
Number of managed hosts: 20001 – 60000
RAM: 128G
Number of CPU cores: 32
- extra-extra-large
Number of managed hosts: 60000+
RAM: 256G
Number of CPU cores: 48+
Procedure
Optional: If you have configured the
custom-hiera.yaml
file on Satellite Server, back up the/etc/foreman-installer/custom-hiera.yaml
file tocustom-hiera.original
. You can use the backup file to restore the/etc/foreman-installer/custom-hiera.yaml
file to its original state if it becomes corrupted:# cp /etc/foreman-installer/custom-hiera.yaml \ /etc/foreman-installer/custom-hiera.original
-
Optional: If you have configured the
custom-hiera.yaml
file on Satellite Server, review the definitions of the default tuning profile in/usr/share/foreman-installer/config/foreman.hiera/tuning/common.yaml
and the tuning profile that you want to apply in/usr/share/foreman-installer/config/foreman.hiera/tuning/sizes/
. Compare the configuration entries against the entries in your/etc/foreman-installer/custom-hiera.yaml
file and remove any duplicated configuration settings in your/etc/foreman-installer/custom-hiera.yaml
file. Enter the
satellite-installer
command with the--tuning
option for the profile that you want to apply. For example, to apply the medium tuning profile settings, enter the following command:# satellite-installer --tuning medium
Chapter 5. Migrating from Internal Satellite Databases to External Databases
When you install Red Hat Satellite, the satellite-installer command installs PostgreSQL databases on the same server as Satellite. If you are using the default internal databases but want to start using external databases to help with the server load, you can migrate your internal databases to external databases.
To confirm whether your Satellite Server has internal or external databases, you can query the status of your databases:
For PostgreSQL, enter the following command:
# satellite-maintain service status --only postgresql
Red Hat does not provide support or tools for external database maintenance. This includes backups, upgrades, and database tuning. You must have your own database administrator to support and maintain external databases.
To migrate from the default internal databases to external databases, you must complete the following procedures:
- Section 5.2, “Preparing a Host for External Databases”. Prepare a Red Hat Enterprise Linux 8 server to host the external databases.
- Section 5.3, “Installing PostgreSQL”. Prepare PostgreSQL with databases for Satellite, Pulp and Candlepin with dedicated users owning them.
-
Section 5.4, “Migrating to External Databases”. Edit the parameters of
satellite-installer
to point to the new databases, and runsatellite-installer
.
5.1. PostgreSQL as an External Database Considerations
Foreman, Katello, and Candlepin use the PostgreSQL database. If you want to use PostgreSQL as an external database, the following information can help you decide if this option is right for your Satellite configuration. Satellite supports PostgreSQL version 12.
Advantages of External PostgreSQL
- Increase in free memory and free CPU on Satellite
-
Flexibility to set
shared_buffers
on the PostgreSQL database to a high number without the risk of interfering with other services on Satellite - Flexibility to tune the PostgreSQL server’s system without adversely affecting Satellite operations
Disadvantages of External PostgreSQL
- Increase in deployment complexity that can make troubleshooting more difficult
- The external PostgreSQL server is an additional system to patch and maintain
- If either Satellite or the PostgreSQL database server suffers a hardware or storage failure, Satellite is not operational
- If there is latency between the Satellite server and database server, performance can suffer
If you suspect that the PostgreSQL database on your Satellite is causing performance problems, use the information in Satellite 6: How to enable postgres query logging to detect slow running queries to determine if you have slow queries. Queries that take longer than one second are typically caused by performance issues with large installations, and moving to an external database might not help. If you have slow queries, contact Red Hat Support.
5.2. Preparing a Host for External Databases
Install a freshly provisioned system with the latest Red Hat Enterprise Linux 8 to host the external databases.
Subscriptions for Red Hat Enterprise Linux do not provide the correct service level agreement for using Satellite with external databases. You must also attach a Satellite subscription to the base operating system that you want to use for the external databases.
Prerequisite
- The prepared host must meet Satellite’s Storage Requirements.
Procedure
- Use the instructions in Attaching the Satellite Infrastructure Subscription to attach a Satellite subscription to your server.
Disable all repositories and enable only the following repositories:
# subscription-manager repos --disable '*' # subscription-manager repos \ --enable=satellite-6.13-for-rhel-8-x86_64-rpms \ --enable=satellite-maintenance-6.13-for-rhel-8-x86_64-rpms \ --enable=rhel-8-for-x86_64-baseos-rpms \ --enable=rhel-8-for-x86_64-appstream-rpms
Enable the following modules:
# dnf module enable satellite:el8
NoteEnablement of the module
satellite:el8
warns about a conflict withpostgresql:10
andruby:2.5
as these modules are set to the default module versions on Red Hat Enterprise Linux 8. The modulesatellite:el8
has a dependency for the modulespostgresql:12
andruby:2.7
that will be enabled with thesatellite:el8
module. These warnings do not cause installation process failure, hence can be ignored safely. For more information about modules and lifecycle streams on Red Hat Enterprise Linux 8, see Red Hat Enterprise Linux Application Streams Life Cycle.
5.3. Installing PostgreSQL
You can install only the same version of PostgreSQL that is installed with the satellite-installer
tool during an internal database installation. Satellite supports PostgreSQL version 12.
Procedure
To install PostgreSQL, enter the following command:
# dnf install postgresql-server postgresql-evr
To initialize PostgreSQL, enter the following command:
# postgresql-setup initdb
Edit the
/var/lib/pgsql/data/postgresql.conf
file:# vi /var/lib/pgsql/data/postgresql.conf
Note that the default configuration of external PostgreSQL needs to be adjusted to work with Satellite. The base recommended external database configuration adjustments are as follows:
- checkpoint_completion_target: 0.9
- max_connections: 500
- shared_buffers: 512MB
- work_mem: 4MB
Remove the
#
and edit to listen to inbound connections:listen_addresses = '*'
Edit the
/var/lib/pgsql/data/pg_hba.conf
file:# vi /var/lib/pgsql/data/pg_hba.conf
Add the following line to the file:
host all all Satellite_ip/32 md5
To start, and enable PostgreSQL service, enter the following commands:
# systemctl enable --now postgresql
Open the postgresql port on the external PostgreSQL server:
# firewall-cmd --add-service=postgresql # firewall-cmd --runtime-to-permanent
Switch to the
postgres
user and start the PostgreSQL client:$ su - postgres -c psql
Create three databases and dedicated roles: one for Satellite, one for Candlepin, and one for Pulp:
CREATE USER "foreman" WITH PASSWORD 'Foreman_Password'; CREATE USER "candlepin" WITH PASSWORD 'Candlepin_Password'; CREATE USER "pulp" WITH PASSWORD 'Pulpcore_Password'; CREATE DATABASE foreman OWNER foreman; CREATE DATABASE candlepin OWNER candlepin; CREATE DATABASE pulpcore OWNER pulp;
Exit the
postgres
user:# \q
From Satellite Server, test that you can access the database. If the connection succeeds, the commands return
1
.# PGPASSWORD='Foreman_Password' psql -h postgres.example.com -p 5432 -U foreman -d foreman -c "SELECT 1 as ping" # PGPASSWORD='Candlepin_Password' psql -h postgres.example.com -p 5432 -U candlepin -d candlepin -c "SELECT 1 as ping" # PGPASSWORD='Pulpcore_Password' psql -h postgres.example.com -p 5432 -U pulp -d pulpcore -c "SELECT 1 as ping"
5.4. Migrating to External Databases
Back up and transfer existing data, then use the satellite-installer
command to configure Satellite to connect to an external PostgreSQL database server.
Prerequisite
- You have installed and configured a PostgreSQL server on a Red Hat Enterprise Linux server.
Procedure
On Satellite Server, stop Satellite services:
# satellite-maintain service stop
Start the PostgreSQL services:
# systemctl start postgresql
Back up the internal databases:
# satellite-maintain backup online --skip-pulp-content --preserve-directory -y /var/migration_backup
Transfer the data to the new external databases:
PGPASSWORD='Foreman_Password' pg_restore -h postgres.example.com -U foreman -d foreman < /var/migration_backup/foreman.dump PGPASSWORD='Candlepin_Password' pg_restore -h postgres.example.com -U candlepin -d candlepin < /var/migration_backup/candlepin.dump PGPASSWORD='Pulpcore_Password' pg_restore -h postgres.example.com -U pulp -d pulpcore < /var/migration_backup/pulpcore.dump
Use the
satellite-installer
command to update Satellite to point to the new databases:satellite-installer --scenario satellite \ --foreman-db-host postgres.example.com \ --foreman-db-password Foreman_Password \ --foreman-db-database foreman \ --foreman-db-manage false \ --foreman-db-username foreman \ --katello-candlepin-db-host postgres.example.com \ --katello-candlepin-db-name candlepin \ --katello-candlepin-db-password Candlepin_Password \ --katello-candlepin-manage-db false \ --katello-candlepin-db-user candlepin \ --foreman-proxy-content-pulpcore-manage-postgresql false \ --foreman-proxy-content-pulpcore-postgresql-host postgres.example.com \ --foreman-proxy-content-pulpcore-postgresql-db-name pulpcore \ --foreman-proxy-content-pulpcore-postgresql-password Pulpcore_Password \ --foreman-proxy-content-pulpcore-postgresql-user pulp
Chapter 6. Managing Satellite with Ansible Collections
Satellite Ansible Collections is a set of Ansible modules that interact with the Satellite API. You can use Satellite Ansible Collections to manage and automate many aspects of Satellite.
6.1. Installing the Satellite Ansible Modules
Use this procedure to install the Satellite Ansible modules.
Procedure
Install the package using the following command:
# satellite-maintain packages install ansible-collection-redhat-satellite
6.2. Viewing the Satellite Ansible Modules
You can view the installed Satellite Ansible modules by running:
# ansible-doc -l redhat.satellite
Alternatively, you can also see the complete list of Satellite Ansible modules and other related information at Red Hat Ansible Automation Platform.
All modules are in the redhat.satellite
namespace and can be referred to in the format redhat.satellite._module_name_
. For example, to display information about the activation_key
module, enter the following command:
$ ansible-doc redhat.satellite.activation_key
Chapter 7. Managing Organizations
Organizations divide Red Hat Satellite resources into logical groups based on ownership, purpose, content, security level, or other divisions. You can create and manage multiple organizations through Red Hat Satellite, then divide and assign your Red Hat subscriptions to each individual organization. This provides a method of managing the content of several individual organizations under one management system. Here are some examples of organization management:
- Single Organization
- A small business with a simple system administration chain. In this case, you can create a single organization for the business and assign content to it.
- Multiple Organizations
- A large company that owns several smaller business units. For example, a company with separate system administration and software development groups. In this case, you can create organizations for the company and each of the business units it owns. This keeps the system infrastructure for each separate. You can then assign content to each organization based on its needs.
- External Organizations
- A company that manages external systems for other organizations. For example, a company offering cloud computing and web hosting resources to customers. In this case, you can create an organization for the company’s own system infrastructure and then an organization for each external business. You can then assign content to each organization where necessary.
A default installation of Red Hat Satellite has a default organization called Default Organization.
New Users
If a new user is not assigned a default organization, their access is limited. To grant systems rights to users, assign them to a default organization. The next time the user logs on to Satellite, the user’s account has the correct system rights.
7.1. Creating an Organization
Use this procedure to create an organization. To use the CLI instead of the Satellite web UI, see the CLI procedure.
Procedure
- In the Satellite web UI, navigate to Administer > Organizations.
- Click New Organization.
- In the Name field, enter a name for the organization.
- In the Label field, enter a unique identifier for the organization. This is used for creating and mapping certain assets, such as directories for content storage. Use letters, numbers, underscores, and dashes, but no spaces.
Optional: If you do not wish to enable Simple Content Access (SCA), uncheck the Simple Content Access checkbox. For more information on SCA, see Simple Content Access.
NoteRed Hat does not recommend disabling SCA as entitlement mode is deprecated.
- Optional: in the Description field, enter a description for the organization.
- Click Submit.
- If you have hosts with no organization assigned, select the hosts that you want to add to the organization, then click Proceed to Edit.
- In the Edit page, assign the infrastructure resources that you want to add to the organization. This includes networking resources, installation media, kickstart templates, and other parameters. You can return to this page at any time by navigating to Administer > Organizations and then selecting an organization to edit.
- Click Submit.
CLI procedure
To create an organization, enter the following command:
# hammer organization create \ --name "My_Organization" \ --label "My_Organization_Label" \ --description "My_Organization_Description"
NoteOrganizations created this way have Simple Content Access (SCA) enabled by default. If you wish to disable SCA, add the
--simple-content-access false
parameter to the command. Red Hat does not advise you to disable SCA because entitlement mode (not using SCA) is deprecated.Optional: To edit an organization, enter the
hammer organization update
command. For example, the following command assigns a compute resource to the organization:# hammer organization update \ --name "My_Organization" \ --compute-resource-ids 1
7.2. Setting the Organization Context
An organization context defines the organization to use for a host and its associated resources.
Procedure
The organization menu is the first menu item in the menu bar, on the upper left of the Satellite web UI. If you have not selected a current organization, the menu says Any Organization. Click the Any Organization button and select the organization to use.
CLI procedure
While using the CLI, include either --organization "My_Organization"
or --organization-label "My_Organization_Label"
as an option. For example:
# hammer subscription list \
--organization "My_Organization"
This command outputs subscriptions allocated for the My_Organization.
7.3. Creating an Organization Debug Certificate
If you require a debug certificate for your organization, use the following procedure.
Procedure
- In the Satellite web UI, navigate to Administer > Organizations.
- Select an organization that you want to generate a debug certificate for.
- Click Generate and Download.
- Save the certificate file in a secure location.
Debug Certificates for Provisioning Templates
Debug Certificates are automatically generated for provisioning template downloads if they do not already exist in the organization for which they are being downloaded.
7.4. Browsing Repository Content Using an Organization Debug Certificate
You can view an organization’s repository content using a web browser or using the API if you have a debug certificate for that organization.
Prerequisite
- You created and downloaded an organization certificate. For more information, see Section 7.3, “Creating an Organization Debug Certificate”.
Procedure
Split the private and public keys from the certificate into two files.
Open the X.509 certificate, for example, for the default organization:
$ vi 'Default Organization-key-cert.pem'
-
Copy the contents of the file from
-----BEGIN RSA PRIVATE KEY-----
to-----END RSA PRIVATE KEY-----
, into akey.pem
file. -
Copy the contents of the file from
-----BEGIN CERTIFICATE-----
to-----END CERTIFICATE-----
, into acert.pem
file.
- To use a browser, you must first convert the X.509 certificate to a format your browser supports and then import the certificate.
For Firefox Users
Convert the certificate into the PKCS12 format using the following command:
$ openssl pkcs12 -keypbe PBE-SHA1-3DES -certpbe PBE-SHA1-3DES -export -in cert.pem -inkey key.pem -out My_Organization_Label.pfx -name My_Organization
- In the Firefox browser, navigate to Edit > Preferences > Advanced Tab.
- Select View Certificates and click the Your Certificates tab.
-
Click Import and select the
.pfx
file to load. Enter the following URL in the address bar to browse the accessible paths for all the repositories and check their contents:
https://satellite.example.com/pulp/content/
For CURL Users
To use the organization debug certificate with CURL, enter the following command:
$ curl -k --cert cert.pem --key key.pem \ https://satellite.example.com/pulp/content/My_Organization_Label/Library/content/dist/rhel/server/7/7Server/x86_64/os/
Ensure that the paths to
cert.pem
andkey.pem
are the correct absolute paths otherwise the command fails silently. Pulp uses the organization label, therefore, you must enter the organization label into the URL.
7.5. Deleting an Organization
You can delete an organization if the organization is not associated with any life cycle environments or host groups. If there are any life cycle environments or host groups associated with the organization you are about to delete, remove them by navigating to Administer > Organizations and clicking the relevant organization. Do not delete the default organization created during installation because the default organization is a placeholder for any unassociated hosts in the Satellite environment. There must be at least one organization in the environment at any given time.
Procedure
- In the Satellite web UI, navigate to Administer > Organizations.
- From the list to the right of the name of the organization you want to delete, select Delete.
- Click OK to delete the organization.
CLI procedure
Enter the following command to retrieve the ID of the organization that you want to delete:
# hammer organization list
From the output, note the ID of the organization that you want to delete.
Enter the following command to delete an organization:
# hammer organization delete --id Organization_ID
Chapter 8. Managing Locations
Locations function similar to organizations: they provide a method to group resources and assign hosts. Organizations and locations have the following conceptual differences:
- Locations are based on physical or geographical settings.
- Locations have a hierarchical structure.
8.1. Creating a Location
Use this procedure to create a location so that you can manage your hosts and resources by location. To use the CLI instead of the Satellite web UI, see the CLI procedure.
Procedure
- In the Satellite web UI, navigate to Administer > Locations.
- Click New Location.
- Optional: from the Parent list, select a parent location. This creates a location hierarchy.
- In the Name field, enter a name for the location.
- Optional: in the Description field, enter a description for the location.
- Click Submit.
- If you have hosts with no location assigned, add any hosts that you want to assign to the new location, then click Proceed to Edit.
- Assign any infrastructure resources that you want to add to the location. This includes networking resources, installation media, kickstart templates, and other parameters. You can return to this page at any time by navigating to Administer > Locations and then selecting a location to edit.
- Click Submit to save your changes.
CLI procedure
Enter the following command to create a location:
# hammer location create \ --description "My_Location_Description" \ --name "My_Location" \ --parent-id "My_Location_Parent_ID"
8.2. Creating Multiple Locations
The following example Bash script creates three locations – London, Munich, Boston – and assigns them to the Example Organization.
ORG="Example Organization" LOCATIONS="London Munich Boston" for LOC in ${LOCATIONS} do hammer location create --name "${LOC}" hammer location add-organization --name "${LOC}" --organization "${ORG}" done
8.3. Setting the Location Context
A location context defines the location to use for a host and its associated resources.
Procedure
The location menu is the second menu item in the menu bar, on the upper left of the Satellite web UI. If you have not selected a current location, the menu displays Any Location. Click Any location and select the location to use.
CLI procedure
While using the CLI, include either --location "My_Location"
or --location-id "My_Location_ID"
as an option. For example:
# hammer host list --location "My_Location"
This command lists hosts associated with the My_Location location.
8.4. Deleting a Location
You can delete a location if the location is not associated with any life cycle environments or host groups. If there are any life cycle environments or host groups associated with the location you are about to delete, remove them by navigating to Administer > Locations and clicking the relevant location. Do not delete the default location created during installation because the default location is a placeholder for any unassociated hosts in the Satellite environment. There must be at least one location in the environment at any given time.
Procedure
- In the Satellite web UI, navigate to Administer > Locations.
- Select Delete from the list to the right of the name of the location you want to delete.
- Click OK to delete the location.
CLI procedure
Enter the following command to retrieve the ID of the location that you want to delete:
# hammer location list
From the output, note the ID of the location that you want to delete.
Enter the following command to delete the location:
# hammer location delete --id Location ID
Chapter 9. Managing Users and Roles
A User defines a set of details for individuals using the system. Users can be associated with organizations and environments, so that when they create new entities, the default settings are automatically used. Users can also have one or more roles attached, which grants them rights to view and manage organizations and environments. See Section 9.1, “Managing Users” for more information on working with users.
You can manage permissions of several users at once by organizing them into user groups. User groups themselves can be further grouped to create a hierarchy of permissions. For more information on creating user groups, see Section 9.4, “Creating and Managing User Groups”.
Roles define a set of permissions and access levels. Each role contains one on more permission filters that specify the actions allowed for the role. Actions are grouped according to the Resource type. Once a role has been created, users and user groups can be associated with that role. This way, you can assign the same set of permissions to large groups of users. Satellite provides a set of predefined roles and also enables creating custom roles and permission filters as described in Section 9.5, “Creating and Managing Roles”.
9.1. Managing Users
As an administrator, you can create, modify and remove Satellite users. You can also configure access permissions for a user or a group of users by assigning them different roles.
9.1.1. Creating a User
Use this procedure to create a user. To use the CLI instead of the Satellite web UI, see the CLI procedure.
Procedure
- In the Satellite web UI, navigate to Administer > Users.
- Click Create User.
- In the Login field, enter a username for the user.
- In the Firstname and Lastname fields, enter the real first name and last name of the user.
- In the Mail field, enter the user’s email address.
- In the Description field, add a description of the new user.
- Select a specific language for the user from the Language list.
Select a timezone for the user from the Timezone list.
By default, Satellite Server uses the language and timezone settings of the user’s browser.
Set a password for the user:
From the Authorized by list, select the source by which the user is authenticated.
- INTERNAL: to enable the user to be managed inside Satellite Server.
- EXTERNAL: to configure external authentication as described in Configuring External Authentication in Installing Satellite Server in a Connected Network Environment.
- Enter an initial password for the user in the Password field and the Verify field.
- Click Submit to create the user.
CLI procedure
To create a user, enter the following command:
# hammer user create \ --auth-source-id My_Authentication_Source \ --login My_User_Name \ --mail My_User_Mail \ --organization-ids My_Organization_ID_1,My_Organization_ID_2 \ --password My_User_Password
The
--auth-source-id 1
setting means that the user is authenticated internally, you can specify an external authentication source as an alternative. Add the--admin
option to grant administrator privileges to the user. Specifying organization IDs is not required, you can modify the user details later using theupdate
subcommand.
For more information about user related subcommands, enter hammer user --help
.
9.1.2. Assigning Roles to a User
Use this procedure to assign roles to a user. To use the CLI instead of the Satellite web UI, see the CLI procedure.
Procedure
- In the Satellite web UI, navigate to Administer > Users.
Click the username of the user to be assigned one or more roles.
NoteIf a user account is not listed, check that you are currently viewing the correct organization. To list all the users in Satellite, click Default Organization and then Any Organization.
- Click the Locations tab, and select a location if none is assigned.
- Click the Organizations tab, and check that an organization is assigned.
- Click the Roles tab to display the list of available roles.
Select the roles to assign from the Roles list.
To grant all the available permissions, select the Admin checkbox.
- Click Submit.
To view the roles assigned to a user, click the Roles tab; the assigned roles are listed under Selected items. To remove an assigned role, click the role name in Selected items.
CLI procedure
To assign roles to a user, enter the following command:
# hammer user add-role --id user_id --role role_name
9.1.3. Impersonating a Different User Account
Administrators can impersonate other authenticated users for testing and troubleshooting purposes by temporarily logging on to the Satellite web UI as a different user. When impersonating another user, the administrator has permissions to access exactly what the impersonated user can access in the system, including the same menus.
Audits are created to record the actions that the administrator performs while impersonating another user. However, all actions that an administrator performs while impersonating another user are recorded as having been performed by the impersonated user.
Prerequisites
- Ensure that you are logged on to the Satellite web UI as a user with administrator privileges for Satellite.
Procedure
- In the Satellite web UI, navigate to Administer > Users.
- To the right of the user that you want to impersonate, from the list in the Actions column, select Impersonate.
When you want to stop the impersonation session, in the upper right of the main menu, click the impersonation icon.
9.1.4. Creating an API-Only User
You can create users that can interact only with the Satellite API.
Prerequisite
- You have created a user and assigned roles to them. Note that this user must be authorized internally. For more information, see ] and xref:Assigning_Roles_to_a_User_admin[.
Procedure
- Log in to your Satellite as admin.
- Navigate to Administer > Users and select a user.
On the User tab, set a password. Do not save or communicate this password with others. You can create pseudo-random strings on your console:
# openssl rand -hex 32
- Create a Personal Access Token for the user. For more information, see Section 9.3.1, “Creating a Personal Access Token”.
9.2. Managing SSH Keys
Adding SSH keys to a user allows deployment of SSH keys during provisioning. For information on deploying SSH keys during provisioning, see Deploying SSH Keys during Provisioning in Provisioning Hosts.
For information on SSH keys and SSH key creation, see Using SSH-based Authentication in Red Hat Enterprise Linux 8 Configuring basic system settings.
9.2.1. Managing SSH Keys for a User
Use this procedure to add or remove SSH keys for a user. To use the CLI instead of the Satellite web UI, see the CLI procedure.
Prerequisites
- Ensure that you are logged in to the Satellite web UI as an Admin user of Red Hat Satellite or a user with the create_ssh_key permission enabled for adding SSH key and destroy_ssh_key permission for removing a key.
Procedure
- In the Satellite web UI, navigate to Administer > Users.
- From the Username column, click on the username of the required user.
Click on the SSH Keys tab.
To Add SSH key
- Prepare the content of the public SSH key in a clipboard.
- Click Add SSH Key.
- In the Key field, paste the public SSH key content from the clipboard.
- In the Name field, enter a name for the SSH key.
- Click Submit.
To Remove SSH key
- Click Delete on the row of the SSH key to be deleted.
- Click OK in the confirmation prompt.
CLI procedure
To add an SSH key to a user, you must specify either the path to the public SSH key file, or the content of the public SSH key copied to the clipboard.
If you have the public SSH key file, enter the following command:
# hammer user ssh-keys add \ --user-id user_id \ --name key_name \ --key-file ~/.ssh/id_rsa.pub
If you have the content of the public SSH key, enter the following command:
# hammer user ssh-keys add \ --user-id user_id \ --name key_name \ --key ecdsa-sha2-nistp256 AAAAE2VjZHNhLXNoYTItbmlzdHAyNTYAAAAIbmlzdHAyNtYAAABBBHHS2KmNyIYa27Qaa7EHp+2l99ucGStx4P77e03ZvE3yVRJEFikpoP3MJtYYfIe8k 1/46MTIZo9CPTX4CYUHeN8= host@user
To delete an SSH key from a user, enter the following command:
# hammer user ssh-keys delete --id key_id --user-id user_id
To view an SSH key attached to a user, enter the following command:
# hammer user ssh-keys info --id key_id --user-id user_id
To list SSH keys attached to a user, enter the following command:
# hammer user ssh-keys list --user-id user_id
9.3. Managing Personal Access Tokens
Personal Access Tokens allow you to authenticate API requests without using your password. You can set an expiration date for your Personal Access Token and you can revoke it if you decide it should expire before the expiration date.
9.3.1. Creating a Personal Access Token
Use this procedure to create a Personal Access Token.
Procedure
- In the Satellite web UI, navigate to Administer > Users.
- Select a user for which you want to create a Personal Access Token.
- On the Personal Access Tokens tab, click Add Personal Access Token.
- Enter a Name for you Personal Access Token.
- Optional: Select the Expires date to set an expiration date. If you do not set an expiration date, your Personal Access Token will never expire unless revoked.
Click Submit. You now have the Personal Access Token available to you on the Personal Access Tokens tab.
ImportantEnsure to store your Personal Access Token as you will not be able to access it again after you leave the page or create a new Personal Access Token. You can click Copy to clipboard to copy your Personal Access Token.
Verification
Make an API request to your Satellite Server and authenticate with your Personal Access Token:
# curl https://satellite.example.com/api/status --user My_Username:My_Personal_Access_Token
You should receive a response with status
200
, for example:{"satellite_version":"6.13.0","result":"ok","status":200,"version":"3.5.1.10","api_version":2}
If you go back to Personal Access Tokens tab, you can see the updated Last Used time next to your Personal Access Token.
9.3.2. Revoking a Personal Access Token
Use this procedure to revoke a Personal Access Token before its expiration date.
Procedure
- In the Satellite web UI, navigate to Administer > Users.
- Select a user for which you want to revoke the Personal Access Token.
- On the Personal Access Tokens tab, locate the Personal Access Token you want to revoke.
- Click Revoke in the Actions column next to the Personal Access Token you want to revoke.
Verification
Make an API request to your Satellite Server and try to authenticate with the revoked Personal Access Token:
# curl https://satellite.example.com/api/status --user My_Username:My_Personal_Access_Token
You receive the following error message:
{ "error": {"message":"Unable to authenticate user My_Username"} }
9.4. Creating and Managing User Groups
9.4.1. User Groups
With Satellite, you can assign permissions to groups of users. You can also create user groups as collections of other user groups. If using an external authentication source, you can map Satellite user groups to external user groups as described in Configuring External User Groups in Installing Satellite Server in a Connected Network Environment.
User groups are defined in an organizational context, meaning that you must select an organization before you can access user groups.
9.4.2. Creating a User Group
Use this procedure to create a user group.
Procedure
- In the Satellite web UI, navigate to Administer > User Groups.
- Click Create User group.
On the User Group tab, specify the name of the new user group and select group members:
- Select the previously created user groups from the User Groups list.
- Select users from the Users list.
- On the Roles tab, select the roles you want to assign to the user group. Alternatively, select the Admin checkbox to assign all available permissions.
- Click Submit.
CLI procedure
To create a user group, enter the following command:
# hammer user-group create \ --name My_User_Group_Name \ --role-ids My_Role_ID_1,My_Role_ID_2 \ --user-ids My_User_ID_1,My_User_ID_2
9.4.3. Removing a User Group
Use the following procedure to remove a user group from Satellite.
Procedure
- In the Satellite web UI, navigate to Administer > User Groups.
- Click Delete to the right of the user group you want to delete.
- Click Confirm to delete the user group.
9.5. Creating and Managing Roles
Satellite provides a set of predefined roles with permissions sufficient for standard tasks, as listed in Section 9.6, “Predefined Roles Available in Satellite”. It is also possible to configure custom roles, and assign one or more permission filters to them. Permission filters define the actions allowed for a certain resource type. Certain Satellite plug-ins create roles automatically.
9.5.1. Creating a Role
Use this procedure to create a role.
Procedure
- In the Satellite web UI, navigate to Administer > Roles.
- Click Create Role.
- Provide a Name for the role.
- Click Submit to save your new role.
CLI procedure
To create a role, enter the following command:
# hammer role create --name My_Role_Name
To serve its purpose, a role must contain permissions. After creating a role, proceed to Section 9.5.3, “Adding Permissions to a Role”.
9.5.2. Cloning a Role
Use the Satellite web UI to clone a role.
Procedure
- In the Satellite web UI, navigate to Administer > Roles and select Clone from the drop-down menu to the right of the required role.
- Provide a Name for the role.
- Click Submit to clone the role.
- Click the name of the cloned role and navigate to Filters.
- Edit the permissions as required.
- Click Submit to save your new role.
9.5.3. Adding Permissions to a Role
Use this procedure to add permissions to a role. To use the CLI instead of the Satellite web UI, see the CLI procedure.
Procedure
- In the Satellite web UI, navigate to Administer > Roles.
- Select Add Filter from the drop-down list to the right of the required role.
- Select the Resource type from the drop-down list. The (Miscellaneous) group gathers permissions that are not associated with any resource group.
- Click the permissions you want to select from the Permission list.
- Depending on the Resource type selected, you can select or deselect the Unlimited and Override checkbox. The Unlimited checkbox is selected by default, which means that the permission is applied on all resources of the selected type. When you disable the Unlimited checkbox, the Search field activates. In this field you can specify further filtering with use of the Satellite search syntax. For more information, see Section 9.7, “Granular Permission Filtering”. When you enable the Override checkbox, you can add additional locations and organizations to allow the role to access the resource type in the additional locations and organizations; you can also remove an already associated location and organization from the resource type to restrict access.
- Click Next.
- Click Submit to save changes.
CLI procedure
List all available permissions:
# hammer filter available-permissions
Add permissions to a role:
# hammer filter create \ --permission-ids My_Permission_ID_1,My_Permission_ID_2 \ --role My_Role_Name
For more information about roles and permissions parameters, enter the hammer role --help
and hammer filter --help
commands.
9.5.4. Viewing Permissions of a Role
Use the Satellite web UI to view the permissions of a role.
Procedure
- In the Satellite web UI, navigate to Administer > Roles.
- Click Filters to the right of the required role to get to the Filters page.
The Filters page contains a table of permissions assigned to a role grouped by the resource type. It is also possible to generate a complete table of permissions and actions that you can use on your Satellite system. For more information, see Section 9.5.5, “Creating a Complete Permission Table”.
9.5.5. Creating a Complete Permission Table
Use the Satellite CLI to create a permission table.
Procedure
Ensure that the required packages are installed. Execute the following command on Satellite Server:
# satellite-maintain packages install foreman-console
Start the Satellite console with the following command:
# foreman-rake console
Insert the following code into the console:
f = File.open('/tmp/table.html', 'w') result = Foreman::AccessControl.permissions {|a,b| a.security_block <=> b.security_block}.collect do |p| actions = p.actions.collect { |a| "<li>#{a}</li>" } "<tr><td>#{p.name}</td><td><ul>#{actions.join('')}</ul></td><td>#{p.resource_type}</td></tr>" end.join("\n") f.write(result)
The above syntax creates a table of permissions and saves it to the
/tmp/table.html
file.Press
Ctrl
+D
to exit the Satellite console. Insert the following text at the first line of/tmp/table.html
:<table border="1"><tr><td>Permission name</td><td>Actions</td><td>Resource type</td></tr>
Append the following text at the end of
/tmp/table.html
:</table>
-
Open
/tmp/table.html
in a web browser to view the table.
9.5.6. Removing a Role
Use the following procedure to remove a role from Satellite.
Procedure
- In the Satellite web UI, navigate to Administer > Roles.
- Select Delete from the drop-down list to the right of the role to be deleted.
- Click Confirm to delete the role.
9.6. Predefined Roles Available in Satellite
The following table provides an overview of permissions that predefined roles in Satellite grant to a user.
To view the exact set of permissions a predefined role grants, display the role in Satellite web UI as the privileged user. For more information, see Section 9.5.4, “Viewing Permissions of a Role”.
Role | Permissions Provided by Role |
---|---|
Access Insights Admin | Add and edit Insights rules. |
Access Insights Viewer | View Insight reports. |
Ansible Roles Manager | Play roles on hosts and host groups. View, destroy, and import Ansible roles. View, edit, create, destroy, and import Ansible variables. |
Ansible Tower Inventory Reader | View facts, hosts, and host groups. |
Bookmarks manager | Create, edit, and delete bookmarks. |
Boot disk access | Download the boot disk. |
Compliance manager | View, create, edit, and destroy SCAP content files, compliance policies, and tailoring files. View compliance reports. |
Compliance viewer | View compliance reports. |
Create ARF report | Create compliance reports. |
Default role | The set of permissions that every user is granted, irrespective of any other roles. |
Discovery Manager | View, provision, edit, and destroy discovered hosts and manage discovery rules. |
Discovery Reader | View hosts and discovery rules. |
Edit hosts | View, create, edit, destroy, and build hosts. |
Edit partition tables | View, create, edit and destroy partition tables. |
Manager | View and edit global settings. |
Organization admin | All permissions except permissions for managing organizations. An administrator role defined per organization. The role has no visibility into resources in other organizations. By cloning this role and assigning an organization, you can delegate administration of that organization to a user. |
Red Hat Access Logs | View the log viewer and the logs. |
Remote Execution Manager | Control which roles have permission to run infrastructure jobs. |
Remote Execution User | Run remote execution jobs against hosts. |
Site manager | A restrained version of the Manager role. |
System admin |
Users with this role can create users and assign all roles to them. Therefore, ensure to give this role only to trusted users. |
Tasks manager | View and edit Satellite tasks. |
Tasks reader | A role that can only view Satellite tasks. |
Viewer | A passive role that provides the ability to view the configuration of every element of the Satellite structure, logs, reports, and statistics. |
View hosts | A role that can only view hosts. |
Virt-who Manager | A role with full virt-who permissions. |
Virt-who Reporter | Upload reports generated by virt-who to Satellite. It can be used if you configure virt-who manually and require a user role that has limited virt-who permissions. |
Virt-who Viewer | View virt-who configurations. Users with this role can deploy virt-who instances using existing virt-who configurations. |
9.7. Granular Permission Filtering
As mentioned in Section 9.5.3, “Adding Permissions to a Role”, Red Hat Satellite provides the ability to limit the configured user permissions to selected instances of a resource type. These granular filters are queries to the Satellite database and are supported by the majority of resource types.
9.7.1. Creating a Granular Permission Filter
Use this procedure to create a granular filter. To use the CLI instead of the Satellite web UI, see the CLI procedure.
Satellite does not apply search conditions to create actions. For example, limiting the create_locations action with name = "Default Location" expression in the search field does not prevent the user from assigning a custom name to the newly created location.
Procedure
Specify a query in the Search field on the Edit Filter page. Deselect the Unlimited checkbox for the field to be active. Queries have the following form:
field_name operator value
- field_name marks the field to be queried. The range of available field names depends on the resource type. For example, the Partition Table resource type offers family, layout, and name as query parameters.
- operator specifies the type of comparison between field_name and value. See Section 9.7.3, “Supported Operators for Granular Search” for an overview of applicable operators.
- value is the value used for filtering. This can be for example a name of an organization. Two types of wildcard characters are supported: underscore (_) provides single character replacement, while percent sign (%) replaces zero or more characters.
For most resource types, the Search field provides a drop-down list suggesting the available parameters. This list appears after placing the cursor in the search field. For many resource types, you can combine queries using logical operators such as and, not and has operators.
CLI procedure
To create a granular filter, enter the
hammer filter create
command with the--search
option to limit permission filters, for example:# hammer filter create \ --permission-ids 91 \ --search "name ~ ccv*" \ --role qa-user
This command adds to the qa-user role a permission to view, create, edit, and destroy Content Views that only applies to Content Views with name starting with ccv
.
9.7.2. Examples of Using Granular Permission Filters
As an administrator, you can allow selected users to make changes in a certain part of the environment path. The following filter allows you to work with content while it is in the development stage of the application life cycle, but the content becomes inaccessible once is pushed to production.
9.7.2.1. Applying Permissions for the Host Resource Type
The following query applies any permissions specified for the Host resource type only to hosts in the group named host-editors.
hostgroup = host-editors
The following query returns records where the name matches XXXX, Yyyy, or zzzz example strings:
name ^ (XXXX, Yyyy, zzzz)
You can also limit permissions to a selected environment. To do so, specify the environment name in the Search field, for example:
Dev
You can limit user permissions to a certain organization or location with the use of the granular permission filter in the Search field. However, some resource types provide a GUI alternative, an Override checkbox that provides the Locations and Organizations tabs. On these tabs, you can select from the list of available organizations and locations. For more information, see Section 9.7.2.2, “Creating an Organization Specific Manager Role”.
9.7.2.2. Creating an Organization Specific Manager Role
Use the Satellite web UI to create an administrative role restricted to a single organization named org-1.
Procedure
- In the Satellite web UI, navigate to Administer > Roles.
- Clone the existing Organization admin role. Select Clone from the drop-down list next to the Filters button. You are then prompted to insert a name for the cloned role, for example org-1 admin.
- Click the desired locations and organizations to associate them with the role.
- Click Submit to create the role.
- Click org-1 admin, and click Filters to view all associated filters. The default filters work for most use cases. However, you can optionally click Edit to change the properties for each filter. For some filters, you can enable the Override option if you want the role to be able to access resources in additional locations and organizations. For example, by selecting the Domain resource type, the Override option, and then additional locations and organizations using the Locations and Organizations tabs, you allow this role to access domains in the additional locations and organizations that is not associated with this role. You can also click New filter to associate new filters with this role.
9.7.3. Supported Operators for Granular Search
Operator | Description |
and | Combines search criteria. |
not | Negates an expression. |
has | Object must have a specified property. |
Operator | Description |
= | Is equal to. An equality comparison that is case-sensitive for text fields. |
!= | Is not equal to. An inversion of the = operator. |
~ | Like. A case-insensitive occurrence search for text fields. |
!~ | Not like. An inversion of the ~ operator. |
^ | In. An equality comparison that is case-sensitive search for text fields. This generates a different SQL query to the Is equal to comparison, and is more efficient for multiple value comparison. |
!^ | Not in. An inversion of the ^ operator. |
>, >= | Greater than, greater than or equal to. Supported for numerical fields only. |
<, ⇐ | Less than, less than or equal to. Supported for numerical fields only. |
Chapter 10. Configuring Email Notifications
Email notifications are created by Satellite Server periodically or after completion of certain events. The periodic notifications can be sent daily, weekly or monthly.
For an overview of available notification types, see Section 10.1, “Email Notification Types”.
Users do not receive any email notifications by default. An administrator can configure users to receive notifications based on criteria such as the type of notification, and frequency.
Satellite Server does not enable outgoing emails by default, therefore you must review your email configuration. For more information, see Configuring Satellite Server for Outgoing Emails in Installing Satellite Server in a Connected Network Environment.
10.1. Email Notification Types
Satellite can create the following email notifications:
- Audit summary: A summary of all activity audited by Satellite Server.
- Host built: A notification sent when a host is built.
- Host errata advisory: A summary of applicable and installable errata for hosts managed by the user.
- Compliance policy summary: A summary of OpenSCAP policy reports and their results.
- Promote errata: A notification sent only after a Content View promotion. It contains a summary of errata applicable and installable to hosts registered to the promoted Content View. This allows a user to monitor what updates have been applied to which hosts.
- Sync errata: A notification sent only after synchronizing a repository. It contains a summary of new errata introduced by the synchronization.
For a complete list of email notification types, navigate to Administer > Users in the Satellite web UI, click the Username of the required user, and select the Email Preferences tab.
10.2. Configuring Email Notification Preferences
You can configure Satellite to send email messages to individual users registered to Satellite. Satellite sends the email to the email address that has been added to the account, if present. Users can edit the email address by clicking on their name in the top-right of the Satellite web UI and selecting My account.
Configure email notifications for a user from the Satellite web UI.
If you want to send email notifications to a group email address instead of an individual email address, create a user account with the group email address and minimal Satellite permissions, then subscribe the user account to the desired notification types.
Procedure
- In the Satellite web UI, navigate to Administer > Users.
- Click the Username of the user you want to edit.
- On the User tab, verify the value of the Mail field. Email notifications will be sent to the address in this field.
- On the Email Preferences tab, select Mail Enabled.
Select the notifications you want the user to receive using the drop-down menus next to the notification types.
NoteThe Audit Summary notification can be filtered by entering the required query in the Mail Query text box.
Click Submit.
The user will start receiving the notification emails.
10.3. Testing Email Delivery
To verify the delivery of emails, send a test email to a user. If the email gets delivered, the settings are correct.
Procedure
- In the Satellite web UI, navigate to Administer > Users.
- Click on the username.
On the Email Preferences tab, click Test email.
A test email message is sent immediately to the user’s email address.
If the email is delivered, the verification is complete. Otherwise, you must perform the following diagnostic steps:
- Verify the user’s email address.
- Verify Satellite Server’s email configuration.
- Examine firewall and mail server logs.
10.4. Testing Email Notifications
To verify that users are correctly subscribed to notifications, trigger the notifications manually.
Procedure
To trigger the notifications, execute the following command:
# foreman-rake reports:_My_Frequency_
Replace My_Frequency with one of the following:
- daily
- weekly
- monthly
This triggers all notifications scheduled for the specified frequency for all the subscribed users. If every subscribed user receives the notifications, the verification succeeds.
Sending manually triggered notifications to individual users is currently not supported.
10.5. Changing Email Notification Settings for a Host
Satellite can send event notifications for a host to the host’s registered owner. You can configure Satellite to send email notifications either to an individual user or a user group. When set to a user group, all group members who are subscribed to the email type receive a message.
Receiving email notifications for a host can be useful, but also overwhelming if you are expecting to receive frequent errors, for example, because of a known issue or error you are working around.
Procedure
- In the Satellite web UI, navigate to Hosts > All Hosts, locate the host that you want to view, and click Edit in the Actions column.
- Go to the Additional Information tab. If the checkbox Include this host within Satellite reporting is checked, then the email notifications are enabled on that host.
Optional: Toggle the checkbox to enable or disable the email notifications.
NoteIf you want to receive email notifications, ensure that you have an email address set in your user settings.
Chapter 11. Managing Security Compliance
Security compliance management is the ongoing process of defining security policies, auditing systems for compliance with those policies, and resolving instances of non-compliance. Any non-compliance is managed according to the organization’s configuration management policies. Security policies range in scope from host-specific to industry-wide, therefore, flexibility in their definition is required.
With Satellite, you can schedule compliance auditing and reporting on all registered hosts.
11.1. Security Content Automation Protocol
Satellite uses the Security Content Automation Protocol (SCAP) standard to define security policies.
SCAP is a framework of several specifications based on XML, such as checklists described in the Extensible Checklist Configuration Description Format (XCCDF) and vulnerabilities described in the Open Vulnerability and Assessment Language (OVAL). These specifications are encapsulated as data stream files.
Checklist items in XCCDF, also known as rules, express the desired configuration of a system item. For example, a rule may specify that no one can log in to a host over SSH using the root
user account. Rules can be grouped into one or more XCCDF profiles, which allows multiple profiles to share a rule.
The OpenSCAP scanner tool evaluates system items on a host against the rules and generates a report in the Asset Reporting Format (ARF), which is then returned to Satellite for monitoring and analysis.
Title | Description | Version |
SCAP | Security Content Automation Protocol | 1.3 |
XCCDF | Extensible Configuration Checklist Description Format | 1.2 |
OVAL | Open Vulnerability and Assessment Language | 5.11 |
- | Asset Identification | 1.1 |
ARF | Asset Reporting Format | 1.1 |
CCE | Common Configuration Enumeration | 5.0 |
CPE | Common Platform Enumeration | 2.3 |
CVE | Common Vulnerabilities and Exposures | 2.0 |
CVSS | Common Vulnerability Scoring System | 2.0 |
Additional resources
- For more information about SCAP, see the OpenSCAP project.
11.2. SCAP Content in Satellite
SCAP content is a SCAP data-stream file that contains implementation of compliance, configuration, or security baselines. A single data stream usually includes multiple XCCDF profiles. An XCCDF profile defines an industry standard or custom security standard against which you can evaluate compliance of host configuration in Satellite, such as Protection Profile for General Purpose Operating Systems (OSPP), Health Insurance Portability and Accountability Act (HIPAA), and PCI-DSS v3.2.1 Control Baseline for Red Hat Enterprise Linux 9. You can adapt existing XCCDF profiles according to your requirements using tailoring files.
In Satellite, you use an XCCDF profile from SCAP content and, eventually, a tailoring file, to define a compliance policy. Satellite includes default SCAP contents from SCAP Security Guide provided by the OpenSCAP project.
For more information on how to download, deploy, modify, and create your own content, see:
11.2.1. Supported SCAP Versions
Satellite supports content of SCAP versions 1.2 and 1.3.
11.3. Compliance Policy Deployment Options
You can use one of the following methods to deploy compliance policies:
- Ansible deployment
- You use an Ansible role to configure hosts for compliance scans.
- Puppet deployment
- You use a Puppet class and the Puppet agent to configure hosts for compliance scans.
- Manual deployment
- You manually configure hosts for compliance scans.
11.4. Configuring Compliance Policy Deployment Methods
Use one the following procedures to configure Satellite for the method that you have selected to deploy compliance policies. You will select one of these methods when you later create a compliance policy.
Procedure for Ansible deployment
Import the
theforeman.foreman_scap_client
Ansible role.For more information, see Managing Configurations Using Ansible Integration in Red Hat Satellite.
-
Assign the created policy and the
theforeman.foreman_scap_client
Ansible role to a host or host group. To trigger the deployment, run the Ansible role on the host or host group either manually, or set up a recurring job by using remote execution for regular policy updates.
For more information, see Configuring and Setting Up Remote Jobs in Managing Hosts.
Procedure for Puppet deployment
- Ensure Puppet is enabled.
- Ensure the Puppet agent is installed on hosts.
Import the Puppet environment that contains the
foreman_scap_client
Puppet module.For more information, see Managing Configurations Using Puppet Integration in Red Hat Satellite.
Assign the created policy and the
foreman_scap_client
Puppet class to a host or host group.Puppet triggers the deployment on the next regular run or you can run Puppet manually. Puppet runs every 30 minutes by default.
Procedure for manual deployment
For the manual deployment method, no additional Satellite configuration is required.
For information on manual deployment, see How to set up OpenSCAP Policies using Manual Deployment option in the Red Hat Knowledgebase.
11.5. Listing Available SCAP Contents
Use this procedure to view what SCAP contents are already loaded in Satellite. To use the CLI instead of the Satellite web UI, see the CLI procedure.
Prerequisite
-
Your user account has the
view_scap_contents
permission.
Procedure
- In the Satellite web UI, navigate to Hosts > Compliance – SCAP contents.
CLI procedure
Run the following Hammer command on Satellite Server:
# hammer scap-content list \ --location "My_Location" \ --organization "My_Organization"
11.6. Configuring SCAP Contents
You can upload SCAP data streams and tailoring files to define compliance policies.
11.6.1. Loading the Default SCAP Contents
By loading the default SCAP contents on Satellite Server, you ensure that the data streams from the SCAP Security Guide (SSG) are loaded and assigned to all organizations and locations.
SSG is provided by the operating system of Satellite Server and installed in /usr/share/xml/scap/ssg/content/
. Note that the available data streams depend on the operating system version on which Satellite runs. You can only use this SCAP content to scan hosts that have the same minor RHEL version as your Satellite Server. For more information, see Section 11.6.2, “Getting Supported SCAP Contents for RHEL”.
Prerequisites
-
Your user account has a role assigned that has the
create_scap_contents
permission.
Procedure
Use the following Hammer command on Satellite Server:
# hammer scap-content bulk-upload --type default
11.6.2. Getting Supported SCAP Contents for RHEL
You can get the latest SCAP Security Guide (SSG) for Red Hat Enterprise Linux on the Red Hat Customer Portal. You have to get a version of SSG that is designated for the minor RHEL version of your hosts.
Procedure
- Access the SCAP Security Guide in the package browser.
-
From the Version menu, select the latest SSG version for the minor version of RHEL that your hosts are running. For example, for RHEL 8.6, select a version named
*.el8_6
. - Download the package RPM.
Extract the data-stream file (
*-ds.xml
) from the RPM. For example:$ rpm2cpio scap-security-guide-0.1.69-3.el8_6.noarch.rpm \ | cpio -iv --to-stdout ./usr/share/xml/scap/ssg/content/ssg-rhel8-ds.xml \ > ssg-rhel-8.6-ds.xml
- Upload the data stream to Satellite. For more information, see Section 11.6.3, “Uploading Additional SCAP Content”.
Additional resources
- Supported versions of the SCAP Security Guide in RHEL in the Red Hat Knowledgebase
- SCAP Security Guide profiles supported in RHEL 9 in Red Hat Enterprise Linux 9 Security hardening
- SCAP Security Guide profiles supported in RHEL 8 in Red Hat Enterprise Linux 8 Security hardening
- SCAP Security Guide profiles supported in RHEL 7 in Red Hat Enterprise Linux 7 Security Guide
11.6.3. Uploading Additional SCAP Content
You can upload additional SCAP content into Satellite Server, either content created by yourself or obtained elsewhere. Note that Red Hat only provides support for SCAP content obtained from Red Hat. To use the CLI instead of the Satellite web UI, see the CLI procedure.
Prerequisite
-
Your user account has the
create_scap_contents
permission. - You have acquired a SCAP data-stream file.
Procedure
- In the Satellite web UI, navigate to Hosts > Compliance > SCAP contents.
- Click Upload New SCAP Content.
-
Enter a title in the Title text box, such as
My SCAP Content
. - In Scap File, click Choose file, navigate to the location containing a SCAP data-stream file and click Open.
- On the Locations tab, select locations.
- On the Organizations tab, select organizations.
- Click Submit.
If the SCAP content file is loaded successfully, a message similar to Successfully created My SCAP Content
is displayed.
CLI procedure
-
Place the SCAP data-stream file to a directory on your Satellite Server, such as
/usr/share/xml/scap/my_content/
. Run the following Hammer command on Satellite Server:
# hammer scap-content bulk-upload --type directory \ --directory /usr/share/xml/scap/my_content/ \ --location "My_Location" \ --organization "My_Organization"
Verification
- List the available SCAP contents. The list of SCAP contents includes the new title.
11.6.4. Tailoring XCCDF Profiles
You can customize existing XCCDF profiles using tailoring files without editing the original SCAP content. A single tailoring file can contain customizations of multiple XCCDF profiles.
You can create a tailoring file using the SCAP Workbench tool. For more information on using the SCAP Workbench tool, see Customizing SCAP Security Guide for your use case.
Then you can assign a tailoring file to a compliance policy to customize an XCCDF profile in the policy.
11.6.5. Uploading a Tailoring File
After uploading a tailoring file, you can apply it in a compliance policy to customize an XCCDF profile.
Prerequisite
-
Your user account has the
create_tailoring_files
permission.
Procedure
- In the Satellite web UI, navigate to Hosts > Compliance – Tailoring Files and click New Tailoring File.
- Enter a name in the Name text box.
- Click Choose File, navigate to the location containing the tailoring file and select Open.
- Click Submit to upload the chosen tailoring file.
11.7. Managing Compliance Policies
A compliance policy is a scheduled audit that checks the specified hosts for compliance against a specific XCCDF profile from a SCAP content.
You specify the schedule for scans on Satellite Server and the scans are performed on hosts. When a scan completes, a report in ARF format is generated and uploaded to Satellite Server. The compliance policy makes no changes to the scanned host.
A compliance policy defines a SCAP client configuration and a cron schedule. The policy is then deployed together with the SCAP client on hosts to which the policy is assigned.
11.7.1. Creating a Compliance Policy
By creating a compliance policy, you can define and plan your security compliance requirements, and ensure that your hosts remain compliant to your security policies.
Prerequisites
- You have configured Satellite for your selected compliance policy deployment method.
You have available SCAP contents, and eventually tailoring files, in Satellite.
- To verify what SCAP contents are available, see Section 11.5, “Listing Available SCAP Contents”.
- To upload SCAP contents and tailoring files, see Section 11.6, “Configuring SCAP Contents”.
-
Your user account has the
view_policies
andcreate_policies
permissions.
Procedure
- In the Satellite web UI, navigate to Hosts > Compliance – Policies.
- Click New Policy or New Compliance Policy.
- Select the deployment method: Ansible, Puppet, or Manual. Then click Next.
- Enter a name for this policy, a description (optional), then click Next.
Select the SCAP Content and XCCDF Profile to be applied, then click Next.
Note that Satellite does not detect whether the selected XCCDF profile contains any rules. An empty XCCDF profile, such as the
Default XCCDF Profile
, will return empty reports.- Optional: To customize the XCCDF profile, select a Tailoring File and a XCCDF Profile in Tailoring File, then click Next.
Specify the scheduled time when the policy is to be applied. Select Weekly, Monthly, or Custom from the Period list. The Custom option allows for greater flexibility in the policy’s schedule.
- If you select Weekly, also select the desired day of the week from the Weekday list.
- If you select Monthly, also specify the desired day of the month in the Day of month field.
- If you select Custom, enter a valid Cron expression in the Cron line field.
- Select the locations to which to apply the policy, then click Next.
- Select the organizations to which to apply the policy, then click Next.
- Optional: Select the host groups to which to assign the policy.
- Click Submit.
11.7.2. Viewing a Compliance Policy
You can preview the rules which will be applied by specific OpenSCAP content and profile combination. This is useful when you plan policies.
Prerequisite
-
Your user account has the
view_policies
permission.
Procedure
- In the Satellite web UI, navigate to Hosts > Compliance – Policies.
- In the Actions column of the required policy, click Show Guide or select it from the list.
11.7.3. Editing a Compliance Policy
In the Satellite web UI, you can edit compliance policies.
Puppet agent applies an edited policy to the host on the next run. By default, this occurs every 30 minutes. If you use Ansible, you must run the Ansible role manually again or have configured a recurring remote execution job that runs the Ansible role on hosts.
Prerequisite
-
Your user account has the
view_policies
andedit_policies
permissions.
Procedure
- In the Satellite web UI, navigate to Hosts > Compliance – Policies.
- Click the name of the required policy.
- Edit the necessary attributes.
- Click Submit.
11.7.4. Deleting a Compliance Policy
In the Satellite web UI, you can delete existing compliance policies.
Prerequisite
-
Your user account has the
view_policies
anddestroy_policies
permissions.
Procedure
- In the Satellite web UI, navigate to Hosts > Compliance – Policies.
- In the Actions column of the required policy, select Delete from the list.
- Click OK in the confirmation message.
11.8. Deploying Compliance Policies
To deploy a compliance policy, you must install the SCAP client, update the cron schedule file, and upload the SCAP content selected in the policy onto a host.
11.8.1. Deploying a Policy in a Host Group Using Ansible
After you deploy a compliance policy in a host group using Ansible, the Ansible role installs the SCAP client and configures OpenSCAP scans on the hosts according to the selected compliance policy.
Prerequisites
- You have enabled OpenSCAP on your Capsule. For more information, see Enabling OpenSCAP on Capsule Servers in Installing Capsule Server.
You have enabled and synced the operating system repositories to Satellite, and enabled them on the hosts:
-
Red Hat Enterprise Linux 9 for x86_64 - BaseOS and Appstream (RPMs) –
rhel-9-for-x86_64-baseos-rpms
andrhel-9-for-x86_64-appstream-rpms
-
Red Hat Enterprise Linux 8 for x86_64 - BaseOS and Appstream (RPMs) –
rhel-8-for-x86_64-baseos-rpms
andrhel-8-for-x86_64-appstream-rpms
-
Red Hat Enterprise Linux 7 Server and Extras (RPMs) –
rhel-7-server-rpms
andrhel-7-server-extras-rpms
-
Red Hat Enterprise Linux 9 for x86_64 - BaseOS and Appstream (RPMs) –
- You have enabled and synced the Satellite Client 6 repository to Satellite, and enabled it on the hosts.
- You have created a compliance policy with the Ansible deployment option and assigned the host group.
Procedure
- In the Satellite web UI, navigate to Configure > Host Groups.
- Click the host group that you want to configure for OpenSCAP reporting.
- From the OpenSCAP Capsule list, select the Capsule with OpenSCAP enabled that you want to use.
-
On the Ansible Roles tab, assign the
theforeman.foreman_scap_client
Ansible role. - Optional: On the Parameters tab, configure any Ansible variables of the role.
- Click Submit to save your changes.
- In the row of the required host group, navigate to the Actions column and select Run all Ansible roles.
11.8.2. Deploying a Policy on a Host Using Ansible
After you deploy a compliance policy on a host using Ansible, the Ansible role installs the SCAP client and configures OpenSCAP scans on the host according to the selected compliance policy.
Prerequisites
- You have enabled OpenSCAP on your Capsule. For more information, see Enabling OpenSCAP on Capsule Servers in Installing Capsule Server.
You have enabled and synced the operating system repositories to Satellite, and enabled them on the hosts:
-
Red Hat Enterprise Linux 9 for x86_64 - BaseOS and Appstream (RPMs) –
rhel-9-for-x86_64-baseos-rpms
andrhel-9-for-x86_64-appstream-rpms
-
Red Hat Enterprise Linux 8 for x86_64 - BaseOS and Appstream (RPMs) –
rhel-8-for-x86_64-baseos-rpms
andrhel-8-for-x86_64-appstream-rpms
-
Red Hat Enterprise Linux 7 Server and Extras (RPMs) –
rhel-7-server-rpms
andrhel-7-server-extras-rpms
-
Red Hat Enterprise Linux 9 for x86_64 - BaseOS and Appstream (RPMs) –
- You have enabled and synced the Satellite Client 6 repository to Satellite, and enabled it on the host.
- You have created a compliance policy with the Ansible deployment option.
Procedure
- In the Satellite web UI, navigate to Hosts > All Hosts, and select Edit on the host you want to configure for OpenSCAP reporting.
- From the OpenSCAP Capsule list, select the Capsule with OpenSCAP enabled that you want to use.
-
On the Ansible Roles tab, add the
theforeman.foreman_scap_client
Ansible role. - Optional: On the Parameters tab, configure any Ansible variables of the role.
- Click Submit to save your changes.
- Click the Hosts breadcrumbs link to navigate back to the host index page.
- Select the host or hosts to which you want to add the policy.
- Click Select Action.
- Select Assign Compliance Policy from the list.
- In the Assign Compliance Policy window, select Remember hosts selection for the next bulk action.
- Select the required policy from the list of available policies and click Submit.
- Click Select Action.
- Select Run all Ansible roles from the list.
11.8.3. Deploying a Policy in a Host Group Using Puppet
After you deploy a compliance policy in a host group using Puppet, the Puppet agent installs the SCAP client and configures OpenSCAP scans on the hosts on the next Puppet run according to the selected compliance policy.
Prerequisites
- You have enabled OpenSCAP on your Capsule. For more information, see Enabling OpenSCAP on Capsule Servers in Installing Capsule Server.
You have enabled and synced the operating system repositories to Satellite, and enabled them on the hosts:
-
Red Hat Enterprise Linux 9 for x86_64 - BaseOS and Appstream (RPMs) –
rhel-9-for-x86_64-baseos-rpms
andrhel-9-for-x86_64-appstream-rpms
-
Red Hat Enterprise Linux 8 for x86_64 - BaseOS and Appstream (RPMs) –
rhel-8-for-x86_64-baseos-rpms
andrhel-8-for-x86_64-appstream-rpms
-
Red Hat Enterprise Linux 7 Server and Extras (RPMs) –
rhel-7-server-rpms
andrhel-7-server-extras-rpms
-
Red Hat Enterprise Linux 9 for x86_64 - BaseOS and Appstream (RPMs) –
- You have enabled and synced the Satellite Client 6 repository to Satellite, and enabled it on the hosts.
- You have created a compliance policy with the Puppet deployment option and assigned the host group.
Procedure
- In the Satellite web UI, navigate to Configure > Host Groups.
- Click the host group that you want to configure for OpenSCAP reporting.
-
In the Environment list, select the Puppet environment that contains the
foreman_scap_client*
Puppet classes. - In the OpenSCAP Capsule list, select the Capsule with OpenSCAP enabled that you want to use.
-
On the Puppet ENC tab, add the
foreman_scap_client
Puppet class. - Optional: Configure any Puppet Class Parameters.
- Click Submit to save your changes.
11.8.4. Deploying a Policy on a Host Using Puppet
After you deploy a compliance policy on a host using Puppet, the Puppet agent installs the SCAP client and configures OpenSCAP scans on the host on the next Puppet run according to the selected compliance policy.
Prerequisites
- You have enabled OpenSCAP on your Capsule. For more information, see Enabling OpenSCAP on Capsule Servers in Installing Capsule Server.
You have enabled and synced the operating system repositories to Satellite, and enabled them on the hosts:
-
Red Hat Enterprise Linux 9 for x86_64 - BaseOS and Appstream (RPMs) –
rhel-9-for-x86_64-baseos-rpms
andrhel-9-for-x86_64-appstream-rpms
-
Red Hat Enterprise Linux 8 for x86_64 - BaseOS and Appstream (RPMs) –
rhel-8-for-x86_64-baseos-rpms
andrhel-8-for-x86_64-appstream-rpms
-
Red Hat Enterprise Linux 7 Server and Extras (RPMs) –
rhel-7-server-rpms
andrhel-7-server-extras-rpms
-
Red Hat Enterprise Linux 9 for x86_64 - BaseOS and Appstream (RPMs) –
- You have enabled and synced the Satellite Client 6 repository to Satellite, and enabled it on the host.
- You have created a compliance policy with the Puppet deployment option.
Procedure
- In the Satellite web UI, navigate to Hosts > All Hosts, and select Edit on the host you want to configure for OpenSCAP reporting.
-
From the Environment list, select the Puppet environment that contains the
foreman_scap_client
andforeman_scap_client::params
Puppet classes. - From the OpenSCAP Capsule list, select the Capsule with OpenSCAP enabled that you want to use.
-
On the Puppet ENC tab, add the
foreman_scap_client
Puppet class. - Optional: Configure any Puppet Class Parameters.
- Click the Hosts breadcrumbs link to navigate back to the host index page.
- Select the host or hosts to which you want to add the policy.
- Click Select Action.
- Select Assign Compliance Policy from the list.
- In the Assign Compliance Policy window, select Remember hosts selection for the next bulk action.
- Select the required policy from the list of available policies and click Submit.
11.9. Running a Security Compliance Scan on Demand
Hosts perform OpenSCAP scans regularly by the CRON schedule defined in the compliance policies assigned to hosts. However, you can also run a scan on a host for all configured compliance policies manually at any time.
Prerequisites
-
Your user account has the
view_hosts
,create_job_invocations
, andview_job_invocations
permissions. You have created a compliance policy and deployed it on the host.
- For more information about managing policies, see Section 11.7, “Managing Compliance Policies”.
- For more information about deploying policies, see Section 11.8, “Deploying Compliance Policies”.
Procedure
- Navigate to Hosts > All Hosts.
- Click the hostname of the required host.
- On the host details page, expand the Schedule a job dropdown menu.
- Select Run OpenSCAP scan.
Verification
- In the host details overview, locate the Recent jobs card.
- Select the Running tab. Unless the job has already finished, the table shows a job called Run scan for all OpenSCAP policies.
- On the Recent jobs card, select the Finished tab.
- If the job has finished successfully, you should see the succeeded status in the row of the job.
- Optional: Click the job name to review invocation details.
11.10. Monitoring Compliance
With Satellite, you can centralize compliance monitoring and management. A compliance dashboard provides an overview of compliance of hosts and the ability to view details for each host within the scope of that policy. Compliance reports provide a detailed analysis of compliance of each host with the applicable policy. With this information, you can evaluate the risks presented by each host and manage the resources required to bring hosts into compliance. By monitoring compliance with SCAP, you can verify policy compliance and detect changes in compliance.
11.10.1. Searching Compliance Reports
Use the Compliance Reports search field to filter the list of available reports on any subset of hosts.
Procedure
- In the Satellite web UI, navigate to Hosts > Reports.
- Optional: To see a list of available search parameters, click the empty Search field.
- Enter the search query in the Search field and click Search. The search query is case insensitive.
Search Query Examples
- Find all compliance reports for which more than five rules failed
failed > 5
- Find all compliance reports created after January 1, 2023, for hosts with hostnames that contain
prod-
host ~ prod- AND date > "Jan 1, 2023"
- Find all reports generated by the
rhel7_audit
compliance policy from an hour ago
"1 hour ago" AND compliance_policy = date = "1 hour ago" AND compliance_policy = rhel7_audit
- Find reports that pass an XCCDF rule
xccdf_rule_passed = xccdf_org.ssgproject.content_rule_firefox_preferences-auto-download_actions
- Find reports that fail an XCCDF rule
xccdf_rule_failed = xccdf_org.ssgproject.content_rule_firefox_preferences-auto-download_actions
- Find reports that have a result different than fail or pass for an XCCDF rule
xccdf_rule_othered = xccdf_org.ssgproject.content_rule_firefox_preferences-auto-download_actions
Additional Information
-
You can create complex queries with the following logical operators:
and
,not
andhas
. For more information about logical operators, see Supported Operators for Granular Search in Administering Red Hat Satellite. - You cannot use regular expressions in a search query. However, you can use multiple fields in a single search expression. For more information about all available search operators, see Supported Operators for Granular Search in Administering Red Hat Satellite.
- You can bookmark a search to reuse the same search query. For more information, see Creating Bookmarks in Administering Red Hat Satellite.
11.10.2. Compliance Email Notifications
Satellite Server sends an OpenSCAP Summary email to all users who subscribe to the Compliance policy summary email notifications. For more information on subscribing to email notifications, see Section 10.2, “Configuring Email Notification Preferences”.
Each time a policy is run, Satellite checks the results against the previous run, noting any changes between them. The email is sent according to the frequency requested by each subscriber, providing a summary of each policy and its most recent result.
11.10.3. Viewing Compliance Policy Statistics
You can view a compliance policy dashboard to verify compliance reports of a particular policy. The compliance policy dashboard provides a statistical summary of compliance of hosts and the ability to view report details for each host within the scope of that policy.
Consider prioritizing the following hosts when viewing compliance reports:
-
Hosts which were evaluated as
Failed
-
Hosts labelled as
Never audited
because their status is unknown
Prerequisite
-
Your user account has the
view_policies
permission.
Procedure
- In the Satellite web UI, navigate to Hosts > Policies.
- In the row of the required policy, navigate to the Actions column and click Dashboard.
11.10.4. Examining Hosts per Rule Compliance Result
You can examine a simplified report and use policy rules to list hosts that have a certain compliance result, such as failing a particular rule.
Prerequisite
-
Your user account has the
view_arf_reports
andview_hosts
permissions.
Procedure
- In the Satellite web UI, navigate to Hosts > Reports.
- In the Reported At column, navigate to the report of the required host and compliance policy, and click the time link.
- Satellite displays a simplified list of policy rules with the results of the scan.
Optional: Filter the rules by check result. From the Show log messages dropdown list, select one of the following filters:
- Failed and othered – to view rules that have failed or have not been checked during the scan,
- Failed only – to view only rules that have failed.
- Optional: Examine the details of the rule. In the Message column, click the icon next to the name of the rule.
- In the row of the required rule, navigate to the Actions column and click Hosts failing this rule.
11.10.5. Examining Compliance Failures of a Host
You can examine a full compliance report, determine why a host failed compliance on a rule, and, in some cases, see how to remediate a case of non-compliance.
Do not implement any of the recommended remedial actions or scripts without first testing them in a non-production environment. Remediation might render the system non-functional.
A compliance report consists of the following areas:
- Introduction
- Evaluation Characteristics
- Compliance and Scoring
- Rule Overview
Prerequisite
-
Your user account has the
view_arf_reports
andview_hosts
permissions.
Procedure
- In the Satellite web UI, navigate to Hosts > Reports to list all compliance reports.
- In the row of the required host, navigate to the Actions column and click Full Report to view the complete details of an evaluation report.
- Navigate to the Evaluation Characteristics area to review basic details about the evaluation of the host against a specific profile.
- Navigate to the Compliance and Scoring area to review evaluation statistics and the host compliance score.
- Navigate to the Rule Overview to examine the rules.
- Optional: Deselect the check statuses that you want to hide, such as pass, notapplicable, or fixed.
- Optional: From the Group rule by dropdown menu, select the criterion for the grouping of rules, such as Severity.
- Optional: Enter a search string into the search field to filter rules by title. The search is case insensitive and applied dynamically as you type.
Click the title of a rule to inspect further result details:
- A description of the rule with instructions for bringing the host into compliance if available.
- The rationale for the rule.
- In some cases, a remediation script.
11.10.6. Deleting a Compliance Report
You can delete compliance reports on your Satellite.
Prerequisite
-
Your user account has the
view_arf_reports
anddestroy_arf_reports
permissions.
Procedure
- In the Satellite web UI, navigate to Hosts > Reports.
- In the Compliance Reports window, identify the policy that you want to delete and, on the right of the policy’s name, select Delete.
- Click OK.
11.10.7. Deleting Multiple Compliance Reports
You can delete multiple compliance policies simultaneously. However, in the Satellite web UI, compliance policies are paginated, so you must delete one page of reports at a time. If you want to delete all OpenSCAP reports, use the script in Deleting OpenSCAP Reports in the API Guide.
Prerequisite
-
Your user account has the
view_arf_reports
anddestroy_arf_reports
permissions.
Procedure
- In the Satellite web UI, navigate to Hosts > Reports.
- In the Compliance Reports window, select the compliance reports that you want to delete.
- In the upper right of the list, select Delete reports.
- Repeat these steps for as many pages as you want to delete.
Chapter 12. Backing Up Satellite Server and Capsule Server
You can back up your Satellite deployment to ensure the continuity of your Red Hat Satellite deployment and associated data in the event of a disaster. If your deployment uses custom configurations, you must consider how to handle these custom configurations when you plan your backup and disaster recovery policy.
If you create a new instance of the Satellite Server, decommission the old instances after restoring the backup. Cloned instances are not supposed to run in parallel in a production environment.
To create a backup of your Satellite Server or Capsule Server and all associated data, use the satellite-maintain backup
command. Backing up to a separate storage device on a separate system is highly recommended.
Satellite services are unavailable during the backup. Therefore, you must ensure that no other tasks are scheduled by other administrators. You can schedule a backup using cron
. For more information, see the Section 12.5, “Example of a Weekly Full Backup Followed by Daily Incremental Backups”.
During offline or snapshot backups, the services are inactive and Satellite is in a maintenance mode. All the traffic from outside on port 443 is rejected by a firewall to ensure there are no modifications triggered.
A backup contains sensitive information from the /root/ssl-build
directory. For example, it can contain hostnames, ssh keys, request files and SSL certificates. You must encrypt or move the backup to a secure location to minimize the risk of damage or unauthorized access to the hosts.
Conventional Backup Methods
You can also use conventional backup methods. For more information, see Recovering and restoring a system in Red Hat Enterprise Linux 8 Configuring basic system settings.
If you plan to use the satellite-maintain backup
command to create a backup, do not stop Satellite services.
When creating a snapshot or conventional backup, you must stop all services as follows:
# satellite-maintain service stop
Start the services after creating a snapshot or conventional backup:
# satellite-maintain service start
12.1. Estimating the Size of a Backup
The full backup creates uncompressed archives of PostgreSQL and Pulp database files, and Satellite configuration files. Compression occurs after the archives are created to decrease the time when Satellite services are unavailable.
A full backup requires space to store the following data:
- Uncompressed Satellite database and configuration files
- Compressed Satellite database and configuration files
- An extra 20% of the total estimated space to ensure a reliable backup
Procedure
Enter the
du
command to estimate the size of uncompressed directories containing Satellite database and configuration files:# du -sh /var/lib/pgsql/data /var/lib/pulp 100G /var/lib/pgsql/data 100G /var/lib/pulp # du -csh /var/lib/qpidd /var/lib/tftpboot /etc /root/ssl-build \ /var/www/html/pub /opt/puppetlabs 886M /var/lib/qpidd 16M /var/lib/tftpboot 37M /etc 900K /root/ssl-build 100K /var/www/html/pub 2M /opt/puppetlabs 942M total
Calculate how much space is required to store the compressed data.
The following table describes the compression ratio of all data items included in the backup:
Table 12.1. Backup Data Compression Ratio Data type Directory Ratio Example results PostgreSQL database files
/var/lib/pgsql/data
80 – 85%
100 GB → 20 GB
Pulp RPM files
/var/lib/pulp
(not compressed)
100 GB
Configuration files
/var/lib/qpidd
/var/lib/tftpboot
/etc
/root/ssl-build
/var/www/html/pub
/opt/puppetlabs
85%
942 MB → 141 MB
In this example, the compressed backup data occupies 120 GB in total.
To calculate the amount of available space you require to store a backup, calculate the sum of the estimated values of compressed and uncompressed backup data, and add an extra 20% to ensure a reliable backup.
This example requires 201 GB plus 120 GB for the uncompressed and compressed backup data, 321 GB in total. With 64 GB of extra space, 385 GB must be allocated for the backup location.
12.2. Performing a Full Backup of Satellite Server or Capsule Server
Red Hat Satellite uses the satellite-maintain backup
command to make backups.
There are three main methods of backing up Satellite Server:
- Offline backup
- Online backup
Snapshot backups
For more information about each of these methods, you can view the usage statements for each backup method.
Offline backups
# satellite-maintain backup offline --help
Online backups
# satellite-maintain backup online --help
Snapshots backups
# satellite-maintain backup snapshot --help
Directory creation
The satellite-maintain backup
command creates a time-stamped subdirectory in the backup directory that you specify. The satellite-maintain backup
command does not overwrite backups, therefore you must select the correct directory or subdirectory when restoring from a backup or an incremental backup. The satellite-maintain backup
command stops and restarts services as required.
When you run the satellite-maintain backup offline
command, the following default backup directories are created:
-
satellite-backup
on Satellite -
foreman-proxy-backup
on Capsule
If you want to set a custom directory name, add the --preserve-directory
option and add a directory name. The backup is then stored in the directory you provide in the command line. If you use the --preserve-directory
option, no data is removed if the backup fails.
Note that if you use a local PostgreSQL database, the postgres
user requires write access to the backup directory.
Remote databases
You can use the satellite-maintain backup
command to back up remote databases.
You can use both online and offline methods to back up remote databases, but if you use offline methods, such as snapshot, the satellite-maintain backup
command performs a database dump.
Prerequisites
- Ensure that your backup location has sufficient available disk space to store the backup. For more information, see Section 12.1, “Estimating the Size of a Backup”.
Request other users of Satellite Server or Capsule Server to save any changes and warn them that Satellite services are unavailable for the duration of the backup. Ensure no other tasks are scheduled for the same time as the backup.
Procedure
On Satellite Server, enter the following command:
# satellite-maintain backup offline /var/satellite-backup
On Capsule Server, enter the following command:
# satellite-maintain backup offline /var/foreman-proxy-backup
12.3. Performing a Backup without Pulp Content
You can perform an offline backup that excludes the contents of the Pulp directory. The backup without Pulp content is useful for debugging purposes and is only intended to provide access to configuration files without backing up the Pulp database. For production usecases, do not restore from a directory that does not contain Pulp content.
Request other users of Satellite Server or Capsule Server to save any changes and warn them that Satellite services are unavailable for the duration of the backup. Ensure no other tasks are scheduled for the same time as the backup.
Prerequisites
- Ensure that your backup location has sufficient available disk space to store the backup. For more information, see Section 12.1, “Estimating the Size of a Backup”.
Procedure
To perform an offline backup without Pulp content, enter the following command:
# satellite-maintain backup offline --skip-pulp-content /var/backup_directory
12.4. Performing an Incremental Backup
Use this procedure to perform an offline backup of any changes since a previous backup.
To perform incremental backups, you must perform a full backup as a reference to create the first incremental backup of a sequence. Keep the most recent full backup and a complete sequence of incremental backups to restore from.
Request other users of Satellite Server or Capsule Server to save any changes and warn them that Satellite services are unavailable for the duration of the backup. Ensure no other tasks are scheduled for the same time as the backup.
Prerequisites
- Ensure that your backup location has sufficient available disk space to store the backup. For more information, see Section 12.1, “Estimating the Size of a Backup”.
Procedure
To perform a full offline backup, enter the following command:
# satellite-maintain backup offline /var/backup_directory
To create a directory within your backup directory to store the first incremental back up, enter the
satellite-maintain backup
command with the--incremental
option:# satellite-maintain backup offline --incremental /var/backup_directory/full_backup /var/backup_directory
To create the second incremental backup, enter the
satellite-maintain backup
command with the--incremental
option and include the path to the first incremental backup to indicate the starting point for the next increment. This creates a directory for the second incremental backup in your backup directory:# satellite-maintain backup offline --incremental /var/backup_directory/first_incremental_backup /var/backup_directory
Optional: If you want to point to a different version of the backup, and make a series of increments with that version of the backup as the starting point, you can do this at any time. For example, if you want to make a new incremental backup from the full backup rather than the first or second incremental backup, point to the full backup directory:
# satellite-maintain backup offline --incremental /var/backup_directory/full_backup /var/backup_directory
12.5. Example of a Weekly Full Backup Followed by Daily Incremental Backups
The following script performs a full backup on a Sunday followed by incremental backups for each of the following days. A new subdirectory is created for each day that an incremental backup is performed. The script requires a daily cron job.
#!/bin/bash -e PATH=/sbin:/bin:/usr/sbin:/usr/bin DESTINATION=/var/backup_directory if [[ $(date +%w) == 0 ]]; then satellite-maintain backup offline --assumeyes $DESTINATION else LAST=$(ls -td -- $DESTINATION/*/ | head -n 1) satellite-maintain backup offline --assumeyes --incremental "$LAST" $DESTINATION fi exit 0
Note that the satellite-maintain backup
command requires /sbin
and /usr/sbin
directories to be in PATH
and the --assumeyes
option is used to skip the confirmation prompt.
12.6. Performing an Online Backup
Perform an online backup only for debugging purposes.
Risks Associated with Online Backups
When performing an online backup, if there are procedures affecting the Pulp database, the Pulp part of the backup procedure repeats until it is no longer being altered. Because the backup of the Pulp database is the most time consuming part of backing up Satellite, if you make a change that alters the Pulp database during this time, the backup procedure keeps restarting.
For production environments, use the snapshot method. For more information, see Section 12.7, “Performing a Snapshot Backup”. If you want to use the online backup method in production, proceed with caution and ensure that no modifications occur during the backup.
Request other users of Satellite Server or Capsule Server to save any changes and warn them that Satellite services are unavailable for the duration of the backup. Ensure no other tasks are scheduled for the same time as the backup.
Prerequisites
- Ensure that your backup location has sufficient available disk space to store the backup. For more information, see Section 12.1, “Estimating the Size of a Backup”.
Procedure
To perform an online backup, enter the following command:
# satellite-maintain backup online /var/backup_directory
12.7. Performing a Snapshot Backup
You can perform a snapshot backup that uses Logical Volume Manager (LVM) snapshots of the Pulp, and PostgreSQL directories. Creating a backup from LVM snapshots mitigates the risk of an inconsistent backup.
The snapshot backup method is faster than a full offline backup and therefore reduces Satellite downtime.
To view the usage statement, enter the following command:
satellite-maintain backup snapshot -h
Request other Satellite Server or Capsule Server users to save any changes and warn them that Satellite services are unavailable for the duration of the backup. Ensure no other tasks are scheduled for the same time as the backup.
Prerequisites
-
The system uses LVM for the directories that you snapshot:
/var/lib/pulp/
, and/var/lib/pgsql
. - The free disk space in the relevant volume group (VG) is three times the size of the snapshot. More precisely, the VG must have enough space unreserved by the member logical volumes (LVs) to accommodate new snapshots. In addition, one of the LVs must have enough free space for the backup directory.
- The target backup directory is on a different LV than the directories that you snapshot.
Procedure
To perform a snapshot backup, enter the
satellite-maintain backup snapshot
command:# satellite-maintain backup snapshot /var/backup_directory
The satellite-maintain backup snapshot
command creates snapshots when the services are active, and stops all services which can impact the backup. This makes the maintenance window shorter. After the successful snapshot, all services are restarted and LVM snapshots are removed.
12.8. White-listing and Skipping Steps When Performing Backups
A backup using the satellite-maintain backup
command proceeds in a sequence of steps. To skip part of the backup add the --whitelist
option to the command and add the step label that you want to omit.
Procedure
To display a list of available step labels, enter the following command:
# satellite-maintain advanced procedure run -h
To skip a step of the backup, enter the
satellite-maintain backup
command with the--whitelist
option. For example:# satellite-maintain backup online --whitelist backup-metadata -y /var/backup_directory
Chapter 13. Restoring Satellite Server or Capsule Server from a Backup
You can restore Satellite Server or Capsule Server from the backup data that you create as part of Chapter 12, Backing Up Satellite Server and Capsule Server. This process outlines how to restore the backup on the same server that generated the backup, and all data covered by the backup is deleted on the target system. If the original system is unavailable, provision a system with the same configuration settings and host name.
13.1. Restoring from a Full Backup
Use this procedure to restore Red Hat Satellite or Capsule Server from a full backup. When the restore process completes, all processes are online, and all databases and system configuration revert to the state at the time of the backup.
Prerequisites
- Ensure that you are restoring to the correct instance. The Red Hat Satellite instance must have the same host name, configuration, and be the same minor version (X.Y) as the original system.
- Ensure that you have an existing target directory. The target directory is read from the configuration files contained within the archive.
Ensure that you have enough space to store this data on the base system of Satellite Server or Capsule Server as well as enough space after the restoration to contain all the data in the
/etc/
and/var/
directories contained within the backup.To check the space used by a directory, enter the following command:
# du -sh /var/backup_directory
To check for free space, enter the following command:
# df -h /var/backup_directory
Add the
--total
option to get a total of the results from more than one directory.Ensure that all SELinux contexts are correct. Enter the following command to restore the correct SELinux contexts:
# restorecon -Rv /
Procedure
Choose the appropriate method to install Satellite or Capsule:
- To install Satellite Server from a connected network, follow the procedures in Installing Satellite Server in a Connected Network Environment.
- To install Satellite Server from a disconnected network, follow the procedures in Installing Satellite Server in a Disconnected Network Environment.
- To install a Capsule Server, follow the procedures in Installing Capsule Server.
-
Copy the backup data to Satellite Server’s local file system. Use
/var/
or/var/tmp/
. Run the restoration script.
# satellite-maintain restore /var/backup_directory
Where backup_directory is the time-stamped directory or subdirectory containing the backed-up data.
The restore process can take a long time to complete, because of the amount of data to copy.
Additional Resources
-
For troubleshooting, you can check
/var/log/foreman/production.log
and/var/log/messages
.
13.2. Restoring from Incremental Backups
Use this procedure to restore Satellite or Capsule Server from incremental backups. If you have multiple branches of incremental backups, select your full backup and each incremental backup for the branch you want to restore, in chronological order.
When the restore process completes, all processes are online, and all databases and system configuration revert to the state at the time of the backup.
Procedure
- Restore the last full backup using the instructions in Section 13.1, “Restoring from a Full Backup”.
-
Remove the full backup data from Satellite Server’s local file system, for example,
/var/
or/var/tmp/
. -
Copy the incremental backup data to Satellite Server’s local file system, for example,
/var/
or/var/tmp/
. Restore the incremental backups in the same sequence that they are made:
# satellite-maintain restore /var/backup_directory/FIRST_INCREMENTAL # satellite-maintain restore /var/backup_directory/SECOND_INCREMENTAL
Additional Resources
-
For troubleshooting, you can check
/var/log/foreman/production.log
and/var/log/messages
.
13.3. Backup and Restore Capsule Server Using a Virtual Machine Snapshot
If your Capsule Server is a virtual machine, you can restore it from a snapshot. Creating weekly snapshots to restore from is recommended. In the event of failure, you can install, or configure a new Capsule Server, and then synchronize the database content from Satellite Server.
If required, deploy a new Capsule Server, ensuring the host name is the same as before, and then install the Capsule certificates. You may still have them on Satellite Server, the package name ends in -certs.tar, alternately create new ones. Follow the procedures in Installing Capsule Server until you can confirm, in the Satellite web UI, that Capsule Server is connected to Satellite Server. Then use the procedure Section 13.3.1, “Synchronizing an External Capsule” to synchronize from Satellite.
13.3.1. Synchronizing an External Capsule
Synchronize an external Capsule with Satellite.
Procedure
- To synchronize an external Capsule, select the relevant organization and location in the Satellite web UI, or choose Any Organization and Any Location.
- In the Satellite web UI, navigate to Infrastructure > Capsules and click the name of the Capsule to synchronize.
- On the Overview tab, select Synchronize.
Chapter 14. Renaming Satellite Server or Capsule Server
To rename Satellite Server or Capsule Server, use the satellite-change-hostname
script.
When changing the domain name of your Satellite Server or Capsule Server, update the hostname using satellite-change-hostname
to avoid networking issues.
14.1. Renaming Satellite Server
The host name of Satellite Server is used by Satellite Server components, all Capsule Servers, and hosts registered to it for communication. This procedure ensures that in addition to renaming Satellite Server, you also update all references to point to the new host name.
Renaming your Satellite Server host shuts down all Satellite services on that host. The services restart after the renaming is complete.
Prerequisites
- Back up your Satellite Server before changing its host name. If you fail to successfully rename it, restore it from the backup. For more information, see Chapter 12, Backing Up Satellite Server and Capsule Server.
Run the
hostname
andhostname -f
commands on Satellite Server. If both commands do not return the FQDN of Satellite Server, thesatellite-change-hostname
script will fail to complete.If the
hostname
command returns the shortname of Satellite Server instead of the FQDN, usehostnamectl set-hostname My_Old_FQDN
to set the old FQDN correctly before using thesatellite-change-hostname
script.- If Satellite Server has a custom SSL certificate installed, obtain a new certificate for the new FQDN of the host. For more information, see Configuring Satellite Server with a Custom SSL Certificate in Installing Satellite Server in a Connected Network Environment.
Procedure
On Satellite Server, run the
satellite-change-hostname
script, and provide the new host name. Choose one of the following methods:If your Satellite Server is installed with the default self-signed SSL certificates, enter the following command:
# satellite-change-hostname new-satellite \ --username admin \ --password password
If your Satellite Server is installed with custom SSL certificates:
# satellite-change-hostname new-satellite \ --username admin \ --password password \ --custom-cert "/root/ownca/test.com/test.com.crt" \ --custom-key "/root/ownca/test.com/test.com.key"
- If you have created a custom SSL certificate for the new Satellite Server host name, run the Satellite installation script to install the certificate. For more information about installing a custom SSL certificate, see Deploying a Custom SSL Certificate to Satellite Server in Installing Satellite Server in a Connected Network Environment.
- Reregister all Satellite hosts. For more information, see Registering Hosts in Managing Hosts.
On all Capsule Servers, run the Satellite installation script to update references to the new host name:
# satellite-installer \ --foreman-proxy-foreman-base-url https://new-satellite.example.com \ --foreman-proxy-trusted-hosts new-satellite.example.com \ --puppet-server-foreman-url https://new-satellite.example.com
On Satellite Server, list all Capsule Servers:
# hammer capsule list
On Satellite Server, synchronize content for each Capsule Server:
# hammer capsule content synchronize \ --id My_capsule_ID
- If you use the virt-who agent, update the virt-who configuration files with the new host name. For more information, see Modifying a virt-who Configuration in Configuring Virtual Machine Subscriptions in Red Hat Satellite.
-
If you use external authentication, reconfigure Satellite Server for external authentication after you run the
satellite-change-hostname
script. For more information, see Configuring External Authentication in Installing Satellite Server in a Connected Network Environment.
14.2. Renaming Capsule Server
The host name of Capsule Server is referenced by Satellite Server components and all hosts registered to it. This procedure ensures that in addition to renaming Capsule Server, you also update all references to the new host name.
Renaming your Capsule Server host shuts down all Satellite services on that host. The services restart after the renaming is complete.
Prerequisites
- Back up your Capsule Server before renaming. If you fail to successfully rename it, restore it from the backup. For more information, see Chapter 12, Backing Up Satellite Server and Capsule Server.
Run the
hostname
andhostname -f
commands on Capsule Server. If both commands do not return the FQDN of Capsule Server, thesatellite-change-hostname
script will fail to complete.If the
hostname
command returns the shortname of Capsule Server instead of the FQDN, usehostnamectl set-hostname My_Old_FQDN
to set the old FQDN correctly before attempting to use thesatellite-change-hostname
script.
Procedure
On Satellite Server, generate a new certificates archive file for Capsule Server.
If you are using the default SSL certificate, enter the following command:
# capsule-certs-generate \ --foreman-proxy-fqdn new-capsule.example.com \ --certs-tar /root/new-capsule.example.com-certs.tar
Ensure that you enter the full path to the
.tar
file.- If you are using a custom SSL certificate, create a new SSL certificate for Capsule Server. For more information, see Configuring Capsule Server with a Custom SSL Certificate in Installing Capsule Server.
On Satellite Server, copy the certificates archive file to Capsule Server. For example, to copy the archive file to the
root
user’s home directory:# scp /root/new-capsule.example.com-certs.tar root@capsule.example.com:
On Capsule Server, run the
satellite-change-hostname
script and provide the host’s new name, Satellite credentials, and certificates archive file name.# satellite-change-hostname new-capsule.example.com --username admin \ --password password \ --certs-tar /root/new-capsule.example.com-certs.tar
Ensure that you enter the full path to the
.tar
file.-
If you have created a custom certificate for Capsule Server, deploy the certificate on Capsule Server by entering the
satellite-installer
command that thecapsule-certs-generate
command returned in a previous step. For more information, see Deploying a Custom SSL Certificate to Capsule Server in Installing Capsule Server. On all Capsule clients, enter the following commands to reinstall the bootstrap RPM, reregister clients, and refresh their subscriptions.
You can use the remote execution feature to perform this step. For more information, see Configuring and Setting up Remote Jobs in Managing Hosts.
# dnf remove katello-ca-consumer* # dnf install http://new-capsule.example.com/pub/katello-ca-consumer-latest.noarch.rpm # subscription-manager register --org="My_Organization" \ --environment="Library" \ --force # subscription-manager refresh
Update the Capsule host name in the Satellite web UI.
- In the Satellite web UI, navigate to Infrastructure > Capsules.
- Locate Capsule Server in the list, and click Edit.
- Edit the Name and URL fields to match Capsule Server’s new host name, then click Submit.
- On your DNS server, add a record for the new hostname of your Capsule Server, and delete the record of the previous host name.
Chapter 15. Maintaining Satellite Server
This chapter provides information on how to maintain a Satellite Server, including information on how to work with audit records, how to clean unused tasks, and how to recover Pulp from a full disk.
15.1. Deleting Audit Records Manually
You can use the foreman-rake audits:expire
command to remove audit records at any time.
Procedure
Delete the audit records using the
foreman-rake audits:expire
command:# foreman-rake audits:expire days=Number_Of_Days
This command deletes all audit records older than
Number_Of_Days
.
15.2. Deleting Audit Records Automatically
You can automatically delete audit records using the Saved audits interval
setting. This setting is empty by default, meaning Satellite does not automatically delete the audit records.
Procedure
- In the Satellite web UI, navigate to Administer > Settings.
- On the General tab, find the Saved audits interval setting.
- Set the value of the setting to the number of days after which you want Satellite to delete the audit records.
15.3. Anonymizing Audit Records
You can use the foreman-rake audits:anonymize
command to remove any user account or IP information while maintaining the audit records in the database. You can also use a cron job to schedule anonymizing the audit records at the set interval that you want.
By default, using the foreman-rake audits:anonymize
command anonymizes audit records that are older than 90 days. You can specify the number of days to keep the audit records by adding the days option and add the number of days.
For example, if you want to anonymize audit records that are older than seven days, enter the following command:
# foreman-rake audits:anonymize days=7
15.4. Deleting Report Records
Report records are created automatically in Satellite. You can use the foreman-rake reports:expire
command to remove reports at any time. You can also use a cron job to schedule report record deletions at the set interval that you want.
By default, using the foreman-rake reports:expire
command removes report records that are older than 90 days. You can specify the number of days to keep the report records by adding the days option and add the number of days.
For example, if you want to delete report records that are older than seven days, enter the following command:
# foreman-rake reports:expire days=7
15.5. Configuring the Cleaning Unused Tasks Feature
Satellite performs regular cleaning to reduce disc space in the database and limit the rate of disk growth. As a result, Satellite backup completes faster and overall performance is higher.
By default, Satellite executes a cron job that cleans tasks every day at 19:45. Satellite removes the following tasks during the cleaning:
- Tasks that have run successfully and are older than thirty days
- All tasks that are older than a year
You can configure the cleaning unused tasks feature using these options:
To configure the time at which Satellite runs the cron job, set the
--foreman-plugin-tasks-cron-line
parameter to the time you want in cron format. For example, to schedule the cron job to run every day at 15:00, enter the following command:# satellite-installer --foreman-plugin-tasks-cron-line "00 15 * * *"
-
To configure the period after which Satellite deletes the tasks, edit the
:rules:
section in the/etc/foreman/plugins/foreman-tasks.yaml
file. To disable regular task cleanup on Satellite, enter the following command:
# satellite-installer --foreman-plugin-tasks-automatic-cleanup false
To reenable regular task cleanup on Satellite, enter the following command:
# satellite-installer --foreman-plugin-tasks-automatic-cleanup true
15.6. Deleting Task Records
Task records are created automatically in Satellite. You can use the foreman-rake foreman_tasks:cleanup
command to remove tasks at any time. You can also use a cron job to schedule Task record deletions at the set interval that you want.
For example, if you want to delete task records from successful repository synchronizations, enter the following command:
# foreman-rake foreman_tasks:cleanup TASK_SEARCH='label = Actions::Katello::Repository::Sync' STATES='stopped'
15.7. Deleting a Task by ID
You can delete tasks by ID, for example if you have submitted confidential data by mistake.
Procedure
Connect to your Satellite Server using SSH:
# ssh root@satellite.example.com
Optional: View the task:
# hammer task info --id My_Task_ID
Delete the task:
# foreman-rake foreman_tasks:cleanup TASK_SEARCH="id=My_Task_ID"
Optional: Ensure the task has been removed from Satellite Server:
# hammer task info --id My_Task_ID
Note that because the task is deleted, this command returns a non-zero exit code.
15.8. Recovering from a Full Disk
The following procedure describes how to resolve the situation when a logical volume (LV) with the Pulp database on it has no free space.
Procedure
- Let running Pulp tasks finish but do not trigger any new ones as they can fail due to the full disk.
Ensure that the LV with the
/var/lib/pulp
directory on it has sufficient free space. Here are some ways to achieve that:Remove orphaned content:
# foreman-rake katello:delete_orphaned_content RAILS_ENV=production
This is run weekly so it will not free much space.
- Change the download policy from Immediate to On Demand for as many repositories as possible and remove already downloaded packages. See the Red Hat Knowledgebase solution How to change syncing policy for Repositories on Satellite from "Immediate" to "On-Demand" on the Red Hat Customer Portal for instructions.
Grow the file system on the LV with the
/var/lib/pulp
directory on it. For more information, see Growing a logical volume and file system in Red Hat Enterprise Linux 8 Configuring and managing logical volumes.NoteIf you use an untypical file system (other than for example ext3, ext4, or xfs), you might need to unmount the file system so that it is not in use. In that case, complete the following steps:
Stop Satellite services:
# satellite-maintain service stop
- Grow the file system on the LV.
Start Satellite services:
# satellite-maintain service start
- If some Pulp tasks failed due to the full disk, run them again.
15.9. Managing Packages on the Base Operating System of Satellite Server or Capsule Server
To install and update packages on the Satellite Server or Capsule Server base operating system, you must enter the satellite-maintain packages
command. Satellite prevents users from installing and updating packages with yum
because yum
might also update the packages related to Satellite Server or Capsule Server and result in system inconsistency.
The satellite-maintain packages
command restarts some services on the operating system where you run it because it runs the satellite-installer
command after installing packages.
You can manage packages using the satellite-maintain packages
command as follows:
To install packages on Satellite Server or Capsule Server:
# satellite-maintain packages install package_1 package_2
To check for available package updates on Satellite Server or Capsule Server:
# satellite-maintain packages check-update
To update all packages on Satellite Server or Capsule Server:
# satellite-maintain packages update
To update specific packages on Satellite Server or Capsule Server:
# satellite-maintain packages update package_1 package_2
Updating packages individually can lead to package inconsistencies on Satellite Server or Capsule Server. For more information about updating packages on Satellite Server, see Updating Satellite Server to the Next Minor Version in Upgrading and Updating Red Hat Satellite.
15.10. Reclaiming PostgreSQL Space
The PostgreSQL database can use a large amount of disk space especially in heavily loaded deployments. Use this procedure to reclaim some of this disk space on Satellite.
Procedure
Stop all services, except for the
postgresql
service:# satellite-maintain service stop --exclude postgresql
Switch to the
postgres
user and reclaim space on the database:# su - postgres -c 'vacuumdb --full --all'
Start the other services when the vacuum completes:
# satellite-maintain service start
15.11. Reclaiming Space From On Demand Repositories
If you set the download policy to on demand, Satellite downloads packages only when the clients request them. You can clean up these packages to reclaim space.
Space reclamation requires an existing repository. For deleted repositories, wait for the next scheduled orphan cleanup or remove orphaned content manually:
# foreman-rake katello:delete_orphaned_content
For a single repository
- In the Satellite web UI, navigate to Content > Products.
- Select a product.
- On the Repositories tab, click the repository name.
- From the Select Actions list, select Reclaim Space.
For multiple repositories
- In the Satellite web UI, navigate to Content > Products.
- Select the product name.
- On the Repositories tab, select the checkbox of the repositories.
- Click Reclaim Space at the top right corner.
For Capsules
- In the Satellite web UI, navigate to Infrastructure > Capsules.
- Select the Capsule Server.
- Click Reclaim space.
Chapter 16. Renewing the Custom SSL Certificate
This chapter provides information on how to renew the custom SSL certificate on Satellite Server as well as on Capsule Server.
16.1. Renewing a Custom SSL Certificate on Satellite Server
Use this procedure to update your custom SSL certificate for Satellite Server.
Prerequisite
-
You must create a new Certificate Signing Request (CSR) and send it to the Certificate Authority to sign the certificate. Refer to the Configuring Satellite Server with a Custom SSL Certificate guide before creating a new CSR because the Server certificate must have X.509 v3
Key Usage
andExtended Key Usage
extensions with required values. In return, you will receive the Satellite Server certificate and CA bundle.
Procedure
Before deploying a renewed custom certificate on your Satellite Server, validate the custom SSL input files. Note that for the
katello-certs-check
command to work correctly, Common Name (CN) in the certificate must match the FQDN of Satellite Server:# katello-certs-check -t satellite \ -b /root/satellite_cert/ca_cert_bundle.pem \ -c /root/satellite_cert/satellite_cert.pem \ -k /root/satellite_cert/satellite_cert_key.pem
If the command is successful, it returns the following
satellite-installer
command. You can use this command to deploy the renewed CA certificates to Satellite Server:# satellite-installer --scenario satellite \ --certs-server-cert "/root/satellite_cert/satellite_cert.pem" \ --certs-server-key "/root/satellite_cert/satellite_key.pem" \ --certs-server-ca-cert "/root/satellite_cert/ca_cert_bundle.pem" \ --certs-update-server \ --certs-update-server-ca
Do not delete the certificate files after you deploy the certificate. They are required when upgrading Satellite Server.
If a new consumer package katello-ca-consumer-latest.noarch.rpm
is generated due to a different Certificate Signing Authority, all the clients registered to Satellite Server must be updated.
Verification
- Access the Satellite web UI from your local machine. For example, https://satellite.example.com.
- In your browser, view the certificate details to verify the deployed certificate.
16.2. Renewing a Custom SSL certificate on Capsule Server
Use this procedure to update your custom SSL certificate for Capsule Server. The satellite-installer
command, which the capsule-certs-generate
command returns, is unique to each Capsule Server. You cannot use the same command on more than one Capsule Server.
Prerequisite
-
You must create a new Certificate Signing Request and send it to the Certificate Authority to sign the certificate. Refer to the Configuring Satellite Server with a Custom SSL Certificate guide before creating a new CSR because the Satellite Server certificate must have X.509 v3
Key Usage
andExtended Key Usage
extensions with required values. In return, you will receive the Capsule Server certificate and CA bundle.
Procedure
On your Satellite Server, validate the custom SSL certificate input files:
# katello-certs-check -t capsule \ -b /root/capsule_cert/ca_cert_bundle.pem \ -c /root/capsule_cert/capsule_cert.pem \ -k /root/capsule_cert/capsule_cert_key.pem
On your Satellite Server, generate the certificate archive file for your Capsule Server:
capsule-certs-generate --foreman-proxy-fqdn "capsule.example.com" \ --certs-tar "/root/My_Certificates/capsule.example.com-certs.tar" \ --server-cert "/root/My_Certificates/capsule_cert.pem" \ --server-key "/root/My_Certificates/capsule_cert_key.pem" \ --server-ca-cert "/root/My_Certificates/ca_cert_bundle.pem" \ --certs-update-server
On your Satellite Server, copy the certificate archive file to your Capsule Server:
# scp /root/My_Certificates/capsule.example.com-certs.tar user@capsule.example.com:
You can move the copied file to the applicable path if required.
-
Retain a copy of the
satellite-installer
command that thecapsule-certs-generate
command returns for deploying the certificate to your Capsule Server. Deploy the certificate on your Capsule Server using the
satellite-installer
command returned by thecapsule-certs-generate
command:# satellite-installer --scenario capsule \ --foreman-proxy-register-in-foreman "true" \ --foreman-proxy-foreman-base-url "https://satellite.example.com" \ --certs-tar-file "/root/My_Certificates/capsule.example.com-certs.tar" \ --certs-update-server
Do not delete the certificate archive file on the Capsule Server after you deploy the certificate. They are required when upgrading Capsule Server.
If a new consumer package katello-ca-consumer-latest.noarch.rpm
is generated due to a different Certificate Signing Authority, all the clients registered to Capsule Server must be updated.
Chapter 17. Logging and Reporting Problems
This chapter provides information on how to log and report problems in Satellite, including information on relevant log files, how to enable debug logging, how to open a support case and attach the relevant log tar files, and how to access support cases within the Satellite web UI.
You can use the log files and other information described in this chapter to do your own troubleshooting, or you can capture these and many more files, as well as diagnostic and configuration information, to send to Red Hat Support if you need further assistance.
For more information about Satellite logging settings, use satellite-installer
with the --full-help
option:
# satellite-installer --full-help | grep logging
17.1. Enabling Debug Logging
Debug logging provides the most detailed log information and can help with troubleshooting issues that can arise with Satellite and its components. In the Satellite CLI, enable debug logging to log detailed debugging information for Satellite.
Procedure
To enable debug logging, enter the following command:
# satellite-installer --foreman-logging-level debug
After you complete debugging, reset the logging level to the default value:
# satellite-installer --reset-foreman-logging-level
17.2. Increasing the Logging Levels to Help with Debugging
By default, Satellite comes with :INFO
level logging enabled. You can increase or decrease the log levels on your Satellite.
Enabling debug level logging on all components
# hammer admin logging --all --level-debug # satellite-maintain service restart
Enabling debug level logging for a specific component
# hammer admin logging --components "Component" --level-debug
Reverting debug level logging to INFO
# hammer admin logging --all --level-production # satellite-maintain service restart
Listing all components and changed configuration files
# hammer admin logging --list -----------|-------------------------------------|------------------------------------- COMPONENT | AUTO-DETECTED BY EXISTENCE OF | DESTINATIONS -----------|-------------------------------------|------------------------------------- dhcpd | /etc/dhcp/dhcpd.conf | syslog /var/log/dhcpd-debug.log postgresql | /var/lib/pgsql/data/postgresql.conf | syslog /var/lib/pgsql/data/pg_log/ proxy | /etc/foreman-proxy/settings.yml | /var/log/foreman-proxy/proxy.log qpidd | /etc/qpid/qpidd.conf | syslog rails | /etc/foreman/settings.yaml | /var/log/foreman/production.log tomcat | /etc/candlepin/candlepin.conf | /var/log/candlepin/ /var/log/tomcat/ virt-who | /etc/sysconfig/virt-who | syslog -----------|-------------------------------------|-------------------------------------
17.2.1. Increasing the Logging Level For Hammer
You can find the log for Hammer in ~/.hammer/log/hammer.log
. Edit /etc/hammer/cli_config.yml
and set the :log_level:
:
:log_level: 'debug'
17.2.2. Increasing the Logging Level On Capsule
You can find the log for Capsule in /var/log/foreman-proxy/proxy.log
. Uncomment the DEBUG
line in /etc/foreman-proxy/settings.yml
:
:log_level: DEBUG
Ensure to restart the foreman-proxy
service afterwards:
# systemctl restart foreman-proxy
Running the installer will revert this change back.
17.2.3. Increasing the Logging Level For Candlepin
You can find the log for Candlepin in /var/log/candlepin/candlepin.log
. Errors are also logged to a separate file for easier debugging /var/log/candlepin/error.log
.
Extend /etc/candlepin/candlepin.conf
:
log4j.logger.org.candlepin=DEBUG
Ensure to restart the tomcat
service afterwards:
# systemctl restart tomcat
If the candlepin log files are too verbose, you can decrease the default debug level:
log4j.logger.org.candlepin.resource.ConsumerResource=WARN log4j.logger.org.candlepin.resource.HypervisorResource=WARN
17.2.4. Increasing the Logging Level On Satellite
You can find the log for Satellite in /var/log/foreman/production.log
.
Satellite stores logs for Apache in:
-
/var/log/httpd/foreman_error.log
-
/var/log/httpd/foreman_access.log
-
/var/log/httpd/foreman_ssl_error.log
-
/var/log/httpd/foreman_ssl_access.log
Procedure
Set the logging level in
/etc/foreman/settings.yaml
::logging: :production: :type: file :layout: pattern :level: debug
Enable selected loggers in
/etc/foreman/settings.yaml
::loggers: :ldap: :enabled: true :permissions: :enabled: true :sql: :enabled: true
Note that to see logging from some area, debug logging has to be set.
Restart Satellite services:
# satellite-maintain service restart
You can find the complete list of loggers with their default values in /usr/share/foreman/config/application.rb
in the Foreman::Logging.add_loggers
command.
17.2.5. Increasing the Logging Level For Qpid Dispatch Router
Qpid logs to syslog and can be viewed in /var/log/messages
or with journalctl
. Enable debug logging in /etc/qpid-dispatch/qdrouterd.conf
:
enable: debug+
Ensure to restart the Qpid Dispatch Router afterwards:
# systemctl restart qdrouterd
Running the installer will revert this change back.
17.2.6. Increasing the Logging Level For Qpid Broker
Qpid logs to syslog and can be viewed in /var/log/messages
or with journalctl
. Set the log level in /etc/qpid/qpidd.conf
:
log-enable=debug+
Ensure to restart the Qpid Broker afterwards:
# systemctl restart qpidd
Running the installer will revert this change.
17.2.7. Increasing the Logging Level For Redis
You can find the log for Redis in /var/log/redis/redis.log
. Set the log level in /etc/opt/rh/rh-redis5/redis.conf
:
loglevel debug
Ensure to restart the Redis service afterwards:
# systemctl restart rh-redis5-redis
17.2.8. Increasing the Logging Level For Postgres
You can find the log for Postgres in /var/lib/pgsql/data/log
. Uncomment the log_statement
in /var/lib/pgsql/data/postgresql.conf
:
log_statement = 'all'
Ensure to restart Satellite services afterwards:
# satellite-maintain service restart
Based on the size of your Satellite installation, this can cause disk space to fill up very quickly. Only turn this on if absolutely needed.
For more debug log settings, refer to the Postgresql documentation.
17.2.9. Increasing the Logging Level For Satellite Installer
You can find the log files in /var/log/foreman-installer/
. To increase the log level of the Satellite Installer during an install:
# satellite-installer --verbose-log-level debug
17.2.10. Increasing the Logging Level For Pulp
By default, Pulp logs to syslog and can be viewed in /var/log/messages
or with journalctl
. Add the following config to the /etc/pulp/settings.py
file:
LOGGING = {"dynaconf_merge": True, "loggers": {'': {'handlers': ['console'], 'level': 'DEBUG'}}}
Ensure to restart the Pulp services afterwards:
# systemctl restart \ pulpcore-api \ pulpcore-content \ pulpcore-resource-manager \ pulpcore-worker@1 \ pulpcore-worker@2 \ rh-redis5-redis
17.2.11. Increasing the Logging Level For Puppet Agent
You can increase the logging level for Puppet agent on your Satellite Server.
Procedure
Add the following line to the
[agent]
block in the/etc/puppetlabs/puppet/puppet.conf
file:[agent] log_level = debug
You can find the logs in /var/log/puppetlabs/puppet/
17.2.12. Increasing the Logging Level For Puppet Server
You can increase the logging level for Puppet server on your Satellite Server.
Prerequisite
- Puppet must be enabled in your Satellite. For more information, see Enabling Puppet Integration with Satellite in Managing Configurations Using Puppet Integration in Red Hat Satellite.
Procedure
Add the following line to the
[master]
block in/etc/puppetlabs/puppet/puppet.conf
file:[master] log_level = debug
Restart the Puppet server:
# satellite-maintain service restart --only puppetserver
You can find the logs in /var/log/puppetlabs/puppetserver/
.
17.3. Retrieving the Status of Services
Procedure
- In the Satellite web UI, navigate to Administer > About.
- On the Smart Proxies tab, you can view the status of all Capsules.
- On the Compute Resources tab, you can view the status of attached compute resource providers.
- In the Backend System Status table, you can view the status of all back-end services.
CLI procedure
Run
hammer ping
to get information from the database and Satellite services:# hammer ping
Use
satellite-maintain
to check the status of the services running in systemd:# satellite-maintain service status
Use
satellite-maintain
to perform a health check:$ satellite-maintain health check
17.4. Restarting Services
Satellite uses a set of back-end services to perform tasks. You you experience an issue with your Satellite, check the status of Satellite services.
Procedure
Use
satellite-maintain
to restart Satellite services:# satellite-maintain service restart
Run foreman-maintain --help
for more information.
17.5. Enabling Individual Loggers
You can enable individual loggers for selective logging. Satellite uses the following loggers:
app
- Logs web requests and all general application messages. Default value: true.
audit
- Logs additional fact statistics, numbers of added, updated, and removed facts. Default value: true.
background
- Logs information from the background processing component.
blob
Logs contents of rendered templates for auditing purposes.
ImportantThe
blob
logger might contain sensitive data.dynflow
- Logs information from the Dynflow process.
ldap
- Logs high level LDAP queries and LDAP operations. Default value: false.
notifications
- Logs information from the notifications component.
permissions
- Logs queries to user roles, filters, and permissions when loading pages. Default value: false.
sql
- Logs SQL queries made through Rails ActiveRecord. Default value: false.
telemetry
- Logs debugging information from telemetry.
templates
- Logs information from the template renderer component.
Procedure
Enable the individual loggers that you want. For example, to enable
sql
andldap
loggers, enter the following command:# satellite-installer \ --foreman-loggers ldap:true \ --foreman-loggers sql:true
Optional: To reset loggers to their default values, enter the following command:
# satellite-installer --reset-foreman-loggers
17.6. Configuring Logging to Journal or File-based Logging
Satellite uses file-based logging by default. You can use the satellite-installer
command to reconfigure logging.
Procedure for configuring logging with Journal
Enter the following
satellite-installer
command to configure logging to thejournald
service:# satellite-installer \ --foreman-logging-layout pattern \ --foreman-logging-type journald \ --foreman-proxy-log JOURNAL
Optional: To inspect the log messages, use the
journalctl
utility. For example:-
journalctl --unit foreman
andjournalctl --unit foreman-proxy
show messages for theforeman
andforeman-proxy
units -
journalctl REQUEST=request_ID
shows messages for a specified request
-
Procedure for configuring file-based logging
Enter the following
satellite-installer
command to configure file-based logging:# satellite-installer \ --reset-foreman-logging-layout \ --reset-foreman-logging-type \ --reset-foreman-proxy-log
Optional: To inspect the log messages, view these files:
-
/var/log/foreman/production.log
-
/var/log/foreman-proxy.log
-
Additional resources
For more information about Journal, see Viewing logs using the command line in the Red Hat Enterprise Linux 8 Configuring Basic System Settings Guide.
17.7. Log File Directories Provided by Satellite
Red Hat Satellite provides system information in the form of notifications and log files.
Log File Directories | Description of Log File Content |
---|---|
| Subscription management |
| Installer |
| Foreman maintain |
| Foreman proxy |
| Foreman |
| Apache HTTP server |
| Various other log messages |
| Configuration management |
| Subscription management |
| Candlepin webservice logs |
You can also use the foreman-tail
command to follow many of the log files related to Satellite. You can run foreman-tail -l
to list the processes and services that it follows.
17.8. Utilities for Collecting Log Information
You can collect information from log files to troubleshoot Satellite.
- sosreport
-
The
sosreport
command collects configuration and diagnostic information from a Linux system, such as the running Kernel version, loaded modules, running services, and system and service configuration files. This output is stored in a tar file located at/var/tmp/sosreport-XXX-20171002230919.tar.xz
. For more information, runsosreport --help
or see What is a sosreport and how can I create one?.
The collection process removes security information such as passwords, tokens, and keys while collecting information. However, the tar files can still contain sensitive information about the Satellite Server. Red Hat recommends that you send this information directly to the intended recipient and not to a public target.
17.9. System Journal Metadata
The following table lists metadata that the journald
service uses in Satellite. You can use this metadata to filter your queries.
Name | Description |
---|---|
AUDIT_ACTION | Audit action performed Example: Create, update, or delete |
AUDIT_TYPE | Audit resource type Example: Host, Subnet, or ContentView |
AUDIT_ID | Audit resource database ID as a number |
AUDIT_ATTRIBUTE | Audit resource field or an updated database column |
AUDIT_FIELD_OLD | Old audit value of an update action |
AUDIT_FIELD_NEW | New audit value of an update action |
AUDIT_ID | Record database ID of the audit subject |
AUDIT_ATTRIBUTE | Attribute name or column on which an action was performed Example: Name or description |
EXCEPTION_MESSAGE | Exception message when error is logged |
EXCEPTION_CLASS | Exception Ruby class when error is logged |
EXCEPTION_BACKTRACE | Exception backtrace as a multiline string when error is logged |
LOC_ID | Location database ID |
LOC_NAME | Location name |
LOC_LABEL | Location label |
LOGGER | Logger name To see the current list of loggers enabled by default, enter this command: # awk '/add_loggers/,/^$/' /usr/share/foreman/config/application.rb |
ORG_ID | Organization database ID |
ORG_NAME | Organization name |
ORG_LABEL | Organization label |
REMOTE_IP | Remote IP address of a client |
REQUEST | Request ID generated by the Action Dispatch module |
SESSION | Random ID generated per session or a request for a sessionless request |
TEMPLATE_NAME | Template name |
TEMPLATE_DIGEST | Digest (SHA256) of rendered template contents |
TEMPLATE_HOST_NAME | Host name for a rendered template if present |
TEMPLATE_HOST_ID | Host database ID for a rendered template if present |
USER_LOGIN | User login name |
Chapter 18. Monitoring Resources
The following chapter details how to configure monitoring and reporting for managed systems. This includes host configuration, Content Views, compliance, subscriptions, registered hosts, promotions, and synchronization.
18.1. Using the Red Hat Satellite Content Dashboard
The Red Hat Satellite content dashboard contains various widgets which provide an overview of the host configuration, Content Views, compliance reports, subscriptions and hosts currently registered, promotions and synchronization, and a list of the latest notifications.
In the Satellite web UI, navigate to Monitor > Dashboard to access the content dashboard. The dashboard can be rearranged by clicking on a widget and dragging it to a different position. The following widgets are available:
- Host Configuration Status
An overview of the configuration states and the number of hosts associated with it during the last reporting interval. The following table shows the descriptions of the possible configuration states.
Table 18.1. Host Configuration States Icon State Description Hosts that had performed modifications without error
Host that successfully performed modifications during the last reporting interval.
Hosts in error state
Hosts on which an error was detected during the last reporting interval.
Good host reports in the last 35 minutes
Hosts without error that did not perform any modifications in the last 35 minutes.
Hosts that had pending changes
Hosts on which some resources would be applied but Puppet was configured to run in the
noop
mode.Out of sync hosts
Hosts that were not synchronized and the report was not received during the last reporting interval.
Hosts with no reports
Hosts for which no reports were collected during the last reporting interval.
Hosts with alerts disabled
Hosts which are not being monitored.
Click the particular configuration status to view hosts associated with it.
- Host Configuration Chart
- A pie chart shows the proportion of the configuration status and the percentage of all hosts associated with it.
- Latest Events
A list of messages produced by hosts including administration information, product and subscription changes, and any errors.
Monitor this section for global notifications sent to all users and to detect any unusual activity or errors.
- Run Distribution (last 30 minutes)
- A graph shows the distribution of the running Puppet agents during the last puppet interval which is 30 minutes by default. In this case, each column represents a number of reports received from clients during 3 minutes.
- New Hosts
- A list of the recently created hosts. Click the host for more details.
- Task Status
- A summary of all current tasks, grouped by their state and result. Click the number to see the list of corresponding tasks.
- Latest Warning/Error Tasks
- A list of the latest tasks that have been stopped due to a warning or error. Click a task to see more details.
- Discovered Hosts
- A list of all bare-metal hosts detected on the provisioning network by the Discovery plug-in.
- Latest Errata
- A list of all errata available for hosts registered to Satellite.
- Content Views
- A list of all Content Views in Satellite and their publish status.
- Sync Overview
- An overview of all products or repositories enabled in Satellite and their synchronization status. All products that are in the queue for synchronization, are unsynchronized or have been previously synchronized are listed in this section.
- Host Subscription Status
An overview of the subscriptions currently consumed by the hosts registered to Satellite. A subscription is a purchased certificate that unlocks access to software, upgrades, and security fixes for hosts. The following table shows the possible states of subscriptions.
Table 18.2. Host Subscription States Icon State Description Invalid
Hosts that have products installed, but are not correctly subscribed. These hosts need attention immediately.
Partial
Hosts that have a subscription and a valid entitlement, but are not using their full entitlements. These hosts should be monitored to ensure they are configured as expected.
Valid
Hosts that have a valid entitlement and are using their full entitlements.
Click the subscription type to view hosts associated with subscriptions of the selected type.
- Subscription Status
- An overview of the current subscription totals that shows the number of active subscriptions, the number of subscriptions that expire in the next 120 days, and the number of subscriptions that have recently expired.
- Host Collections
- A list of all host collections in Satellite and their status, including the number of content hosts in each host collection.
- Virt-who Configuration Status
An overview of the status of reports received from the
virt-who
daemon running on hosts in the environment. The following table shows the possible states.Table 18.3. Virt-who Configuration States State Description No Reports
No report has been received because either an error occurred during the virt-who configuration deployment, or the configuration has not been deployed yet, or virt-who cannot connect to Satellite during the scheduled interval.
No Change
No report has been received because hypervisor did not detect any changes on the virtual machines, or virt-who failed to upload the reports during the scheduled interval. If you added a virtual machine but the configuration is in the No Change state, check that virt-who is running.
OK
The report has been received without any errors during the scheduled interval.
Total Configurations
A total number of virt-who configurations.
Click the configuration status to see all configurations in this state.
The widget also lists the three latest configurations in the No Change state under Latest Configurations Without Change.
- Latest Compliance Reports
- A list of the latest compliance reports. Each compliance report shows a number of rules passed (P), failed (F), or othered (O). Click the host for the detailed compliance report. Click the policy for more details on that policy.
- Compliance Reports Breakdown
- A pie chart shows the distribution of compliance reports according to their status.
- Red Hat Insights Actions
- Red Hat Insights is a tool embedded in Satellite that checks the environment and suggests actions you can take. The actions are divided into 4 categories: Availability, Stability, Performance, and Security.
- Red Hat Insights Risk Summary
A table shows the distribution of the actions according to the risk levels. Risk level represents how critical the action is and how likely it is to cause an actual issue. The possible risk levels are: Low, Medium, High, and Critical.
NoteIt is not possible to change the date format displayed in the Satellite web UI.
18.1.1. Managing Tasks
Red Hat Satellite keeps a complete log of all planned or performed tasks, such as repositories synchronised, errata applied, and Content Views published. To review the log, navigate to Monitor > Tasks.
In the Task window, you can search for specific tasks, view their status, details, and elapsed time since they started. You can also cancel and resume one or more tasks.
The tasks are managed using the Dynflow engine. Remote tasks have a timeout which can be adjusted as needed.
To Adjust Timeout Settings:
- In the Satellite web UI, navigate to Administer > Settings.
- Enter %_timeout in the search box and click Search. The search should return four settings, including a description.
- In the Value column, click the icon next to a number to edit it.
- Enter the desired value in seconds, and click Save.
Adjusting the %_finish_timeout values might help in case of low bandwidth. Adjusting the %_accept_timeout values might help in case of high latency.
When a task is initialized, any back-end service that will be used in the task, such as Candlepin or Pulp, will be checked for correct functioning. If the check fails, you will receive an error similar to the following one:
There was an issue with the backend service candlepin: Connection refused – connect(2).
If the back-end service checking feature turns out to be causing any trouble, it can be disabled as follows.
To Disable Checking for Services:
- In the Satellite web UI, navigate to Administer > Settings.
- Enter check_services_before_actions in the search box and click Search.
- In the Value column, click the icon to edit the value.
- From the drop-down menu, select false.
- Click Save.
18.2. Configuring RSS Notifications
To view Satellite event notification alerts, click the Notifications icon in the upper right of the screen.
By default, the Notifications area displays RSS feed events published in the Red Hat Satellite Blog.
The feed is refreshed every 12 hours and the Notifications area is updated whenever new events become available.
You can configure the RSS feed notifications by changing the URL feed. The supported feed format is RSS 2.0 and Atom. For an example of the RSS 2.0 feed structure, see the Red Hat Satellite Blog feed. For an example of the Atom feed structure, see the Foreman blog feed.
To Configure RSS Feed Notifications:
- In the Satellite web UI, navigate to Administer > Settings and select the Notifications tab.
- In the RSS URL row, click the edit icon in the Value column and type the required URL.
- In the RSS enable row, click the edit icon in the Value column to enable or disable this feature.
18.3. Monitoring Satellite Server
Audit records list the changes made by all users on Satellite. This information can be used for maintenance and troubleshooting.
Procedure
- In the Satellite web UI, navigate to Monitor > Audits to view the audit records.
To obtain a list of all the audit attributes, use the following command:
# foreman-rake audits:list_attributes
18.4. Monitoring Capsule Server
The following section shows how to use the Satellite web UI to find Capsule information valuable for maintenance and troubleshooting.
18.4.1. Viewing General Capsule Information
In the Satellite web UI, navigate to Infrastructure > Capsules to view a table of Capsule Servers registered to Satellite Server. The information contained in the table answers the following questions:
- Is Capsule Server running?
-
This is indicated by a green icon in the Status column. A red icon indicates an inactive Capsule, use the
service foreman-proxy restart
command on Capsule Server to activate it. - What services are enabled on Capsule Server?
- In the Features column you can verify if Capsule for example provides a DHCP service or acts as a Pulp mirror. Capsule features can be enabled during installation or configured in addition. For more information, see Installing Capsule Server.
- What organizations and locations is Capsule Server assigned to?
A Capsule Server can be assigned to multiple organizations and locations, but only Capsules belonging to the currently selected organization are displayed. To list all Capsules, select Any Organization from the context menu in the top left corner.
After changing the Capsule configuration, select Refresh from the drop-down menu in the Actions column to ensure the Capsule table is up to date.
Click the Capsule name to view further details. At the Overview tab, you can find the same information as in the Capsule table. In addition, you can answer to the following questions:
- Which hosts are managed by Capsule Server?
- The number of associated hosts is displayed next to the Hosts managed label. Click the number to view the details of associated hosts.
- How much storage space is available on Capsule Server?
-
The amount of storage space occupied by the Pulp content in
/var/lib/pulp
is displayed. Also the remaining storage space available on the Capsule can be ascertained.
18.4.2. Monitoring Services
In the Satellite web UI, navigate to Infrastructure > Capsules and click the name of the selected Capsule. At the Services tab, you can find basic information on Capsule services, such as the list of DNS domains, or the number of Pulp workers. The appearance of the page depends on what services are enabled on Capsule Server. Services providing more detailed status information can have dedicated tabs at the Capsule page. For more information, see Section 18.4.3, “Monitoring Puppet”.
18.4.3. Monitoring Puppet
In the Satellite web UI, navigate to Infrastructure > Capsules and click the name of the selected Capsule. At the Puppet tab you can find the following:
- A summary of Puppet events, an overview of latest Puppet runs, and the synchronization status of associated hosts at the General sub-tab.
- A list of Puppet environments at the Environments sub-tab.
At the Puppet CA tab you can find the following:
- A certificate status overview and the number of autosign entries at the General sub-tab.
- A table of CA certificates associated with the Capsule at the Certificates sub-tab. Here you can inspect the certificate expiry data, or cancel the certificate by clicking Revoke.
- A list of autosign entries at the Autosign entries sub-tab. Here you can create an entry by clicking New or delete one by clicking Delete.
The Puppet and Puppet CA tabs are available only if you have Puppet enabled in your Satellite. For more information, see Enabling Puppet Integration with Satellite in Managing Configurations Using Puppet Integration in Red Hat Satellite.
Chapter 19. Using Webhooks
A webhook is a way for a web page or web application to provide other applications with information in real time. Webhooks are only triggered after an event occurs. The request usually contains details of the event. An event triggers callbacks, such as sending an e-mail confirming a host has been provisioned. Webhooks enable you to define a call to an external API based on Satellite internal event using a fire-and-forget message exchange pattern. The application sending the request does not wait for the response, or ignores it.
Payload of a webhook is created from webhook templates. Webhook templates use the same ERB syntax as Provisioning templates. Available variables:
-
@event_name
: Name of an event. -
@webhook_id
: Unique event ID. -
@payload
: Payload data, different for each event type. To access individual fields, use@payload[:key_name]
Ruby hash syntax. -
@payload[:object]
: Database object for events triggered by database actions (create, update, delete). Not available for custom events. -
@payload[:context]
: Additional information as hash like request and session UUID, remote IP address, user, organization and location.
Because webhooks use HTTP, no new infrastructure needs be added to existing web services.
The typical use case for webhooks in Satellite is making a call to a monitoring system when a host is created or deleted.
Webhooks are useful where the action you want to perform in the external system can be achieved through its API. Where it is necessary to run additional commands or edit files, the shellhooks plugin for Capsules is available. The shellhooks plugin enables you to define a shell script on the Capsule that can be executed through the API.
You can use webhooks successfully without installing the shellhooks plugin.
For a list of available events, see Available webhook events.
19.1. Migrating to Webhooks
The legacy foreman_hooks
plugin provided full access to model objects that the webhooks plugin does not intentionally provide.
The scope of what is available is limited by the safemode and all objects and macros are both subject to an API stability promise and are fully documented.
The number of events triggered by webhooks is substantially fewer than with foreman_hooks
.
Webhooks are processed asynchronously so there is minimal risk of tampering with internals of the system. It is not possible to migrate from foreman_hooks
without creating payloads for each individual webhook script. However, the webhooks plugin comes with several example payload templates. You can also use the example payloads with shellhooks to simplify migration.
Both script and payload templates must be customized to achieve similar results.
19.2. Installing Webhooks
Use the following procedure to install webhooks. After installing webhooks, you can configure Satellite Server to send webhook requests.
Procedure
Install webhooks using the following command:
# satellite-installer --enable-foreman-plugin-webhooks
Optional: you can install the CLI plugin using the following command:
# satellite-installer --enable-foreman-cli-webhooks
19.3. Creating a Webhook Template
Webhook templates are used to generate the body of HTTP request to a configured target when a webhook is triggered. Use the following procedure to create a webhook template in the Satellite web UI.
Procedure
- In the Satellite web UI, navigate to Administer > Webhook Templates.
- Click Clone an existing template or Create Template.
- Enter a name for the template.
Use the editor to make changes to the template payload.
A webhook HTTP payload must be created using Satellite template syntax. The webhook template can use a special variable called
@object
that can represent the main object of the event.@object
can be missing in case of certain events. You can determine what data are actually available with the@payload
variable.For more information, see Template Writing Reference in Managing Hosts and for available template macros and methods, visit
/templates_doc
on Satellite Server.- Optional: Enter the description and audit comment.
- Assign organizations and locations.
- Click Submit.
Examples
When creating a webhook template, you must follow the format of the target application for which the template is intended. For example, an application can expect a "text"
field with the webhook message. Refer to the documentation of your target application to find more about how your webhook template format should look like.
- Running remote execution jobs
This webhook template defines a message with the ID and result of a remote execution job. The webhook which uses this template can be subscribed to events such as
Actions Remote Execution Run Host Job Succeeded
orActions Remote Execution Run Host Job Failed
.{ "text": "job invocation <%= @object.job_invocation_id %> finished with result <%= @object.task.result %>" }
- Creating users
This webhook template defines a message with the login and email of a created user. The webhook which uses this template should be subscribed to the
User Created
event.{ "text": "user with login <%= @object.login %> and email <%= @object.mail %> created" }
19.4. Creating a Webhook
You can customize events, payloads, HTTP authentication, content type, and headers through the Satellite web UI.
Use the following procedure to create a webhook in the Satellite web UI.
Procedure
- In the Satellite web UI, navigate to Administer > Webhooks.
- Click Create new.
- From the Subscribe to list, select an event.
- Enter a Name for your webhook.
- Enter a Target URL. Webhooks make HTTP requests to pre-configured URLs. The target URL can be a dynamic URL.
- Click Template to select a template. Webhook templates are used to generate the body of the HTTP request to Satellite Server when a webhook is triggered.
- Enter an HTTP method.
- Optional: If you do not want activate the webhook when you create it, uncheck the Enabled flag.
- Click the Credentials tab.
- Optional: If HTTP authentication is required, enter User and Password.
- Optional: Uncheck Verify SSL if you do not want to verify the server certificate against the system certificate store or Satellite CA.
-
On the Additional tab, enter the HTTP Content Type. For example,
application/json
,application/xml
ortext/plain
on the payload you define. The application does not attempt to convert the content to match the specified content type. - Optional: Provide HTTP headers as JSON. ERB is also allowed.
When configuring webhooks with endpoints with non-standard HTTP or HTTPS ports, an SELinux port must be assigned, see Configuring SELinux to Ensure Access to Satellite on Custom Ports in Installing Satellite Server in a Connected Network Environment.
19.5. Available Webhook Events
The following table contains a list of webhook events that are available from the Satellite web UI. Action
events trigger webhooks only on success
, so if an action fails, a webhook is not triggered.
For more information about payload, go to Administer > About > Support > Templates DSL. A list of available types is provided in the following table. Some events are marked as custom, in that case, the payload is an object object but a Ruby hash (key-value data structure) so syntax is different.
Event name | Description | Payload |
---|---|---|
Actions Katello Content View Promote Succeeded | A Content View was successfully promoted. | Actions::Katello::ContentView::Promote |
Actions Katello Content View Publish Succeeded | A repository was successfully synchronized. | Actions::Katello::ContentView::Publish |
Actions Remote Execution Run Host Job Succeeded | A generic remote execution job succeeded for a host. This event is emitted for all Remote Execution jobs, when complete. | Actions::RemoteExecution::RunHostJob |
Actions Remote Execution Run Host Job Katello Errata Install Succeeded | Install errata using the Katello interface. | Actions::RemoteExecution::RunHostJob |
Actions Remote Execution Run Host Job Katello Group Install Succeeded | Install package group using the Katello interface. | Actions::RemoteExecution::RunHostJob |
Actions Remote Execution Run Host Job Katello Package Install Succeeded | Install package using the Katello interface. | Actions::RemoteExecution::RunHostJob |
Actions Remote Execution Run Host Job Katello Group Remove | Remove package group using the Katello interface. | Actions::RemoteExecution::RunHostJob |
Actions Remote Execution Run Host Job Katello Package Remove Succeeded | Remove package using the Katello interface. | Actions::RemoteExecution::RunHostJob |
Actions Remote Execution Run Host Job Katello Service Restart Succeeded | Restart Services using the Katello interface. | Actions::RemoteExecution::RunHostJob |
Actions Remote Execution Run Host Job Katello Group Update Succeeded | Update package group using the Katello interface. | Actions::RemoteExecution::RunHostJob |
Actions Remote Execution Run Host Job Katello Package Update Succeeded | Update package using the Katello interface. | Actions::RemoteExecution::RunHostJob |
Actions Remote Execution Run Host Job Foreman OpenSCAP Run Scans Succeeded | Run OpenSCAP scan. | Actions::RemoteExecution::RunHostJob |
Actions Remote Execution Run Host Job Ansible Run Host Succeeded | Runs an Ansible playbook containing all the roles defined for a host. | Actions::RemoteExecution::RunHostJob |
Actions Remote Execution Run Host Job Ansible Run Capsule Upgrade Succeeded | Upgrade Capsules on given Capsule server hosts. | Actions::RemoteExecution::RunHostJob |
Actions Remote Execution Run Host Job Ansible Configure Cloud Connector Succeeded | Configure Cloud Connector on given hosts. | Actions::RemoteExecution::RunHostJob |
Actions Remote Execution Run Host Job Ansible Run Insights Plan Succeeded | Runs a given maintenance plan from Red Hat Access Insights given an ID. | Actions::RemoteExecution::RunHostJob |
Actions Remote Execution Run Host Job Ansible Run Playbook Succeeded | Run an Ansible playbook against given hosts. | Actions::RemoteExecution::RunHostJob |
Actions Remote Execution Run Host Job Ansible Enable Web Console Succeeded | Run an Ansible playbook to enable the web console on given hosts. | Actions::RemoteExecution::RunHostJob |
Actions Remote Execution Run Host Job Puppet Run Host Succeeded | Perform a single Puppet run. | Actions::RemoteExecution::RunHostJob |
Actions Remote Execution Run Host Job Katello Module Stream Action Succeeded | Perform a module stream action using the Katello interface. | Actions::RemoteExecution::RunHostJob |
Actions Remote Execution Run Host Job Leapp Pre-upgrade Succeeded | Upgradeability check for RHEL 7 host. | Actions::RemoteExecution::RunHostJob |
Actions Remote Execution Run Host Job Leapp Remediation Plan Succeeded | Run Remediation plan with Leapp. | Actions::RemoteExecution::RunHostJob |
Actions Remote Execution Run Host Job Leapp Upgrade Succeeded | Run Leapp upgrade job for RHEL 7 host. | Actions::RemoteExecution::RunHostJob |
Build Entered | A host entered the build mode. |
Custom event: |
Build Exited | A host build mode was canceled, either it was successfully provisioned or the user canceled the build manually. |
Custom event: |
Content View Created/Updated/Destroyed | Common database operations on a Content View. | Katello::ContentView |
Domain Created/Updated/Destroyed | Common database operations on a domain. | Domain |
Host Created/Updated/Destroyed | Common database operations on a host. | Host |
Hostgroup Created/Updated/Destroyed | Common database operations on a hostgroup. | Hostgroup |
Model Created/Updated/Destroyed | Common database operations on a model. | Model |
Status Changed | Global host status of a host changed. |
Custom event: |
Subnet Created/Updated/Destroyed | Common database operations on a subnet. | Subnet |
Template Render Performed | A report template was rendered. | Template |
User Created/Updated/Destroyed | Common database operations on a user. | User |
19.6. Shellhooks
With webhooks, you can only map one Satellite event to one API call. For advanced integrations, where a single shell script can contain multiple commands, you can install a Capsule shellhooks plugin that exposes executables using a REST HTTP API.
You can then configure a webhook to reach out to a Capsule API to run a predefined shellhook. A shellhook is an executable script that can be written in any language as long as it can be executed. The shellhook can for example contain commands or edit files.
You must place your executable scripts in /var/lib/foreman-proxy/shellhooks
with only alphanumeric characters and underscores in their name.
You can pass input to shellhook script through the webhook payload. This input is redirected to standard input of the shellhook script. You can pass arguments to shellhook script using HTTP headers in format X-Shellhook-Arg-1
to X-Shellhook-Arg-99
. For more information on passing arguments to shellhook script, see:
The HTTP method must be POST. An example URL would be: https://capsule.example.com:9090/shellhook/My_Script
.
Unlike the shellhooks
directory, the URL must contain /shellhook/
in singular to be valid.
You must enable Capsule Authorization for each webhook connected to a shellhook to enable it to authorize a call.
Standard output and standard error output are redirected to the Capsule logs as messages with debug or warning levels respectively.
The shellhook HTTPS calls do not return a value.
For an example on creating a shellhook script, see Section 19.10, “Creating a Shellhook to Print Arguments”.
19.7. Installing the Shellhooks Plugin
Optionally, you can install and enable the shellhooks plugin on each Capsule used for shellhooks, using the following command:
# satellite-installer --enable-foreman-proxy-plugin-shellhooks
19.8. Passing Arguments to Shellhook Script Using Webhooks
Use this procedure to pass arguments to a shellhook script using webhooks.
Procedure
When creating a webhook, on the Additional tab, create HTTP headers in the following format:
{ "X-Shellhook-Arg-1": "VALUE", "X-Shellhook-Arg-2": "VALUE" }
Ensure that the headers have a valid JSON or ERB format. Only pass safe fields like database ID, name, or labels that do not include new lines or quote characters.
For more information, see Section 19.4, “Creating a Webhook”.
Example
{ "X-Shellhook-Arg-1": "<%= @object.content_view_version_id %>", "X-Shellhook-Arg-2": "<%= @object.content_view_name %>" }
19.9. Passing Arguments to Shellhook Script Using Curl
Use this procedure to pass arguments to a shellhook script using curl.
Procedure
When executing a shellhook script using
curl
, create HTTP headers in the following format:"X-Shellhook-Arg-1: VALUE" "X-Shellhook-Arg-2: VALUE"
Example
# curl -sX POST -H 'Content-Type: text/plain' \ -H "X-Shellhook-Arg-1: Version 1.0" \ -H "X-Shellhook-Arg-2: My Content View" \ --data "" https://capsule.example.com:9090/shellhook/My_Script
19.10. Creating a Shellhook to Print Arguments
Create a simple shellhook script that prints "Hello World!" when you run a remote execution job.
Prerequisite
You have the
webhooks
andshellhooks
plug-ins installed. For more information, see:
Procedure
Modify the
/var/lib/foreman-proxy/shellhooks/print_args
script to print arguments to standard error output so you can see them in the Capsule logs:#!/bin/sh # # Prints all arguments to stderr # echo "$@" >&2
- In the Satellite web UI, navigate to Administer > Webhooks.
- Click Create new.
- From the Subscribe to list, select Actions Remote Execution Run Host Job Succeeded.
- Enter a Name for your webhook.
In the Target URL field, enter the URL of your Capsule Server followed by
:9090/shellhook/print_args
:https://capsule.example.com:9090/shellhook/print_args
Note that
shellhook
in the URL is singular, unlike theshellhooks
directory.- From the Template list, select Empty Payload.
- On the Credentials tab, check Capsule Authorization.
On the Additional tab, enter the following text in the Optional HTTP headers field:
{ "X-Shellhook-Arg-1": "Hello", "X-Shellhook-Arg-2": "World!" }
- Click Submit. You now have successfully created a shellhook that prints "Hello World!" to Capsule logs every time you a remote execution job succeeds.
Verification
-
Run a remote execution job on any host. You can use
time
as a command. For more information, see Executing a Remote Job in Managing Hosts. Verify that the shellhook script was triggered and printed "Hello World!" to Capsule Server logs:
# tail /var/log/foreman-proxy/proxy.log
You should find the following lines at the end of the log:
[I] Started POST /shellhook/print_args [I] Finished POST /shellhook/print_args with 200 (0.33 ms) [I] [3520] Started task /var/lib/foreman-proxy/shellhooks/print_args\ Hello\ World\! [W] [3520] Hello World!
Chapter 20. Searching and Bookmarking
Satellite features powerful search functionality on most pages of the Satellite web UI. It enables you to search all kinds of resources that Satellite manages. Searches accept both free text and syntax-based queries, which can be built using extensive input prediction. Search queries can be saved as bookmarks for future reuse.
20.1. Building Search Queries
As you start typing a search query, a list of valid options to complete the current part of the query appears. You can either select an option from the list and keep building the query using the prediction, or continue typing. To learn how free text is interpreted by the search engine, see Section 20.2, “Using Free Text Search”.
20.1.1. Query Syntax
parameter operator value
Available fields, resources to search, and the way the query is interpreted all depend on context, that is, the page where you perform the search. For example, the field "hostgroup" on the Hosts page is equivalent to the field "name" on the Host Groups page. The field type also determines available operators and accepted values.
For a list of all operators, see Operators. For descriptions of value formats, see Values.
20.1.2. Query Operators
All operators that can be used between parameter and value are listed in the following table. Other symbols and special characters that might appear in a prediction-built query, such as colons, do not have special meaning and are treated as free text.
Operator | Short Name | Description | Example |
---|---|---|---|
= | EQUALS | Accepts numerical, temporal, or text values. For text, exact case sensitive matches are returned. |
|
!= | NOT EQUALS | ||
~ | LIKE | Accepts text or temporal values. Returns case insensitive matches. Accepts the following wildcards: _ for a single character, % or * for any number of characters including zero. If no wildcard is specified, the string is treated as if surrounded by wildcards: %rhel7% |
|
!~ | NOT LIKE | ||
> | GREATER THAN | Accepts numerical or temporal values. For temporal values, the operator > is interpreted as "later than", and < as "earlier than". Both operators can be combined with EQUALS: >= <= |
|
< | LESS THAN | ||
^ | IN | Compares an expression against a list of values, as in SQL. Returns matches that contain or not contain the values, respectively. |
|
!^ | NOT IN | ||
HAS or set? |
| Returns values that are present or not present, respectively. |
|
NOT HAS or null? |
|
Simple queries that follow the described syntax can be combined into more complex ones using logical operators AND, OR, and NOT. Alternative notations of the operators are also accepted:
Operator | Alternative Notations | Example | ||
---|---|---|---|---|
and | & | && | <whitespace> |
|
or | | | || |
|
|
not | – | ! |
|
|
20.1.3. Query Values
- Text Values
Text containing whitespaces must be enclosed in quotes. A whitespace is otherwise interpreted as the AND operator.
Examples:
hostgroup = "Web servers"
The search will return hosts with assigned host group named "Web servers".
hostgroup = Web servers
The search will return hosts in the host group Web with any field matching %servers%.
- Temporal Values
Many date and time formats are accepted, including the following:
- "10 January 2017"
- "10 Jan 2017"
- 10-January-2017
- 10/January/2017
- "January 10, 2017"
- Today, Yesterday, and the like.
Avoid ambiguous date formats, such as 02/10/2017 or 10-02-2017.
20.2. Using Free Text Search
When you enter free text, it will be searched for across multiple fields. For example, if you type "64", the search will return all hosts that have that number in their name, IP address, MAC address, and architecture.
Multi-word queries must be enclosed in quotes, otherwise the whitespace is interpreted as the AND operator.
Because of searching across all fields, free text search results are not very accurate and searching can be slow, especially on a large number of hosts. For this reason, we recommend that you avoid free text and use more specific, syntax-based queries whenever possible.
20.3. Managing Bookmarks
You can save search queries as bookmarks for reuse. You can also delete or modify a bookmark.
Bookmarks appear only on the page on which they were created. On some pages, there are default bookmarks available for the common searches, for example, all active
or disabled
hosts.
20.3.1. Creating Bookmarks
This section details how to save a search query as a bookmark. You must save the search query on the relevant page to create a bookmark for that page, for example, saving a host related search query on the Hosts page.
Procedure
- In the Satellite web UI, navigate to the page where you want to create a bookmark.
- In the Search field, enter the search query you want to save.
- Select the arrow to the right of the Search button and then select Bookmark this search.
- In the Name field, enter a name for the new bookmark.
- In the Search query field, ensure your search query is correct.
Ensure the Public checkbox is set correctly:
- Select the Public checkbox to set the bookmark as public and visible to all users.
- Clear the Public checkbox to set the bookmark as private and only visible to the user who created it.
- Click Submit.
To confirm the creation, either select the arrow to the right of the Search button to display the list of bookmarks, or navigate to Administer > Bookmarks and then check the Bookmarks list for the name of the bookmark.
20.3.2. Deleting Bookmarks
You can delete bookmarks on the Bookmarks page.
Procedure
- In the Satellite web UI, navigate to Administer > Bookmarks.
- On the Bookmarks page, click Delete for the Bookmark you want to delete.
- When the confirmation window opens, click OK to confirm the deletion.
To confirm the deletion, check the Bookmarks list for the name of the bookmark.
Appendix A. Administration Settings
This section contains information about settings that you can edit in the Satellite web UI by navigating to Administer > Settings.
A.1. General Settings
Setting | Default Value | Description |
---|---|---|
Administrator email address | The default administrator email address | |
Satellite URL | URL where your Satellite instance is reachable. See also Provisioning > Unattended URL. | |
Entries per page | 20 | Number of records shown per page in Satellite |
Fix DB cache | No |
Satellite maintains a cache of permissions and roles. When set to |
DB pending seed | No |
Should the |
Capsule request timeout | 60 | Open and read timeout for HTTP requests from Satellite to Capsule (in seconds). |
Login page footer text | Text to be shown in the login-page footer. | |
HTTP(S) proxy | Set a proxy for outgoing HTTP(S) connections from the Satellite product. System-wide proxies must be configured at the operating system level. | |
HTTP(S) proxy except hosts | [] | Set hostnames to which requests are not to be proxied. Requests to the local host are excluded by default. |
Show Experimental Labs | No | Whether or not to show a menu to access experimental lab features (requires reload of page). |
Append domain names to the host | Yes |
If set to |
Out of sync interval | 30 |
Managed hosts report periodically, and if the time between reports exceeds this duration in minutes, hosts are considered out of sync. You can override this on your hosts by adding the |
Satellite UUID | Satellite instance ID. Uniquely identifies a Satellite instance. | |
Default language | The UI for new users uses this language. | |
Default timezone | The timezone to use for new users. | |
Instance title | The instance title is shown on the top navigation bar (requires a page reload). | |
Saved audits interval | Duration in days to preserve audit data. Leave empty to disable the audits cleanup. | |
New host details UI | Yes | Satellite loads the new UI for host details. |
A.2. Satellite Task Settings
Setting | Default Value | Description |
---|---|---|
Sync task timeout | 120 | Number of seconds to wait for a synchronous task to finish before an exception is raised. |
Enable dynflow console | Yes |
Enable the dynflow console ( |
Require auth for dynflow console | Yes | The user must be authenticated as having administrative rights before accessing the dynflow console. |
Capsule action retry count | 4 | Number of attempts permitted to start a task on the Capsule before failing. |
Capsule action retry interval | 15 | Time in seconds between retries. |
Allow Capsule batch tasks | Yes | Enable batch triggering of tasks on the Capsule. |
Capsule tasks batch size | 100 |
Number of tasks included in one request to the Capsule if |
Tasks troubleshooting URL |
URL pointing to the task troubleshooting documentation. It should contain a | |
Polling intervals multiplier | 1 | Polling multiplier used to multiply the default polling intervals. You can use this to prevent polling too frequently for long running tasks. |
A.3. Template Sync Settings
Setting | Default Value | Description |
---|---|---|
Associate | New | Associate templates with OS, organization and location. |
Branch | Default branch in Git repo. | |
Commit message | Templates export made by a Satellite user | Custom commit message for exported templates. |
Dirname | / | The directory within the Git repo containing the templates. |
Filter | Import or export of names matching this regex. Case-insensitive. Snippets are not filtered. | |
Force import | No |
If set to |
Lock templates | Keep, do not lock new | How to handle lock for imported templates. |
Metadata export mode | Refresh | Default metadata export mode. Possible options:
|
Negate | No | Negate the filter for import or export. |
Prefix | A string added as a prefix to imported templates. | |
Repo | Target path from where to import or export templates. Different protocols can be used, for example:
When exporting to | |
Verbosity | No | Choose verbosity for Rake task importing templates. |
A.4. Discovered Settings
Setting | Default Value | Description |
---|---|---|
Discovery location | Indicates the default location to place discovered hosts in. | |
Discovery organization | Indicates the default organization to which discovered hosts are added. | |
Interface fact | discovery_bootif | Fact name to use for primary interface detection. |
Create bond interfaces | No | Automatically create a bond interface if another interface is detected on the same VLAN using LLDP. |
Clean all facts | No | Clean all reported facts (except discovery facts) during provisioning. |
Hostname facts | discovery_bootif | List of facts to use for the hostname (comma separated, first wins). |
Auto provisioning | No | Use the provisioning rules to automatically provision newly discovered hosts. |
Reboot | Yes | Automatically reboot or kexec discovered hosts during provisioning. |
Hostname prefix | mac | The default prefix to use for the hostname. Must start with a letter. |
Fact columns | Extra facter columns to show in host lists (comma separated). | |
Highlighted facts |
Regex to organize facts for highlights section – e.g. | |
Storage facts | Regex to organize facts for the storage section. | |
Software facts | Regex to organize facts for the software section. | |
Hardware facts | Regex to organize facts for the hardware section. | |
Network facts | Regex to organize facts for the network section. | |
IPMI facts | Regex to organize facts for the Intelligent Platform Management Interface (IPMI) section. | |
Lock PXE | No | Automatically generate a Preboot Execution Environment (PXE) configuration to pin a newly discovered host to discovery. |
Locked PXELinux template name | pxelinux_discovery | PXELinux template to be used when pinning a host to discovery. |
Locked PXEGrub template name | pxegrub_discovery | PXEGrub template to be used when pinning a host to discovery. |
Locked PXEGrub2 template name | pxegrub2_discovery | PXEGrub2 template to be used when pinning a host to discovery. |
Force DNS | Yes | Force the creation of DNS entries when provisioning a discovered host. |
Error on existing NIC | No | Do not permit to discover an existing managed host matching the MAC of a provisioning Network Interface Card (NIC) (errors out early). |
Type of name generator | Fact + prefix | Discovery hostname naming pattern. |
Prefer IPv6 | No | Prefer IPv6 to IPv4 when calling discovered nodes. |
A.5. Boot Disk Settings
Setting | Default Value | Description |
---|---|---|
iPXE directory |
| Path to directory containing iPXE images. |
ISOLINUX directory |
| Path to directory containing ISOLINUX images. |
SYSLINUX directory |
| Path to directory containing SYSLINUX images. |
Grub2 directory |
|
Path to directory containing |
Host image template | Boot disk iPXE - host | iPXE template to use for host-specific boot disks. |
Generic image template | Boot disk iPXE - generic host | iPXE template to use for generic host boot disks. |
Generic Grub2 EFI image template | Boot disk Grub2 EFI - generic host | Grub2 template to use for generic Extensible Firmware Interface (EFI) host boot disks. |
ISO generation command | genisoimage |
Command to generate ISO image, use |
Installation media caching | Yes | Installation media files are cached for full host images. |
Allowed bootdisk types | [generic, host, full_host, subnet] | List of permitted bootdisk types. Leave blank to disable it. |
A.6. Red Hat Cloud Settings
Setting | Default Value | Description |
---|---|---|
Automatic inventory upload | Yes | Enable automatic upload of your host inventory to the Red Hat cloud. |
Synchronize recommendations Automatically | No | Enable automatic synchronization of Insights recommendations from the Red Hat cloud. |
Obfuscate host names | No | Obfuscate hostnames sent to the Red Hat cloud. |
Obfuscate host ipv4 addresses | No | Obfuscate IPv4 addresses sent to the Red Hat cloud. |
ID of the RHC daemon | ***** | RHC daemon id. |
A.7. Content Settings
Setting | Default Value | Description |
---|---|---|
Default HTTP Proxy | Default HTTP Proxy for syncing content. | |
CDN SSL version | SSL version used to communicate with the CDN. | |
Default synced OS provisioning template | Kickstart default | Default provisioning template for operating systems created from synced content. |
Default synced OS finish template | Kickstart default finish | Default finish template for new operating systems created from synced content. |
Default synced OS user-data | Kickstart default user data | Default user data for new operating systems created from synced content. |
Default synced OS PXELinux template | Kickstart default PXELinux | Default PXELinux template for new operating systems created from synced content. |
Default synced OS PXEGrub template | Kickstart default PXEGrub | Default PXEGrub template for new operating systems created from synced content. |
Default synced OS PXEGrub2 template | Kickstart default PXEGrub2 | Default PXEGrub2 template for new operating systems created from synced content. |
Default synced OS iPXE template | Kickstart default iPXE | Default iPXE template for new operating systems created from synced content. |
Default synced OS partition table | Kickstart default | Default partitioning table for new operating systems created from synced content. |
Default synced OS kexec template | Discovery Red Hat kexec | Default kexec template for new operating systems created from synced content. |
Default synced OS Atomic template | Atomic Kickstart default | Default provisioning template for new atomic operating systems created from synced content. |
Manifest refresh timeout | 1200 | Timeout when refreshing a manifest (in seconds). |
Accept action timeout | 20 | Time in seconds to wait for a host to pick up a remote action. |
Finish action timeout | 3600 | Time in seconds to wait for a host to finish a remote action. |
Subscription connection enabled | Yes | Can communicate with the Red Hat Portal for subscriptions. |
Installable errata from Content View | No | Calculate errata host status based only on errata in a host’s Content View and Lifecycle Environment. |
Restrict Composite Content View promotion | No | If this is enabled, a composite content view cannot be published or promoted, unless the content view versions that it includes exist in the target environment. |
Check services before actions | Yes | Check the status of backend services such as pulp and candlepin before performing actions? |
Batch size to sync repositories in | 100 | How many repositories should be synced concurrently on a Capsule. A smaller number may lead to longer sync times. A larger number will increase dynflow load. |
Sync Capsules after Content View promotion | Yes | Whether or not to auto sync Capsules after a Content View promotion. |
Default Custom Repository download policy |
|
Default download policy for custom repositories. Either |
Default Red Hat Repository download policy |
|
Default download policy for enabled Red Hat repositories. Either |
Default Capsule download policy |
|
Default download policy for Capsule syncs. Either |
Pulp export destination filepath |
| On-disk location for exported repositories. |
Pulp 3 export destination filepath |
| On-disk location for Pulp 3 exported repositories. |
Pulp client key |
| Path for SSL key used for Pulp server authentication. |
Pulp client cert |
| Path for SSL certificate used for Pulp server authentication. |
Sync Connection Timeout | 300 | Total timeout in seconds for connections when syncing. |
Use remote execution by default | No | If enabled, remote execution is used instead of katello-agent for remote actions. |
Delete Host upon unregister | No | When unregistering a host using subscription-manager, also delete the host record. Managed resources linked to the host such as virtual machines and DNS records might also be deleted. |
Subscription manager name registration fact |
When registering a host using subscription-manager, force use the specified fact for the host name (in the form of | |
Subscription manager name registration fact strict matching | No |
If this is enabled, and |
Default Location subscribed hosts | Default Location | Default location where new subscribed hosts are stored after registration. |
Expire soon days | 120 | The number of days remaining in a subscription before you are reminded about renewing it. |
Content View Dependency Solving Default | No | The default dependency solving value for new content views. |
Host Duplicate DMI UUIDs | [] | If hosts fail to register because of duplicate Desktop Management Interface (DMI) UUIDs, add their comma-separated values here. Subsequent registrations generate a unique DMI UUID for the affected hosts. |
Host Profile Assume | Yes | Enable new host registrations to assume registered profiles with matching hostname as long as the registering DMI UUID is not used by another host. |
Host Profile Can Change In Build | No | Enable host registrations to bypass Host Profile Assume as long as the host is in build mode. |
Host Can Re-Register Only In Build | No | Enable hosts to re-register only when they are in build mode. |
Host Tasks Workers Pool Size | 5 | Number of workers in the pool to handle the execution of host-related tasks. When set to 0, the default queue is used. Restart of the dynflowd/foreman-tasks service is required. |
Applicability Batch Size | 50 | Number of host applicability calculations to process per task. |
Autosearch | Yes | For pages that support it, automatically perform the search while typing in search input. |
Autosearch delay | 500 | If Autosearch is enabled, delay in milliseconds before executing searches while typing. |
Pulp bulk load size | 2000 | The number of items fetched from a single paged Pulp API call. |
Upload profiles without Dynflow | Yes | Enable Katello to update host installed packages, enabled repositories, and module inventory directly instead of wrapped in Dynflow tasks (try turning off if Puma processes are using too much memory). |
Orphaned Content Protection Time | 1440 | Time in minutes to consider orphan content as orphaned. |
Prefer registered through Capsule for remote execution | No | Prefer using a proxy to which a host is registered when using remote execution. |
Allow deleting repositories in published content views | Yes | Enable removal of repositories that the user has previously published in one or more Content View versions. |
A.8. Authentication Settings
Setting | Default Value | Description |
---|---|---|
OAuth active | Yes | Satellite will use OAuth for API authorization. |
OAuth consumer key | ***** | OAuth consumer key. |
OAuth consumer secret | ***** | OAuth consumer secret. |
OAuth map users | No | Satellite maps users by username in the request-header. If this is disabled, OAuth requests have administrator rights. |
Failed login attempts limit | 30 | Satellite blocks user logins from an incoming IP address for 5 minutes after the specified number of failed login attempts. Set to 0 to disable brute force protection. |
Restrict registered Capsules | Yes | Only known Capsules can access features that use Capsule authentication. |
Require SSL for capsules | Yes |
Client SSL certificates are used to identify Capsules ( |
Trusted hosts | [] | List of hostnames, IPv4, IPv6 addresses or subnets to be trusted in addition to Capsules for access to fact/report importers and ENC output. |
SSL certificate |
| SSL Certificate path that Satellite uses to communicate with its proxies. |
SSL CA file |
| SSL CA file path that Satellite uses to communicate with its proxies. |
SSL private key |
| SSL Private Key path that Satellite uses to communicate with its proxies. |
SSL client DN env | HTTP_SSL_CLIENT_S_DN | Environment variable containing the subject DN from a client SSL certificate. |
SSL client verify env | HTTP_SSL_CLIENT_VERIFY | Environment variable containing the verification status of a client SSL certificate. |
SSL client cert env | HTTP_SSL_CLIENT_CERT | Environment variable containing a client’s SSL certificate. |
Server CA file | SSL CA file path used in templates to verify the connection to Satellite. | |
Websockets SSL key |
| Private key file path that Satellite uses to encrypt websockets. |
Websockets SSL certificate |
| Certificate path that Satellite uses to encrypt websockets. |
Websockets encryption | Yes |
VNC/SPICE websocket proxy console access encryption ( |
Login delegation logout URL | Redirect your users to this URL on logout. Enable Authorize login delegation also. | |
Authorize login delegation auth source user autocreate | External | Name of the external authentication source where unknown externally authenticated users (see Authorize login delegation) are created. Empty means no autocreation. |
Authorize login delegation | No |
Authorize login delegation with |
Authorize login delegation API | No |
Authorize login delegation with |
Idle timeout | 60 | Log out idle users after the specified number of minutes. |
BCrypt password cost | 9 | Cost value of bcrypt password hash function for internal auth-sources (4 – 30). A higher value is safer but verification is slower, particularly for stateless API calls and UI logins. A password change is needed to affect existing passwords. |
BMC credentials access | Yes | Permits access to BMC interface passwords through ENC YAML output and in templates. |
OIDC JWKs URL |
OpenID Connect JSON Web Key Set (JWKS) URL. Typically | |
OIDC Audience | [] | Name of the OpenID Connect Audience that is being used for authentication. In the case of Keycloak this is the Client ID. |
OIDC Issuer |
The issuer claim identifies the principal that issued the JSON Web tokens (JWT), which exists at a | |
OIDC Algorithm | The algorithm used to encode the JWT in the OpenID provider. |
A.9. Email Settings
Setting | Default Value | Description |
---|---|---|
Email reply address | Email reply address for emails that Satellite is sending. | |
Email subject prefix | Prefix to add to all outgoing email. | |
Send welcome email | No | Send a welcome email including username and URL to new users. |
Delivery method | Sendmail | Method used to deliver email. |
SMTP enable StartTLS auto | Yes | SMTP automatically enables StartTLS. |
SMTP OpenSSL verify mode | Default verification mode | When using TLS, you can set how OpenSSL checks the certificate. |
SMTP address | SMTP address to connect to. | |
SMTP port | 25 | SMTP port to connect to. |
SMTP HELO/EHLO domain | HELO/EHLO domain. | |
SMTP username | Username to use to authenticate, if required. | |
SMTP password | ***** | Password to use to authenticate, if required. |
SMTP authentication | none | Specify authentication type, if required. |
Sendmail arguments | -i | Specify additional options to sendmail. Only used when the delivery method is set to sendmail. |
Sendmail location |
| The location of the sendmail executable. Only used when the delivery method is set to sendmail. |
A.10. Notifications Settings
Setting | Default Value | Description |
---|---|---|
RSS enable | Yes | Pull RSS notifications. |
RSS URL | https://www.redhat.com/en/rss/blog/channel/red-hat-satellite | URL from which to fetch RSS notifications. |
A.11. Provisioning Settings
Setting | Default Value | Description |
---|---|---|
Host owner | Default owner on provisioned hosts, if empty Satellite uses the current user. | |
Root password | ***** | Default encrypted root password on provisioned hosts. |
Unattended URL | URL that hosts retrieve templates from during the build. When it starts with https, unattended, or userdata, controllers cannot be accessed using HTTP. | |
Safemode rendering |
|
Enables safe mode rendering of provisioning templates. The default and recommended option
When set to |
Access unattended without build | No | Enable access to unattended URLs without build mode being used. |
Query local nameservers | No | Satellite queries the locally configured resolver instead of the SOA/NS authorities. |
Installation token lifetime | 360 | Time in minutes that installation tokens should be valid for. Set to 0 to disable the token. |
SSH timeout | 120 | Time in seconds before SSH provisioning times out. |
Libvirt default console address | 0.0.0.0 | The IP address that should be used for the console listen address when provisioning new virtual machines using libvirt. |
Update IP from built request | No | Satellite updates the host IP with the IP that made the build request. |
Use short name for VMs | No | Satellite uses the short hostname instead of the FQDN for creating new virtual machines. |
DNS timeout | [5, 10, 15, 20] |
List of timeouts (in seconds) for DNS lookup attempts such as the |
Clean up failed deployment | Yes | Satellite deletes the virtual machine if the provisioning script ends with a non-zero exit code. |
Type of name generator |
| Specifies the method used to generate a hostname when creating a new host.
The default
The
The |
Default PXE global template entry |
Default PXE menu item in a global template – | |
Default PXE local template entry |
Default PXE menu item in local template – | |
iPXE intermediate script | iPXE intermediate script | Intermediate iPXE script for unattended installations. |
Destroy associated VM on host delete | No | Destroy associated VM on host delete. When enabled, VMs linked to hosts are deleted on Compute Resource. When disabled, VMs are unlinked when the host is deleted, meaning they remain on Compute Resource and can be re-associated or imported back to Satellite again. This does not automatically power off the VM |
Maximum structured facts | 100 |
Maximum number of keys in structured subtree, statistics stored in |
Default Global registration template | Global Registration | Global Registration template. |
Default 'Host initial configuration' template | Linux host_init_config default | Default 'Host initial configuration' template, automatically assigned when a new operating system is created. |
Global default PXEGrub2 template | PXEGrub2 global default | Global default PXEGrub2 template. This template is deployed to all configured TFTP servers. It is not affected by upgrades. |
Global default PXELinux template | PXELinux global default | Global default PXELinux template. This template is deployed to all configured TFTP servers. It is not affected by upgrades. |
Global default PXEGrub template | PXEGrub global default | Global default PXEGrub template. This template is deployed to all configured TFTP servers. It is not affected by upgrades. |
Global default iPXE template | iPXE global default | Global default iPXE template. This template is deployed to all configured TFTP servers. It is not affected by upgrades. |
Local boot PXEGrub2 template | PXEGrub2 default local boot | Template that is selected as PXEGrub2 default for local boot. |
Local boot PXELinux template | PXELinux default local boot | Template that is selected as PXELinux default for local boot. |
Local boot PXEGrub template | PXEGrub default local boot | Template that is selected as PXEGrub default for local boot. |
Local boot iPXE template | iPXE default local boot | Template that is selected as iPXE default for local boot. |
Manage PuppetCA | Yes | Satellite automates certificate signing upon provision of a new host. |
Use UUID for certificates | No | Satellite uses random UUIDs for certificate signing instead of hostnames. |
Show unsupported provisioning templates | No | Show unsupported provisioning templates. When enabled, all the available templates are shown. When disabled, only Red Hat supported templates are shown. |
A.12. Facts Settings
Setting | Default Value | Description |
---|---|---|
Create new host when facts are uploaded | Yes | Satellite creates the host when new facts are received. |
Location fact | satellite_location | Hosts created after a Puppet run are placed in the location specified by this fact. |
Organization fact | satellite_organization | Hosts created after a Puppet run are placed in the organization specified by this fact. The content of this fact should be the full label of the organization. |
Default location | Default Location | Hosts created after a Puppet run that did not send a location fact are placed in this location. |
Default organization | Default Organization | Hosts created after a Puppet run that did not send an organization fact are placed in this organization. |
Update hostgroup from facts | Yes | Satellite updates a host’s hostgroup from its facts. |
Ignore facts for operating system | No | Stop updating operating system from facts. |
Ignore facts for domain | No | Stop updating domain values from facts. |
Update subnets from facts | None | Satellite updates a host’s subnet from its facts. |
Ignore interfaces facts for provisioning | No | Stop updating IP and MAC address values from facts (affects all interfaces). |
Ignore interfaces with matching identifier |
[ |
Skip creating or updating host network interfaces objects with identifiers matching these values from incoming facts. You can use a * wildcard to match identifiers with indexes, e.g. |
Exclude pattern for facts stored in Satellite |
[ |
Exclude pattern for all types of imported facts (Puppet, Ansible, rhsm). Those facts are not stored in the satellite database. You can use a * wildcard to match names with indexes, e.g. |
A.13. Configuration Management Settings
Setting | Default Value | Description |
---|---|---|
Create new host when report is uploaded | Yes | Satellite creates the host when a report is received. |
Matchers inheritance | Yes | Satellite matchers are inherited by children when evaluating smart class parameters for hostgroups, organizations, and locations. |
Default parameters lookup path |
[ | Satellite evaluates host smart class parameters in this order by default. |
Interpolate ERB in parameters | Yes | Satellite parses ERB in parameters value in the ENC output. |
Always show configuration status | No | All hosts show a configuration status even when a Puppet Capsule is not assigned. |
A.14. Remote Execution Settings
Setting | Default Value | Description |
---|---|---|
Fallback to Any Capsule | No | Search the host for any proxy with Remote Execution. This is useful when the host has no subnet or the subnet does not have an execution proxy. |
Enable Global Capsule | Yes | Search for Remote Execution proxy outside of the proxies assigned to the host. The search is limited to the host’s organization and location. |
SSH User | root |
Default user to use for SSH. You can override per host by setting the |
Effective User | root | Default user to use for executing the script. If the user differs from the SSH user, su or sudo is used to switch the user. |
Effective User Method | sudo |
The command used to switch to the effective user. One of [ |
Effective user password | ***** | Effective user password. See Effective User. |
Sync Job Templates | Yes |
Whether to sync templates from disk when running |
SSH Port | 22 |
Port to use for SSH communication. Default port 22. You can override per host by setting the |
Connect by IP | No |
Whether the IP addresses on host interfaces are preferred over the FQDN. It is useful when the DNS is not resolving the FQDNs properly. You can override this per host by setting the |
Prefer IPv6 over IPv4 | No |
When connecting using an IP address, are IPv6 addresses preferred? If no IPv6 address is set, it falls back to IPv4 automatically. You can override this per host by setting the |
Default SSH password | ***** |
Default password to use for SSH. You can override per host by setting the |
Default SSH key passphrase | ***** |
Default key passphrase to use for SSH. You can override per host by setting the |
Workers pool size | 5 |
Number of workers in the pool to handle the execution of the remote execution jobs. Restart of the |
Cleanup working directories | Yes |
Whether working directories are removed after task completion. You can override this per host by setting the |
Cockpit URL | Where to find the Cockpit instance for the Web Console button. By default, no button is shown. | |
Form Job Template | Run Command - SSH Default | Choose a job template that is pre-selected in job invocation form. |
Job Invocation Report Template | Jobs - Invocation report template | Select a report template used for generating a report for a particular remote execution job. |
Time to pickup | 86400 | Time in seconds within which the host has to pick up a job. If the job is not picked up within this limit, the job will be cancelled. Applies only to pull-mqtt based jobs. Defaults to one day. |
A.15. Ansible Settings
Setting | Default Value | Description |
---|---|---|
Private Key Path |
Use this to supply a path to an SSH Private Key that Ansible uses instead of a password. Override with the | |
Connection type | ssh |
Use this connection type by default when running Ansible playbooks. You can override this on hosts by adding the |
WinRM cert Validation | validate |
Enable or disable WinRM server certificate validation when running Ansible playbooks. You can override this on hosts by adding the |
Default verbosity level | Disabled | Satellite adds this level of verbosity for additional debugging output when running Ansible playbooks. |
Post-provision timeout | 360 | Timeout (in seconds) to set when Satellite triggers an Ansible roles task playbook after a host is fully provisioned. Set this to the maximum time you expect a host to take until it is ready after a reboot. |
Ansible report timeout | 30 | Timeout (in minutes) when hosts should have reported. |
Ansible out of sync disabled | No | Disable host configuration status turning to out of sync for Ansible after a report does not arrive within the configured interval. |
Default Ansible inventory report template | Ansible - Ansible Inventory | Satellite uses this template to schedule the report with Ansible inventory. |
Ansible roles to ignore | [] |
The roles to exclude when importing roles from Capsule. The expected input is comma separated values and you can use * wildcard metacharacters. For example: |
Capsule tasks batch size for Ansible |
Number of tasks which should be sent to the Capsule in one request if |