π ~4 min read β’ Source: ELSA advisory ELSA-2019-3520
Related CVEs: CVE-2019-9947 CVE-2019-9948 CVE-2019-9740 CVE-2019-5010
Table of contents
Symptom & Impact
On Oracle Linux 8 hosts that have python3 installed, administrators report behaviour consistent with ELSA advisory ELSA-2019-3520: failed transactions, units in failed state, audit denials, or β for security-rated advisories β exposure to the vulnerabilities tracked under the related CVEs. Operators see failed systemctl --failed output, abnormal entries in journalctl -xe, and β where the package is part of the serving path β degraded availability. On Oracle Linux 8 the impact ranges from a single service-restart loop to wider production incidents depending on host role and the criticality of python3.
Environment & Reproduction
Reproduction targets Oracle Linux 8 running either the Red Hat Compatible Kernel (RHCK) or the Unbreakable Enterprise Kernel (UEK). Confirm release, kernel, and installed package:
cat /etc/oracle-release
uname -r
rpm -q python3
dnf list installed python3
dnf history list --reverse | head -20
Trigger the workflow that exposes python3 β security and stability fixes β required update while collecting:
journalctl -u python3 -b --no-pager | tail -200
journalctl -xe --no-pager | tail -200
tail -200 /var/log/dnf.log
tail -200 /var/log/audit/audit.log
Root Cause Analysis
Root cause is documented in ELSA advisory ELSA-2019-3520. Upstream Red Hat / Oracle Linux maintainers shipped a fix in the corresponding python3 errata; running an outdated build leaves the host exposed and may trigger the failure modes described in the advisory. Correlate transaction history with system logs and SELinux audit entries to isolate the originating change:
dnf history list --reverse | head -30
dnf history info $(dnf history list | awk '/python3/ {print $1; exit}')
ausearch -m AVC,USER_AVC -ts today | tail -100
cat /proc/sys/kernel/tainted # non-zero = kernel modules / out-of-tree drivers loaded
Quick Triage
Run these checks on Oracle Linux 8 to confirm the failure mode and current state of python3:
rpm -q python3 # installed version
rpm -V python3 # verify file integrity
dnf updateinfo info --security python3 # any security advisories outstanding
systemctl --failed --no-pager
firewall-cmd --list-all 2>/dev/null || echo 'firewalld not running'
getenforce # SELinux mode
# If python3 ships a systemd unit (unit name may differ from the pkg name,
# e.g. httpd pkg/unit match, but bindβnamed, postgresql-serverβpostgresql):
systemctl list-unit-files | grep -i python3 | head -5
Step-by-Step Diagnosis
-
List failed units.
systemctl --failed --no-pager -
Follow the journal for
python3and the system bus.journalctl -u python3 -f --no-pager journalctl -xe -f --no-pager -
Check firewall posture (skip if firewalld is masked).
firewall-cmd --list-all-zones --permanent nft list ruleset 2>/dev/null | head -50 -
Surface SELinux denials and translate them to a policy module if needed.
ausearch -m AVC,USER_AVC -ts today ausearch -m AVC -ts today | audit2allow -a -M /tmp/local-fix # Inspect /tmp/local-fix.te before applying: sudo semodule -i /tmp/local-fix.pp -
Verify
python3integrity and dependency closure.dnf check rpm -V python3 rpm -q --requires python3 | xargs -r rpm -q --whatprovides | head -
Correlate findings with
/var/log/dnf.log,dnf historyand ELSA advisory ELSA-2019-3520 to pin the change that introduced python3 β security and stability fixes β required update.
Solution – Primary Fix
Apply the corrective dnf transaction referenced by ELSA advisory ELSA-2019-3520, reload affected systemd units, and reconcile firewalld / SELinux state:
sudo dnf clean expire-cache
sudo dnf -y update python3
sudo systemctl daemon-reload
# If python3 ships a systemd unit (unit name may differ from pkg name):
sudo systemctl restart python3
rpm -q python3 # confirm new NVR
systemctl is-active python3 # confirm running (if a unit exists)
If the advisory says a reboot is required (kernel, glibc, systemd, openssl):
sudo needs-restarting -r # reports kernel/init/glibc need
sudo systemctl reboot # or: sudo shutdown -r now
Need help applying this fix at scale? Our IT Solutions & Services team rolls Oracle Linux patches across estates with zero-downtime change windows and Ksplice live-patching. Get in touch for a free consultation.
Solution – Alternative Approaches
If the primary fix is not viable, choose from these alternatives:
-
Roll back the offending dnf transaction:
sudo dnf history list --reverse sudo dnf history undo <id> -
Pin
python3with the versionlock plugin:sudo dnf install -y python3-dnf-plugin-versionlock sudo dnf versionlock add python3 sudo dnf versionlock list | grep python3 -
Downgrade to a known-good NVR from the repo cache or vault:
sudo dnf --showduplicates list python3 sudo dnf -y downgrade python3-<older-NVR> -
Switch firewalld backend (nftables β iptables) for compatibility:
sudo sed -i 's/^FirewallBackend=.*/FirewallBackend=iptables/' /etc/firewalld/firewalld.conf sudo systemctl restart firewalld -
If SELinux is suspected, switch to permissive briefly, capture denials, and author a custom module before re-enforcing:
sudo setenforce 0 # do NOT leave permissive # reproduce the failure sudo ausearch -m AVC -ts recent | audit2allow -a -M mylocal sudo semodule -i mylocal.pp sudo setenforce 1 -
Where the advisory has Ksplice coverage, live-patch without reboot (Oracle Linux Premier Support):
sudo uptrack-show # current live patches sudo uptrack-upgrade -y # apply all available uptrack-uname -r # effective kernel after live patching
Verification & Acceptance Criteria
All of these should pass after the fix:
rpm -q python3 # shows the expected fixed NVR
dnf updateinfo list --security installed | head # no security advisories pending for us
systemctl is-active python3 2>/dev/null # active (if a unit exists)
journalctl -u python3 --since "5 minutes ago" --no-pager # no new errors
firewall-cmd --list-services # required services present
getenforce # intended mode (Enforcing/Permissive)
The original reproduction for python3 β security and stability fixes β required update must not trigger across two consecutive runs.
Rollback Plan
Capture state before any change:
rpm -qa > /root/rpm-pre.txt
dnf history list --reverse > /root/dnf-history-pre.txt
# LVM snapshot of the root LV (size to ~10% of root):
sudo lvcreate -L 4G -s -n root_pre_patch /dev/mapper/$(lvs --noheadings -o lv_path | grep -m1 root | xargs basename)
To revert if the patch is bad:
sudo dnf history undo <id>
# Or downgrade just python3 to the previous NVR:
sudo dnf -y downgrade python3
sudo systemctl daemon-reload
# For SELinux module additions:
sudo semodule -r mylocal
# Reboot only if kernel/initramfs/glibc were rolled back:
sudo systemctl reboot
For kernel rollbacks, select the previous entry from the GRUB menu or set it as default with grubby --set-default /boot/vmlinuz-<older>.
Prevention & Hardening
Prevent recurrence on Oracle Linux 8 hosts running python3:
-
Enable scheduled security updates via
dnf-automatic:sudo dnf install -y dnf-automatic # Edit /etc/dnf/automatic.conf: # upgrade_type = security # apply_updates = yes sudo systemctl enable --now dnf-automatic.timer -
Subscribe to the Oracle Linux Errata RSS / mailing list at linux.oracle.com/security.
-
Mirror through a local yum/dnf repository:
sudo dnf install -y dnf-utils createrepo_c sudo reposync --download-metadata --downloadcomps -p /srv/repos -m --repo=ol8_baseos_latest sudo createrepo_c /srv/repos/ol-baseos -
Pin sensitive packages so they cannot be auto-upgraded:
sudo dnf install -y python3-dnf-plugin-versionlock sudo dnf versionlock add python3 -
Snapshot the root LV before every upgrade window:
sudo lvcreate -L 4G -s -n root_pre_$(date +%Y%m%d) /dev/<vg>/<root-lv> -
Monitor file integrity with AIDE:
sudo dnf install -y aide sudo aide --init && sudo mv /var/lib/aide/aide.db.new.gz /var/lib/aide/aide.db.gz sudo aide --check -
Lock down with SELinux audit rules in
/etc/audit/rules.d/:# /etc/audit/rules.d/90-cp.rules -w /etc/passwd -p wa -k identity -w /etc/shadow -p wa -k identity -w /etc/sudoers -p wa -k privilege -a always,exit -F arch=b64 -S execve -k exec -
Where licensed, enable Oracle Ksplice for live kernel and userspace patching:
sudo dnf install -y uptrack ksplice-tools sudo uptrack-upgrade -y sudo systemctl enable --now uptrack
Related Errors & Cross-Refs
Issues that commonly surface alongside python3 β security and stability fixes β required update: dnf transaction lock contention, systemd unit ordering cycles, SELinux AVC bursts, firewalld zone drift, and kernel taint flags. Triage with:
cat /proc/sys/kernel/tainted
systemd-analyze critical-chain
ausearch -m AVC -ts today | tail
firewall-cmd --get-active-zones
dnf history list --reverse | head
View all oracle-linux-8 tutorials on the Tutorials Hub →
Browse all common problems & solutions on the Tutorials Hub.
References & Further Reading
Primary reference: ELSA advisory ELSA-2019-3520. Useful manual pages on Oracle Linux 8:
man dnf
man dnf.conf
man systemctl
man journalctl
man firewall-cmd
man semanage
man audit2allow
man grubby
Other resources: Oracle Linux 8 Administrator’s Guide at docs.oracle.com, the upstream Red Hat CVE database at access.redhat.com/security/cve, the Oracle Ksplice known-fixes feed, and /usr/share/doc/python3/ for component-specific notes implicated in python3 β security and stability fixes β required update.