2023-02-15 10:28:31 +08:00
|
|
|
|
#!/bin/bash
|
|
|
|
|
#from https://github.com/spiritLHLS/pve
|
|
|
|
|
|
2023-02-15 10:56:06 +08:00
|
|
|
|
# 打印信息
|
|
|
|
|
_red() { echo -e "\033[31m\033[01m$@\033[0m"; }
|
|
|
|
|
_green() { echo -e "\033[32m\033[01m$@\033[0m"; }
|
|
|
|
|
_yellow() { echo -e "\033[33m\033[01m$@\033[0m"; }
|
|
|
|
|
_blue() { echo -e "\033[36m\033[01m$@\033[0m"; }
|
2023-02-16 21:03:48 +08:00
|
|
|
|
reading(){ read -rp "$(_green "$1")" "$2"; }
|
2023-02-15 10:56:06 +08:00
|
|
|
|
|
2023-02-15 10:28:31 +08:00
|
|
|
|
# 前置环境安装
|
|
|
|
|
if [ "$(id -u)" != "0" ]; then
|
2023-02-15 10:56:06 +08:00
|
|
|
|
_red "This script must be run as root" 1>&2
|
2023-02-15 10:28:31 +08:00
|
|
|
|
exit 1
|
|
|
|
|
fi
|
2023-02-15 11:14:30 +08:00
|
|
|
|
apt-get update -y
|
2023-02-26 11:15:25 +08:00
|
|
|
|
if [ $? -ne 0 ]; then
|
|
|
|
|
dpkg --configure -a
|
|
|
|
|
apt-get update -y
|
|
|
|
|
fi
|
|
|
|
|
if [ $? -ne 0 ]; then
|
|
|
|
|
apt-get install gnupg -y
|
|
|
|
|
fi
|
|
|
|
|
output=$(apt-get update 2>&1)
|
|
|
|
|
if echo $output | grep -q "NO_PUBKEY"; then
|
2023-02-26 11:18:42 +08:00
|
|
|
|
_yellow "try “ sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys missing key ” to fix"
|
2023-02-26 11:15:25 +08:00
|
|
|
|
exit 1
|
|
|
|
|
fi
|
2023-02-15 10:28:31 +08:00
|
|
|
|
if ! command -v wget > /dev/null 2>&1; then
|
|
|
|
|
apt-get install -y wget
|
|
|
|
|
fi
|
|
|
|
|
if ! command -v curl > /dev/null 2>&1; then
|
|
|
|
|
apt-get install -y curl
|
|
|
|
|
fi
|
2023-02-17 09:56:19 +08:00
|
|
|
|
if ! command -v sudo > /dev/null 2>&1; then
|
|
|
|
|
apt-get install -y sudo
|
|
|
|
|
fi
|
|
|
|
|
if ! command -v bc > /dev/null 2>&1; then
|
|
|
|
|
apt-get install -y bc
|
|
|
|
|
fi
|
|
|
|
|
if ! command -v iptables > /dev/null 2>&1; then
|
|
|
|
|
apt-get install -y iptables
|
|
|
|
|
fi
|
2023-02-26 10:32:11 +08:00
|
|
|
|
|
|
|
|
|
# /etc/hosts文件修改
|
2023-02-15 10:40:54 +08:00
|
|
|
|
ip=$(curl -s ipv4.ip.sb)
|
2023-02-26 10:32:11 +08:00
|
|
|
|
hostname=$(hostname)
|
|
|
|
|
if [ "${hostname}" != "pve" ]; then
|
2023-04-04 19:16:25 +08:00
|
|
|
|
chattr -i /etc/hosts
|
2023-02-26 10:32:11 +08:00
|
|
|
|
hosts=$(grep -E "^[^#]*\s+${hostname}\s+${hostname}\$" /etc/hosts | grep -v "${ip}")
|
|
|
|
|
if [ -n "${hosts}" ]; then
|
|
|
|
|
# 注释掉查询到的行
|
|
|
|
|
sudo sed -i "s/^$(echo ${hosts} | sed 's/\//\\\//g')/# &/" /etc/hosts
|
|
|
|
|
# 添加新行
|
2023-04-04 10:57:27 +08:00
|
|
|
|
# echo "${ip} ${hostname} ${hostname}" | sudo tee -a /etc/hosts > /dev/null
|
|
|
|
|
# _green "已将 ${ip} ${hostname} ${hostname} 添加到 /etc/hosts 文件中"
|
2023-02-26 10:32:11 +08:00
|
|
|
|
else
|
|
|
|
|
_blue "已存在 ${ip} ${hostname} ${hostname} 的记录,无需添加"
|
|
|
|
|
fi
|
2023-04-04 12:41:37 +08:00
|
|
|
|
hostnamectl set-hostname pve
|
|
|
|
|
hostname=$(hostname)
|
|
|
|
|
if ! grep -q "::1 localhost" /etc/hosts; then
|
|
|
|
|
echo "::1 localhost" >> /etc/hosts
|
|
|
|
|
echo "Added ::1 localhost to /etc/hosts"
|
|
|
|
|
fi
|
|
|
|
|
# if grep -q "^127\.0\.0\.1 localhost$" /etc/hosts; then
|
|
|
|
|
# sed -i '/^127\.0\.0\.1 localhost$/ s/^/#/' /etc/hosts
|
|
|
|
|
# echo "Commented out 127.0.0.1 localhost in /etc/hosts"
|
|
|
|
|
# fi
|
|
|
|
|
if ! grep -q "^127\.0\.0\.1 localhost\.localdomain localhost$" /etc/hosts; then
|
|
|
|
|
# 127.0.1.1
|
|
|
|
|
echo "${ip} ${hostname}.localdomain ${hostname}" >> /etc/hosts
|
|
|
|
|
echo "Added ${ip} ${hostname}.localdomain ${hostname} to /etc/hosts"
|
|
|
|
|
fi
|
|
|
|
|
# if ! grep -q "${ip} pve.proxmox.com pve" /etc/hosts; then
|
|
|
|
|
# echo "${ip} pve.proxmox.com pve" >> /etc/hosts
|
|
|
|
|
# echo "Added ${ip} pve.proxmox.com pve to /etc/hosts"
|
|
|
|
|
# fi
|
2023-04-04 19:16:25 +08:00
|
|
|
|
chattr +i /etc/hosts
|
2023-02-26 10:32:11 +08:00
|
|
|
|
fi
|
2023-02-15 10:40:54 +08:00
|
|
|
|
|
2023-02-26 10:32:11 +08:00
|
|
|
|
## ChinaIP检测
|
2023-02-15 11:21:31 +08:00
|
|
|
|
if [[ -z "${CN}" ]]; then
|
|
|
|
|
if [[ $(curl -m 10 -s https://ipapi.co/json | grep 'China') != "" ]]; then
|
|
|
|
|
_yellow "根据ipapi.co提供的信息,当前IP可能在中国"
|
|
|
|
|
read -e -r -p "是否选用中国镜像完成安装? [Y/n] " input
|
|
|
|
|
case $input in
|
|
|
|
|
[yY][eE][sS] | [yY])
|
|
|
|
|
echo "使用中国镜像"
|
|
|
|
|
CN=true
|
|
|
|
|
;;
|
|
|
|
|
[nN][oO] | [nN])
|
|
|
|
|
echo "不使用中国镜像"
|
|
|
|
|
;;
|
|
|
|
|
*)
|
|
|
|
|
echo "使用中国镜像"
|
|
|
|
|
CN=true
|
|
|
|
|
;;
|
|
|
|
|
esac
|
|
|
|
|
fi
|
|
|
|
|
fi
|
|
|
|
|
|
2023-02-15 10:40:54 +08:00
|
|
|
|
# 再次预检查
|
|
|
|
|
apt-get install gnupg -y
|
|
|
|
|
if [ $(uname -m) != "x86_64" ] || [ ! -f /etc/debian_version ] || [ $(grep MemTotal /proc/meminfo | awk '{print $2}') -lt 2000000 ] || [ $(grep -c ^processor /proc/cpuinfo) -lt 2 ] || [ $(ping -c 3 google.com > /dev/null 2>&1; echo $?) -ne 0 ]; then
|
2023-02-15 10:56:06 +08:00
|
|
|
|
_red "Error: This system does not meet the minimum requirements for Proxmox VE installation."
|
2023-04-01 22:43:23 +08:00
|
|
|
|
reading "是否要继续安装(非Debian系或不满足最低的配置安装要求会爆上面这个警告)?(回车则默认不继续安装) [y/n] " confirm
|
2023-02-16 18:33:15 +08:00
|
|
|
|
echo ""
|
2023-02-16 21:08:26 +08:00
|
|
|
|
if [ "$confirm" != "y" ]; then
|
2023-02-16 18:33:15 +08:00
|
|
|
|
exit 1
|
|
|
|
|
fi
|
2023-02-15 10:40:54 +08:00
|
|
|
|
else
|
2023-02-15 11:07:15 +08:00
|
|
|
|
_green "The system meets the minimum requirements for Proxmox VE installation."
|
2023-02-15 10:40:54 +08:00
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
# 新增pve源
|
2023-02-15 12:26:12 +08:00
|
|
|
|
version=$(lsb_release -cs)
|
|
|
|
|
case $version in
|
2023-02-15 11:21:31 +08:00
|
|
|
|
jessie|stretch|buster|bullseye)
|
2023-02-15 12:29:34 +08:00
|
|
|
|
repo_url="deb http://download.proxmox.com/debian/pve ${version} pve-no-subscription"
|
2023-02-15 11:21:31 +08:00
|
|
|
|
if [[ -n "${CN}" ]]; then
|
2023-02-15 12:29:34 +08:00
|
|
|
|
repo_url="deb https://mirrors.tuna.tsinghua.edu.cn/proxmox/debian/pve ${version} pve-no-subscription"
|
2023-02-15 11:21:31 +08:00
|
|
|
|
fi
|
|
|
|
|
;;
|
|
|
|
|
*)
|
|
|
|
|
_red "Error: Unsupported Debian version"
|
2023-02-16 18:37:04 +08:00
|
|
|
|
reading "是否要继续安装(非Debian系会爆上面这个警告)?(回车则默认不继续安装) [y/n] " confirm
|
|
|
|
|
echo ""
|
2023-02-16 21:08:26 +08:00
|
|
|
|
if [ "$confirm" != "y" ]; then
|
2023-02-16 18:37:04 +08:00
|
|
|
|
exit 1
|
|
|
|
|
fi
|
|
|
|
|
repo_url="deb http://download.proxmox.com/debian/pve bullseye pve-no-subscription"
|
|
|
|
|
if [[ -n "${CN}" ]]; then
|
|
|
|
|
repo_url="deb https://mirrors.tuna.tsinghua.edu.cn/proxmox/debian/pve bullseye pve-no-subscription"
|
|
|
|
|
fi
|
2023-02-15 11:21:31 +08:00
|
|
|
|
;;
|
|
|
|
|
esac
|
2023-04-03 22:01:51 +08:00
|
|
|
|
|
|
|
|
|
# 6.x
|
2023-02-20 20:14:49 +08:00
|
|
|
|
if [ ! -f "/etc/apt/trusted.gpg.d/proxmox-ve-release-6.x.gpg" ]; then
|
|
|
|
|
wget http://download.proxmox.com/debian/proxmox-ve-release-6.x.gpg -O /etc/apt/trusted.gpg.d/proxmox-ve-release-6.x.gpg
|
|
|
|
|
chmod +r /etc/apt/trusted.gpg.d/proxmox-ve-release-6.x.gpg
|
|
|
|
|
fi
|
2023-04-03 22:01:51 +08:00
|
|
|
|
|
|
|
|
|
# 7.x
|
|
|
|
|
if [ ! -f "/etc/apt/trusted.gpg.d/proxmox-release-bullseye.gpg" ]; then
|
|
|
|
|
wget http://download.proxmox.com/debian/proxmox-release-bullseye.gpg -O /etc/apt/trusted.gpg.d/proxmox-release-bullseye.gpg
|
|
|
|
|
chmod +r /etc/apt/trusted.gpg.d/proxmox-release-bullseye.gpg
|
|
|
|
|
fi
|
|
|
|
|
|
2023-02-20 20:14:49 +08:00
|
|
|
|
if ! grep -q "^deb.*pve-no-subscription" /etc/apt/sources.list; then
|
|
|
|
|
echo "$repo_url" >> /etc/apt/sources.list
|
|
|
|
|
fi
|
2023-02-15 10:40:54 +08:00
|
|
|
|
|
|
|
|
|
# 下载pve
|
2023-02-15 11:02:52 +08:00
|
|
|
|
apt-get update -y && apt-get full-upgrade -y
|
2023-02-15 10:40:54 +08:00
|
|
|
|
if [ $? -ne 0 ]; then
|
|
|
|
|
apt-get install debian-keyring debian-archive-keyring -y
|
2023-02-15 11:02:52 +08:00
|
|
|
|
apt-get update -y && apt-get full-upgrade -y
|
2023-02-15 10:40:54 +08:00
|
|
|
|
fi
|
2023-02-20 19:37:57 +08:00
|
|
|
|
output=$(apt-get update 2>&1)
|
|
|
|
|
if echo $output | grep -q "NO_PUBKEY"; then
|
|
|
|
|
echo "Some keys are missing, attempting to retrieve them now..."
|
|
|
|
|
missing_keys=$(echo $output | grep "NO_PUBKEY" | awk -F' ' '{print $NF}')
|
|
|
|
|
for key in $missing_keys; do
|
|
|
|
|
sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys $key
|
|
|
|
|
done
|
|
|
|
|
apt-get update
|
|
|
|
|
else
|
|
|
|
|
echo "All keys are present."
|
|
|
|
|
fi
|
2023-02-20 20:14:49 +08:00
|
|
|
|
output=$(apt-get update 2>&1)
|
|
|
|
|
if echo $output | grep -q "NO_PUBKEY"; then
|
|
|
|
|
_yellow "try sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys missing key"
|
|
|
|
|
exit 1
|
|
|
|
|
fi
|
2023-02-24 19:27:14 +08:00
|
|
|
|
apt-get install -y proxmox-ve postfix open-iscsi
|
2023-02-15 10:40:54 +08:00
|
|
|
|
|
2023-04-04 12:21:17 +08:00
|
|
|
|
# 安装必备模块并替换apt源中的无效订阅
|
|
|
|
|
cp /etc/apt/sources.list.d/pve-enterprise.list /etc/apt/sources.list.d/pve-enterprise.list.bak
|
2023-04-04 12:56:37 +08:00
|
|
|
|
# echo "deb http://download.proxmox.com/debian/pve $(lsb_release -sc) pve-no-subscription" > /etc/apt/sources.list.d/pve-enterprise.list
|
|
|
|
|
rm -rf /etc/apt/sources.list.d/pve-enterprise.list
|
2023-04-04 12:21:17 +08:00
|
|
|
|
apt-get update
|
|
|
|
|
install_required_modules() {
|
2023-04-04 12:44:23 +08:00
|
|
|
|
modules=("sudo" "ifupdown2" "lshw" "iproute2" "net-tools" "cloud-init" "novnc") # "isc-dhcp-server"
|
2023-04-04 12:21:17 +08:00
|
|
|
|
for module in "${modules[@]}"
|
|
|
|
|
do
|
|
|
|
|
if dpkg -s $module > /dev/null 2>&1 ; then
|
|
|
|
|
_green "$module 已经安装!"
|
|
|
|
|
else
|
|
|
|
|
apt-get install -y $module
|
|
|
|
|
_green "$module 已成功安装!"
|
|
|
|
|
fi
|
|
|
|
|
done
|
|
|
|
|
}
|
|
|
|
|
install_required_modules
|
|
|
|
|
|
2023-04-04 18:07:11 +08:00
|
|
|
|
# 打印内核
|
2023-04-04 13:09:31 +08:00
|
|
|
|
running_kernel=$(uname -r)
|
|
|
|
|
_green "Running kernel: $(pveversion)"
|
|
|
|
|
installed_kernels=($(dpkg -l 'pve-kernel-*' | awk '/^ii/ {print $2}' | cut -d'-' -f3- | sort -V))
|
|
|
|
|
latest_kernel=${installed_kernels[-1]}
|
2023-04-04 13:29:16 +08:00
|
|
|
|
_green "PVE latest kernel: $latest_kernel"
|
2023-04-04 18:07:11 +08:00
|
|
|
|
# update-grub
|
|
|
|
|
apt-get install ipcalc -y
|
|
|
|
|
# 检查/etc/network/interfaces是否有source /etc/network/interfaces.d/*行
|
|
|
|
|
if grep -q "source /etc/network/interfaces.d/*" /etc/network/interfaces; then
|
|
|
|
|
# 检查/etc/network/interfaces.d/文件夹下是否有50-cloud-init文件
|
|
|
|
|
if [ -f /etc/network/interfaces.d/50-cloud-init ]; then
|
|
|
|
|
# 检查50-cloud-init文件中是否有iface eth0 inet dhcp行
|
|
|
|
|
if grep -q "iface eth0 inet dhcp" /etc/network/interfaces.d/50-cloud-init; then
|
|
|
|
|
# 获取ipv4、subnet、gateway信息
|
|
|
|
|
gateway=$(ip route | awk '/default/ {print $3}')
|
|
|
|
|
eth0info=$(ip -o -4 addr show dev eth0 | awk '{print $4}')
|
|
|
|
|
ipv4=$(echo $eth0info | cut -d'/' -f1)
|
|
|
|
|
subnet=$(echo $eth0info | cut -d'/' -f2)
|
|
|
|
|
subnet=$(ipcalc -n "$ipv4/$subnet" | grep -oP 'Netmask:\s+\K.*' | awk '{print $1}')
|
2023-04-04 19:16:25 +08:00
|
|
|
|
chattr -i /etc/network/interfaces.d/50-cloud-init
|
2023-04-04 18:07:11 +08:00
|
|
|
|
sed -i "/iface eth0 inet dhcp/c\
|
|
|
|
|
iface eth0 inet static\n\
|
|
|
|
|
address $ipv4\n\
|
|
|
|
|
netmask $subnet\n\
|
|
|
|
|
gateway $gateway\n\
|
|
|
|
|
dns-nameservers 8.8.8.8 8.8.4.4" /etc/network/interfaces.d/50-cloud-init
|
2023-04-04 18:52:00 +08:00
|
|
|
|
chattr +i /etc/network/interfaces.d/50-cloud-init
|
2023-04-04 18:07:11 +08:00
|
|
|
|
fi
|
|
|
|
|
fi
|
|
|
|
|
fi
|
2023-04-04 18:24:14 +08:00
|
|
|
|
systemctl restart networking
|
2023-04-04 19:12:24 +08:00
|
|
|
|
if [ ! -s "/etc/resolv.conf" ]
|
|
|
|
|
then
|
2023-04-04 19:16:25 +08:00
|
|
|
|
chattr -i /etc/resolv.conf
|
2023-04-04 19:12:24 +08:00
|
|
|
|
echo "nameserver 8.8.8.8" | sudo tee /etc/resolv.conf > /dev/null
|
2023-04-04 19:16:25 +08:00
|
|
|
|
chattr +i /etc/resolv.conf
|
2023-04-04 19:12:24 +08:00
|
|
|
|
fi
|
2023-04-04 21:14:34 +08:00
|
|
|
|
if [[ -n "${CN}" ]]; then
|
|
|
|
|
wget https://ghproxy.com/https://raw.githubusercontent.com/spiritLHLS/pve/main/check-dns.sh -O /usr/local/bin/check-dns.sh
|
|
|
|
|
wget https://ghproxy.com/https://raw.githubusercontent.com/spiritLHLS/pve/main/check-dns.service -O /etc/systemd/system/check-dns.service
|
|
|
|
|
else
|
|
|
|
|
wget https://raw.githubusercontent.com/spiritLHLS/pve/main/check-dns.sh -O /usr/local/bin/check-dns.sh
|
|
|
|
|
wget https://raw.githubusercontent.com/spiritLHLS/pve/main/check-dns.service -O /etc/systemd/system/check-dns.service
|
2023-04-04 19:24:17 +08:00
|
|
|
|
fi
|
2023-04-04 21:14:34 +08:00
|
|
|
|
chmod +x /usr/local/bin/check-dns.sh
|
|
|
|
|
chmod +x /etc/systemd/system/check-dns.service
|
2023-04-04 19:51:11 +08:00
|
|
|
|
systemctl daemon-reload
|
|
|
|
|
systemctl enable check-dns.service
|
|
|
|
|
systemctl start check-dns.service
|
2023-02-15 10:56:06 +08:00
|
|
|
|
# 打印安装后的信息
|
2023-02-15 10:40:54 +08:00
|
|
|
|
url="https://${ip}:8006/"
|
2023-02-15 11:12:21 +08:00
|
|
|
|
_green "安装完毕,请打开HTTPS网页 $url"
|
2023-02-26 10:46:31 +08:00
|
|
|
|
_green "用户名、密码就是服务器所使用的用户名、密码(如root和root用户的密码)"
|
2023-04-04 13:43:42 +08:00
|
|
|
|
_green "请重启机器以更新PVE的内核"
|
2023-02-15 10:40:54 +08:00
|
|
|
|
|
|
|
|
|
|