mirror of
https://github.com/MacRimi/ProxMenux.git
synced 2025-08-14 08:52:22 +00:00
update pve 8
This commit is contained in:
parent
6e1cb2e0fe
commit
d1c8aeb25d
@ -17,7 +17,6 @@ fi
|
|||||||
load_language
|
load_language
|
||||||
initialize_cache
|
initialize_cache
|
||||||
|
|
||||||
|
|
||||||
ensure_tools_json() {
|
ensure_tools_json() {
|
||||||
[ -f "$TOOLS_JSON" ] || echo "{}" > "$TOOLS_JSON"
|
[ -f "$TOOLS_JSON" ] || echo "{}" > "$TOOLS_JSON"
|
||||||
}
|
}
|
||||||
@ -29,7 +28,6 @@ register_tool() {
|
|||||||
jq --arg t "$tool" --argjson v "$state" '.[$t]=$v' "$TOOLS_JSON" > "$TOOLS_JSON.tmp" && mv "$TOOLS_JSON.tmp" "$TOOLS_JSON"
|
jq --arg t "$tool" --argjson v "$state" '.[$t]=$v' "$TOOLS_JSON" > "$TOOLS_JSON.tmp" && mv "$TOOLS_JSON.tmp" "$TOOLS_JSON"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
download_common_functions() {
|
download_common_functions() {
|
||||||
if ! source <(curl -s "$REPO_URL/scripts/global/common-functions.sh"); then
|
if ! source <(curl -s "$REPO_URL/scripts/global/common-functions.sh"); then
|
||||||
return 1
|
return 1
|
||||||
@ -46,7 +44,6 @@ update_pve8() {
|
|||||||
OS_CODENAME=$(lsb_release -cs 2>/dev/null || echo "bookworm")
|
OS_CODENAME=$(lsb_release -cs 2>/dev/null || echo "bookworm")
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
download_common_functions
|
download_common_functions
|
||||||
|
|
||||||
clear
|
clear
|
||||||
@ -56,7 +53,6 @@ update_pve8() {
|
|||||||
msg_info2 "$(translate "Detected: Proxmox VE 8.x (Debian $OS_CODENAME)")"
|
msg_info2 "$(translate "Detected: Proxmox VE 8.x (Debian $OS_CODENAME)")"
|
||||||
echo
|
echo
|
||||||
|
|
||||||
|
|
||||||
local available_space=$(df /var/cache/apt/archives | awk 'NR==2 {print int($4/1024)}')
|
local available_space=$(df /var/cache/apt/archives | awk 'NR==2 {print int($4/1024)}')
|
||||||
if [ "$available_space" -lt 1024 ]; then
|
if [ "$available_space" -lt 1024 ]; then
|
||||||
msg_error "$(translate "Insufficient disk space. Available: ${available_space}MB")"
|
msg_error "$(translate "Insufficient disk space. Available: ${available_space}MB")"
|
||||||
@ -75,8 +71,6 @@ update_pve8() {
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if [ -f /etc/apt/sources.list.d/pve-enterprise.list ] && grep -q "^deb" /etc/apt/sources.list.d/pve-enterprise.list; then
|
if [ -f /etc/apt/sources.list.d/pve-enterprise.list ] && grep -q "^deb" /etc/apt/sources.list.d/pve-enterprise.list; then
|
||||||
msg_info "$(translate "Disabling enterprise Proxmox repository...")"
|
msg_info "$(translate "Disabling enterprise Proxmox repository...")"
|
||||||
sed -i "s/^deb/#deb/g" /etc/apt/sources.list.d/pve-enterprise.list
|
sed -i "s/^deb/#deb/g" /etc/apt/sources.list.d/pve-enterprise.list
|
||||||
@ -103,7 +97,6 @@ update_pve8() {
|
|||||||
local sources_file="/etc/apt/sources.list"
|
local sources_file="/etc/apt/sources.list"
|
||||||
cp "$sources_file" "${sources_file}.backup.$(date +%Y%m%d_%H%M%S)"
|
cp "$sources_file" "${sources_file}.backup.$(date +%Y%m%d_%H%M%S)"
|
||||||
|
|
||||||
|
|
||||||
if grep -q -E "(debian-security -security|debian main$|debian -updates)" "$sources_file"; then
|
if grep -q -E "(debian-security -security|debian main$|debian -updates)" "$sources_file"; then
|
||||||
msg_info "$(translate "Cleaning malformed repository entries...")"
|
msg_info "$(translate "Cleaning malformed repository entries...")"
|
||||||
sed -i '/^deb.*debian-security -security/d' "$sources_file"
|
sed -i '/^deb.*debian-security -security/d' "$sources_file"
|
||||||
@ -113,9 +106,6 @@ update_pve8() {
|
|||||||
msg_ok "$(translate "Malformed repository entries cleaned")"
|
msg_ok "$(translate "Malformed repository entries cleaned")"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
cat > "$sources_file" << EOF
|
cat > "$sources_file" << EOF
|
||||||
# Debian $OS_CODENAME repositories
|
# Debian $OS_CODENAME repositories
|
||||||
deb http://deb.debian.org/debian $OS_CODENAME main contrib non-free non-free-firmware
|
deb http://deb.debian.org/debian $OS_CODENAME main contrib non-free non-free-firmware
|
||||||
@ -125,15 +115,12 @@ EOF
|
|||||||
|
|
||||||
msg_ok "$(translate "Debian repositories configured for $OS_CODENAME")"
|
msg_ok "$(translate "Debian repositories configured for $OS_CODENAME")"
|
||||||
|
|
||||||
|
|
||||||
local firmware_conf="/etc/apt/apt.conf.d/no-firmware-warnings.conf"
|
local firmware_conf="/etc/apt/apt.conf.d/no-firmware-warnings.conf"
|
||||||
if [ ! -f "$firmware_conf" ]; then
|
if [ ! -f "$firmware_conf" ]; then
|
||||||
echo 'APT::Get::Update::SourceListWarnings::NonFreeFirmware "false";' > "$firmware_conf"
|
echo 'APT::Get::Update::SourceListWarnings::NonFreeFirmware "false";' > "$firmware_conf"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
cleanup_duplicate_repos
|
||||||
cleanup_duplicate_repos "$OS_CODENAME"
|
|
||||||
|
|
||||||
|
|
||||||
msg_info "$(translate "Updating package lists...")"
|
msg_info "$(translate "Updating package lists...")"
|
||||||
if apt-get update > "$log_file" 2>&1; then
|
if apt-get update > "$log_file" 2>&1; then
|
||||||
@ -143,15 +130,11 @@ EOF
|
|||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
local current_pve_version=$(pveversion 2>/dev/null | grep -oP 'pve-manager/\K[0-9]+\.[0-9]+\.[0-9]+' | head -1)
|
local current_pve_version=$(pveversion 2>/dev/null | grep -oP 'pve-manager/\K[0-9]+\.[0-9]+\.[0-9]+' | head -1)
|
||||||
local available_pve_version=$(get_available_pve_version 8 "$OS_CODENAME")
|
local available_pve_version=$(apt-cache policy pve-manager 2>/dev/null | grep -oP 'Candidate: \K[0-9]+\.[0-9]+\.[0-9]+' | head -1)
|
||||||
local upgradable=$(apt list --upgradable 2>/dev/null | grep -c "upgradable")
|
local upgradable=$(apt list --upgradable 2>/dev/null | grep -c "upgradable")
|
||||||
local security_updates=$(apt list --upgradable 2>/dev/null | grep -c "security")
|
local security_updates=$(apt list --upgradable 2>/dev/null | grep -c "security")
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
show_update_menu() {
|
show_update_menu() {
|
||||||
local current_version="$1"
|
local current_version="$1"
|
||||||
local target_version="$2"
|
local target_version="$2"
|
||||||
@ -160,11 +143,9 @@ EOF
|
|||||||
|
|
||||||
local menu_text="$(translate "System Update Information")\n\n"
|
local menu_text="$(translate "System Update Information")\n\n"
|
||||||
menu_text+="$(translate "Current PVE Version"): $current_version\n"
|
menu_text+="$(translate "Current PVE Version"): $current_version\n"
|
||||||
|
|
||||||
if [ -n "$target_version" ] && [ "$target_version" != "$current_version" ]; then
|
if [ -n "$target_version" ] && [ "$target_version" != "$current_version" ]; then
|
||||||
menu_text+="$(translate "Available PVE Version"): $target_version\n"
|
menu_text+="$(translate "Available PVE Version"): $target_version\n"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
menu_text+="\n$(translate "Package Updates Available"): $upgradable_count\n"
|
menu_text+="\n$(translate "Package Updates Available"): $upgradable_count\n"
|
||||||
menu_text+="$(translate "Security Updates"): $security_count\n\n"
|
menu_text+="$(translate "Security Updates"): $security_count\n\n"
|
||||||
|
|
||||||
@ -187,18 +168,16 @@ MENU_RESULT=$?
|
|||||||
|
|
||||||
if [[ $MENU_RESULT -eq 1 ]]; then
|
if [[ $MENU_RESULT -eq 1 ]]; then
|
||||||
msg_info2 "$(translate "Update cancelled by user")"
|
msg_info2 "$(translate "Update cancelled by user")"
|
||||||
perform_final_cleanup
|
apt-get -y autoremove > /dev/null 2>&1 || true
|
||||||
|
apt-get -y autoclean > /dev/null 2>&1 || true
|
||||||
return 0
|
return 0
|
||||||
|
|
||||||
elif [[ $MENU_RESULT -eq 2 ]]; then
|
elif [[ $MENU_RESULT -eq 2 ]]; then
|
||||||
msg_ok "$(translate "System is already up to date. No update needed.")"
|
msg_ok "$(translate "System is already up to date. No update needed.")"
|
||||||
perform_final_cleanup
|
apt-get -y autoremove > /dev/null 2>&1 || true
|
||||||
|
apt-get -y autoclean > /dev/null 2>&1 || true
|
||||||
return 0
|
return 0
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
msg_info "$(translate "Removing conflicting utilities...")"
|
msg_info "$(translate "Removing conflicting utilities...")"
|
||||||
local conflicting_packages=$(dpkg -l 2>/dev/null | grep -E "^ii.*(ntp|openntpd|systemd-timesyncd)" | awk '{print $2}')
|
local conflicting_packages=$(dpkg -l 2>/dev/null | grep -E "^ii.*(ntp|openntpd|systemd-timesyncd)" | awk '{print $2}')
|
||||||
if [ -n "$conflicting_packages" ]; then
|
if [ -n "$conflicting_packages" ]; then
|
||||||
@ -206,7 +185,6 @@ fi
|
|||||||
msg_ok "$(translate "Conflicting utilities removed")"
|
msg_ok "$(translate "Conflicting utilities removed")"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
msg_info "$(translate "Performing system upgrade...")"
|
msg_info "$(translate "Performing system upgrade...")"
|
||||||
if DEBIAN_FRONTEND=noninteractive apt-get -y \
|
if DEBIAN_FRONTEND=noninteractive apt-get -y \
|
||||||
-o Dpkg::Options::='--force-confdef' \
|
-o Dpkg::Options::='--force-confdef' \
|
||||||
@ -218,7 +196,6 @@ fi
|
|||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
msg_info "$(translate "Installing essential Proxmox packages...")"
|
msg_info "$(translate "Installing essential Proxmox packages...")"
|
||||||
local essential_packages=("zfsutils-linux" "proxmox-backup-restore-image" "chrony")
|
local essential_packages=("zfsutils-linux" "proxmox-backup-restore-image" "chrony")
|
||||||
local missing_packages=()
|
local missing_packages=()
|
||||||
@ -233,20 +210,20 @@ fi
|
|||||||
DEBIAN_FRONTEND=noninteractive apt-get -y install "${missing_packages[@]}" >> "$log_file" 2>&1
|
DEBIAN_FRONTEND=noninteractive apt-get -y install "${missing_packages[@]}" >> "$log_file" 2>&1
|
||||||
msg_ok "$(translate "Essential Proxmox packages installed")"
|
msg_ok "$(translate "Essential Proxmox packages installed")"
|
||||||
fi
|
fi
|
||||||
cleanup
|
|
||||||
|
|
||||||
lvm_repair_check
|
lvm_repair_check
|
||||||
|
cleanup_duplicate_repos
|
||||||
|
|
||||||
|
msg_info "$(translate "Performing system cleanup...")"
|
||||||
perform_final_cleanup
|
apt-get -y autoremove > /dev/null 2>&1 || true
|
||||||
|
apt-get -y autoclean > /dev/null 2>&1 || true
|
||||||
|
msg_ok "$(translate "Cleanup finished")"
|
||||||
|
|
||||||
local end_time=$(date +%s)
|
local end_time=$(date +%s)
|
||||||
local duration=$((end_time - start_time))
|
local duration=$((end_time - start_time))
|
||||||
local minutes=$((duration / 60))
|
local minutes=$((duration / 60))
|
||||||
local seconds=$((duration % 60))
|
local seconds=$((duration % 60))
|
||||||
|
|
||||||
|
|
||||||
echo -e "${TAB}${BGN}$(translate "=== PVE 8 UPDATE COMPLETED ===")${CL}"
|
echo -e "${TAB}${BGN}$(translate "=== PVE 8 UPDATE COMPLETED ===")${CL}"
|
||||||
echo -e "${TAB}${GN}$(translate "Duration")${CL}: ${DGN}${minutes}m ${seconds}s${CL}"
|
echo -e "${TAB}${GN}$(translate "Duration")${CL}: ${DGN}${minutes}m ${seconds}s${CL}"
|
||||||
echo -e "${TAB}${GN}$(translate "Log file")${CL}: ${DGN}$log_file${CL}"
|
echo -e "${TAB}${GN}$(translate "Log file")${CL}: ${DGN}$log_file${CL}"
|
||||||
@ -254,7 +231,6 @@ fi
|
|||||||
echo -e "${TAB}${GN}$(translate "Proxmox VE")${CL}: ${DGN}8.x (Debian $OS_CODENAME)${CL}"
|
echo -e "${TAB}${GN}$(translate "Proxmox VE")${CL}: ${DGN}8.x (Debian $OS_CODENAME)${CL}"
|
||||||
|
|
||||||
msg_ok "$(translate "Proxmox VE 8 system update completed successfully")"
|
msg_ok "$(translate "Proxmox VE 8 system update completed successfully")"
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if [[ "${BASH_SOURCE[0]}" == "${0}" ]]; then
|
if [[ "${BASH_SOURCE[0]}" == "${0}" ]]; then
|
||||||
|
@ -574,18 +574,31 @@ install_system_utils() {
|
|||||||
local need_update=false
|
local need_update=false
|
||||||
|
|
||||||
|
|
||||||
|
if [[ ! -f "$sources_file" ]]; then
|
||||||
|
msg_warn "$(translate "sources.list not found, creating default Debian repository...")"
|
||||||
|
cat > "$sources_file" << EOF
|
||||||
|
# Default Debian ${OS_CODENAME} repository
|
||||||
|
deb http://deb.debian.org/debian ${OS_CODENAME} main contrib non-free non-free-firmware
|
||||||
|
EOF
|
||||||
|
need_update=true
|
||||||
|
else
|
||||||
|
|
||||||
if ! grep -q "deb.*${OS_CODENAME}.*main" "$sources_file"; then
|
if ! grep -q "deb.*${OS_CODENAME}.*main" "$sources_file"; then
|
||||||
echo "deb http://deb.debian.org/debian ${OS_CODENAME} main contrib non-free non-free-firmware" >> "$sources_file"
|
echo "deb http://deb.debian.org/debian ${OS_CODENAME} main contrib non-free non-free-firmware" >> "$sources_file"
|
||||||
need_update=true
|
need_update=true
|
||||||
fi
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
if [ "$need_update" = true ] || ! apt list --installed >/dev/null 2>&1; then
|
|
||||||
apt update >/dev/null 2>&1
|
if [[ "$need_update" == true ]] || ! apt list --installed >/dev/null 2>&1; then
|
||||||
|
msg_info "$(translate "Updating APT package lists...")"
|
||||||
|
apt-get update -o Acquire::AllowInsecureRepositories=true >/dev/null 2>&1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
return 0
|
return 0
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
install_single_package() {
|
install_single_package() {
|
||||||
local package="$1"
|
local package="$1"
|
||||||
local command_name="${2:-$package}"
|
local command_name="${2:-$package}"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user