|
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