Este contenido no está disponible en el idioma seleccionado.
Chapter 29. Configuring a system for session recording by using RHEL system roles
			Use the tlog RHEL system role to record and monitor terminal session activities on your managed nodes in an automatic fashion. You can configure the recording to take place per user or user group by means of the SSSD service.
		
The session recording solution in the tlog RHEL system role consists of the following components:
- 
					The tlogutility
- System Security Services Daemon (SSSD)
- Optional: The web console interface
29.1. Configuring session recording for individual users by using the tlog RHEL system role
				Prepare and apply an Ansible playbook to configure a RHEL system to log session recording data to the systemd journal. With that, you can enable recording the terminal output and input of a specific user during their sessions, when the user logs in on the console, or by SSH.
			
				The playbook installs tlog-rec-session, a terminal session I/O logging program, that acts as the login shell for a user. The role creates an SSSD configuration drop file, and this file defines for which users and groups the login shell should be used. Additionally, if the cockpit package is installed on the system, the playbook also installs the cockpit-session-recording package, which is a Cockpit module that allows you to view and play recordings in the web console interface.
			
Prerequisites
- You have prepared the control node and the managed nodes.
- You are logged in to the control node as a user who can run playbooks on the managed nodes.
- 
						The account you use to connect to the managed nodes has sudopermissions on them.
Procedure
- Create a playbook file, for example, - ~/playbook.yml, with the following content:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - tlog_scope_sssd: <value>
- 
									The somevalue specifies you want to record only certain users and groups, notallornone.
- tlog_users_sssd: <list_of_users>
- A YAML list of users you want to record a session from. Note that the role does not add users if they do not exist.
 
- Validate the playbook syntax: - ansible-playbook --syntax-check ~/playbook.yml - $ ansible-playbook --syntax-check ~/playbook.yml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Note that this command only validates the syntax and does not protect against a wrong but valid configuration. 
- Run the playbook: - ansible-playbook ~/playbook.yml - $ ansible-playbook ~/playbook.yml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
Verification
- Check the SSSD drop-in file’s content: - cd /etc/sssd/conf.d/sssd-session-recording.conf - # cd /etc/sssd/conf.d/sssd-session-recording.conf- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - You can see that the file contains the parameters you set in the playbook. 
- Log in as a user whose session will be recorded, perform some actions, and log out.
- As the - rootuser:- Display the list of recorded sessions: - journalctl _COMM=tlog-rec-sessio - # journalctl _COMM=tlog-rec-sessio Nov 12 09:17:30 managed-node-01.example.com -tlog-rec-session[1546]: {"ver":"2.3","host":"managed-node-01.example.com","rec":"07418f2b0f334c1696c10cbe6f6f31a6-60a-e4a2","user":"demo-user",... ...- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - You require the value of the - rec(recording ID) field in the next step.- Note that the value of the - _COMMfield is shortened due to a 15 character limit.
- Play back a session: - tlog-play -r journal -M TLOG_REC=<recording_id> - # tlog-play -r journal -M TLOG_REC=<recording_id>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
29.2. Excluding certain users and groups from session recording by using the tlog RHEL system role
				You can use the tlog_exclude_users_sssd and tlog_exclude_groups_sssd role variables from the tlog RHEL system role to exclude users or groups from having their sessions recorded and logged in the systemd journal.
			
				The playbook installs tlog-rec-session, a terminal session I/O logging program, that acts as the login shell for a user. The role creates an SSSD configuration drop file, and this file defines for which users and groups the login shell should be used. Additionally, if the cockpit package is installed on the system, the playbook also installs the cockpit-session-recording package, which is a Cockpit module that allows you to view and play recordings in the web console interface.
			
Prerequisites
- You have prepared the control node and the managed nodes.
- You are logged in to the control node as a user who can run playbooks on the managed nodes.
- 
						The account you use to connect to the managed nodes has sudopermissions on them.
Procedure
- Create a playbook file, for example, - ~/playbook.yml, with the following content:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - tlog_scope_sssd: <value>
- 
									The value allspecifies that you want to record all users and groups.
- tlog_exclude_users_sssd: <user_list>
- A YAML list of users user names you want to exclude from the session recording.
- tlog_exclude_groups_sssd: <group_list>
- A YAML list of groups you want to exclude from the session recording.
 
- Validate the playbook syntax: - ansible-playbook --syntax-check ~/playbook.yml - $ ansible-playbook --syntax-check ~/playbook.yml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Note that this command only validates the syntax and does not protect against a wrong but valid configuration. 
- Run the playbook: - ansible-playbook ~/playbook.yml - $ ansible-playbook ~/playbook.yml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
Verification
- Check the SSSD drop-in file’s content: - cat /etc/sssd/conf.d/sssd-session-recording.conf - # cat /etc/sssd/conf.d/sssd-session-recording.conf- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - You can see that the file contains the parameters you set in the playbook. 
- Log in as a user whose session will be recorded, perform some actions, and log out.
- As the - rootuser:- Display the list of recorded sessions: - journalctl _COMM=tlog-rec-sessio - # journalctl _COMM=tlog-rec-sessio Nov 12 09:17:30 managed-node-01.example.com -tlog-rec-session[1546]: {"ver":"2.3","host":"managed-node-01.example.com","rec":"07418f2b0f334c1696c10cbe6f6f31a6-60a-e4a2","user":"demo-user",... ...- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - You require the value of the - rec(recording ID) field in the next step.- Note that the value of the - _COMMfield is shortened due to a 15 character limit.
- Play back a session: - tlog-play -r journal -M TLOG_REC=<recording_id> - # tlog-play -r journal -M TLOG_REC=<recording_id>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow