|
1 | 1 | #!/bin/bash
|
2 | 2 |
|
3 |
| -OS_VERSION="$(rpm -q --qf '%{version}' $(rpm -q --whatprovides redhat-release 2>/dev/null) 2>/dev/null | cut -c 1)" |
4 | 3 | BACKUP="/etc/cl-elevate-saved"
|
5 |
| -log=/var/log/elevate_els_packages.log |
| 4 | +RUNNING_KERNEL=$(uname -r) |
6 | 5 |
|
7 |
| -# Create log directory if it doesn't exist |
8 |
| -mkdir -p "$(dirname "$log")" |
9 |
| -touch "$log" |
10 |
| - |
11 |
| -# Start logging |
12 |
| -echo "Starting ELS package handling at $(date)" | tee -a "${log}" |
| 6 | +echo "Starting ELS package handling" |
| 7 | +echo "Running kernel: ${RUNNING_KERNEL}" |
13 | 8 |
|
14 | 9 | mkdir -p "${BACKUP}" 2>/dev/null || {
|
15 |
| - echo "Failed to create backup directory ${BACKUP}" | tee -a "${log}" |
| 10 | + echo "Failed to create backup directory ${BACKUP}" |
16 | 11 | exit 1
|
17 | 12 | }
|
18 | 13 |
|
19 |
| -# Only proceed for CentOS 7 |
20 |
| -if [[ "$OS_VERSION" != "7" ]]; then |
21 |
| - echo "Not Cloudlinux 7, skipping ELS processing" | tee -a "${log}" |
22 |
| - exit 0 |
23 |
| -fi |
24 |
| - |
25 | 14 | # Check if ELS repositories are present
|
26 | 15 | if ! ls /etc/yum.repos.d/centos*els*.repo &> /dev/null; then
|
27 |
| - echo "No ELS repositories found, skipping processing" | tee -a "${log}" |
| 16 | + echo "No ELS repositories found, skipping processing" |
28 | 17 | exit 0
|
29 | 18 | fi
|
30 | 19 |
|
31 |
| -echo "ELS repositories detected. Processing ELS packages before conversion..." | tee -a "${log}" |
| 20 | +echo "ELS repositories detected. Processing ELS packages before conversion..." |
32 | 21 |
|
33 | 22 | # Create package backup list
|
34 | 23 | rpm -qa | sort > "${BACKUP}/els_packages_backup_$(date +%Y%m%d_%H%M%S).txt" || {
|
35 |
| - echo "Warning: Failed to create package backup list" | tee -a "${log}" |
| 24 | + echo "Warning: Failed to create package backup list" |
| 25 | +} |
| 26 | + |
| 27 | +# Function to check if kernel is in use |
| 28 | +is_kernel_in_use() { |
| 29 | + local kernel_pkg=$1 |
| 30 | + local kernel_ver=$(rpm -q --queryformat '%{VERSION}-%{RELEASE}' "$kernel_pkg") |
| 31 | + [[ "$kernel_ver" == "$RUNNING_KERNEL" ]] |
36 | 32 | }
|
37 | 33 |
|
38 | 34 | # Prevent ELS packages from being reinstalled
|
39 | 35 | if ! grep -q "exclude=\*.tuxcare.els\*" /etc/yum.conf; then
|
40 | 36 | {
|
41 | 37 | echo
|
42 |
| - echo "# Added by elevate" |
| 38 | + echo "# Added by cloudlinux Elevate" |
43 | 39 | echo "exclude=*.tuxcare.els*"
|
44 |
| - } >> /etc/yum.conf || echo "Warning: Failed to add exclusion to yum.conf" | tee -a "${log}" |
| 40 | + } >> /etc/yum.conf || echo "Warning: Failed to add exclusion to yum.conf" |
45 | 41 | fi
|
46 | 42 |
|
47 | 43 | # Save and disable ELS repos
|
48 |
| -cp /etc/yum.repos.d/centos*els*.repo "${BACKUP}/" 2>&1 | tee -a "${log}" || true |
49 |
| -echo "Disabling ELS repositories..." | tee -a "${log}" |
50 |
| -yum-config-manager --disable centos7-els 2>&1 | tee -a "${log}" || true |
| 44 | +cp /etc/yum.repos.d/centos*els*.repo "${BACKUP}/" 2>&1 |
| 45 | +echo "Disabling ELS repositories..." |
| 46 | +yum-config-manager --disable centos7-els 2>&1 |
51 | 47 | for i in {1..6}; do
|
52 |
| - yum-config-manager --disable centos7els-rollout-$i 2>&1 | tee -a "${log}" || true |
| 48 | + yum-config-manager --disable centos7els-rollout-$i 2>&1 |
53 | 49 | done
|
54 | 50 |
|
55 | 51 | # Remove els-define package first if present
|
56 | 52 | if rpm -q els-define &> /dev/null; then
|
57 |
| - yum remove -y els-define 2>&1 | tee -a "${log}" || echo "Warning: Failed to remove els-define" | tee -a "${log}" |
| 53 | + yum remove -y els-define 2>&1 || echo "Warning: Failed to remove els-define" |
58 | 54 | fi
|
59 | 55 |
|
60 | 56 | # Get list of installed ELS packages
|
61 |
| -echo "Checking for ELS packages..." | tee -a "${log}" |
| 57 | +echo "Checking for ELS packages..." |
62 | 58 | els_pkgs=$(rpm -qa | grep -E '\.tuxcare\.els[0-9]') || true
|
63 | 59 |
|
64 | 60 | if [ -n "$els_pkgs" ]; then
|
65 |
| - echo "Found ELS packages:" | tee -a "${log}" |
66 |
| - echo "$els_pkgs" | tee -a "${log}" |
67 |
| - |
68 |
| - # Create a yum shell script to handle the transaction |
69 |
| - TMPFILE=$(mktemp) |
70 |
| - echo "# yum shell commands" > "$TMPFILE" |
71 |
| - |
72 |
| - # Process each package |
73 |
| - while read -r pkg; do |
74 |
| - base_name=$(echo "$pkg" | awk -F'-[0-9]' '{print $1}') |
75 |
| - if [ -n "$base_name" ]; then |
76 |
| - echo "remove $pkg" >> "$TMPFILE" |
77 |
| - echo "install $base_name" >> "$TMPFILE" |
78 |
| - fi |
79 |
| - done <<< "$els_pkgs" |
| 61 | + echo "Found ELS packages:" |
| 62 | + echo "$els_pkgs" |
| 63 | + |
| 64 | + # Handle kernel packages separately and more aggressively |
| 65 | + els_kernel_pkgs=$(echo "$els_pkgs" | grep "^kernel") || true |
| 66 | + if [ -n "$els_kernel_pkgs" ]; then |
| 67 | + echo "Found ELS kernel packages:" |
| 68 | + echo "$els_kernel_pkgs" |
| 69 | + |
| 70 | + # Remove all ELS kernel packages, regardless of running kernel |
| 71 | + # since we already have the LVE kernel installed |
| 72 | + echo "Removing all ELS kernel packages since LVE kernel is present..." |
| 73 | + for kernel_pkg in $els_kernel_pkgs; do |
| 74 | + echo "Removing ELS kernel package: $kernel_pkg" |
| 75 | + rpm -e --nodeps "$kernel_pkg" 2>&1 || { |
| 76 | + echo "Warning: Failed to remove $kernel_pkg" |
| 77 | + # If rpm -e fails, try with yum as fallback |
| 78 | + yum remove -y "$kernel_pkg" 2>&1 |
| 79 | + } |
| 80 | + done |
| 81 | + fi |
80 | 82 |
|
81 |
| - echo "run" >> "$TMPFILE" |
82 |
| - echo "exit" >> "$TMPFILE" |
| 83 | + # Process remaining non-kernel ELS packages |
| 84 | + non_kernel_els_pkgs=$(echo "$els_pkgs" | grep -v "^kernel") || true |
| 85 | + if [ -n "$non_kernel_els_pkgs" ]; then |
| 86 | + echo "Processing non-kernel ELS packages..." |
83 | 87 |
|
84 |
| - # Execute the yum shell script |
85 |
| - echo "Replacing ELS packages with base versions..." | tee -a "${log}" |
86 |
| - if ! yum shell -y "$TMPFILE" 2>&1 | tee -a "${log}"; then |
87 |
| - echo "Trying alternative approach..." | tee -a "${log}" |
88 |
| - while read -r pkg; do |
| 88 | + # Create a yum shell script for batch processing |
| 89 | + TMPFILE=$(mktemp) |
| 90 | + echo "# yum shell commands" > "$TMPFILE" |
| 91 | + |
| 92 | + echo "$non_kernel_els_pkgs" | while read -r pkg; do |
89 | 93 | base_name=$(echo "$pkg" | awk -F'-[0-9]' '{print $1}')
|
90 | 94 | if [ -n "$base_name" ]; then
|
91 |
| - yum downgrade -y "$base_name" 2>&1 | tee -a "${log}" || true |
| 95 | + echo "remove $pkg" >> "$TMPFILE" |
| 96 | + echo "install $base_name" >> "$TMPFILE" |
92 | 97 | fi
|
93 |
| - done <<< "$els_pkgs" |
| 98 | + done |
| 99 | + |
| 100 | + echo "run" >> "$TMPFILE" |
| 101 | + echo "exit" >> "$TMPFILE" |
| 102 | + |
| 103 | + # Execute the yum shell script |
| 104 | + echo "Replacing non-kernel ELS packages with base versions..." |
| 105 | + if ! yum shell -y "$TMPFILE" 2>&1; then |
| 106 | + echo "Trying alternative approach for non-kernel packages..." |
| 107 | + echo "$non_kernel_els_pkgs" | while read -r pkg; do |
| 108 | + base_name=$(echo "$pkg" | awk -F'-[0-9]' '{print $1}') |
| 109 | + if [ -n "$base_name" ]; then |
| 110 | + yum downgrade -y "$base_name" 2>&1 |
| 111 | + fi |
| 112 | + done |
| 113 | + fi |
| 114 | + rm -f "$TMPFILE" |
94 | 115 | fi
|
95 |
| - rm -f "$TMPFILE" |
96 | 116 | fi
|
97 | 117 |
|
98 | 118 | # Move ELS repo files to backup and clean up
|
99 |
| -mv -f /etc/yum.repos.d/centos*els*.repo "${BACKUP}/" 2>&1 | tee -a "${log}" || true |
| 119 | +mv -f /etc/yum.repos.d/centos*els*.repo "${BACKUP}/" 2>&1 |
100 | 120 |
|
101 | 121 | # Remove TuxCare GPG key if it exists
|
102 | 122 | if [ -f "/etc/pki/rpm-gpg/RPM-GPG-KEY-TuxCare" ]; then
|
103 |
| - mv -f "/etc/pki/rpm-gpg/RPM-GPG-KEY-TuxCare" "${BACKUP}/" 2>&1 | tee -a "${log}" || true |
| 123 | + mv -f "/etc/pki/rpm-gpg/RPM-GPG-KEY-TuxCare" "${BACKUP}/" 2>&1 |
104 | 124 | fi
|
105 | 125 |
|
106 | 126 | # Clean yum cache
|
107 |
| -yum clean all 2>&1 | tee -a "${log}" || true |
| 127 | +yum clean all 2>&1 |
108 | 128 |
|
109 |
| -echo "ELS package handling complete" | tee -a "${log}" |
| 129 | +echo "ELS package handling complete" |
110 | 130 | exit 0
|
0 commit comments