create_pve-mgnt-lxc_v2.sh aktualisiert
This commit is contained in:
@@ -6,10 +6,10 @@
|
|||||||
# Automatisches Debian 13 Template
|
# Automatisches Debian 13 Template
|
||||||
# WebUI-Konsole funktioniert
|
# WebUI-Konsole funktioniert
|
||||||
# Autostart aktiviert
|
# Autostart aktiviert
|
||||||
# Dialog-basiert
|
# Dialog-basierte GUI + Statusfenster
|
||||||
# =====================================================
|
# =====================================================
|
||||||
|
|
||||||
# ---- Farben für Terminal-Ausgabe ----
|
# ---- Farben / Layout ----
|
||||||
BOLD="\033[1m"
|
BOLD="\033[1m"
|
||||||
GREEN="\033[32m"
|
GREEN="\033[32m"
|
||||||
CYAN="\033[36m"
|
CYAN="\033[36m"
|
||||||
@@ -19,82 +19,84 @@ INDENT=" "
|
|||||||
|
|
||||||
# ---- Root Check ----
|
# ---- Root Check ----
|
||||||
if [[ $EUID -ne 0 ]]; then
|
if [[ $EUID -ne 0 ]]; then
|
||||||
echo -e "${RED}${INDENT}Bitte als Root ausführen!${RESET}"
|
dialog --msgbox "Bitte als Root ausführen!" 8 40
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# ---- Dynamischer Hostname ----
|
# ---- Root Passwort ----
|
||||||
|
ROOTPASS=$(dialog --title "Root Passwort" --passwordbox "Root-Passwort für den LXC:" 8 40 3>&1 1>&2 2>&3 3>&-)
|
||||||
|
clear
|
||||||
|
|
||||||
|
# ---- Hostname & VMID ----
|
||||||
HOSTNAME="$(hostname)-MGNT"
|
HOSTNAME="$(hostname)-MGNT"
|
||||||
|
VMID=300
|
||||||
|
while pct status $VMID &>/dev/null; do ((VMID++)); done
|
||||||
|
|
||||||
# ---- Nächste freie VMID ab 300 ----
|
dialog --msgbox "Hostname: $HOSTNAME\nNächste freie VMID: $VMID" 10 50
|
||||||
MIN_VMID=300
|
|
||||||
VMID=$MIN_VMID
|
|
||||||
while pct status $VMID &>/dev/null; do
|
|
||||||
((VMID++))
|
|
||||||
done
|
|
||||||
|
|
||||||
# ---- Storage auswählen ----
|
# ---- Storage Auswahl ----
|
||||||
mapfile -t STORAGES < <(pvesm status --content rootdir | awk 'NR>1 {print $1}')
|
mapfile -t STORAGES < <(pvesm status --content rootdir | awk 'NR>1 {print $1}')
|
||||||
|
STORAGE_CHOICES=()
|
||||||
if [[ ${#STORAGES[@]} -eq 0 ]]; then
|
|
||||||
echo -e "${RED}${INDENT}Kein geeigneter Storage gefunden!${RESET}"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
STORAGE_OPTIONS=()
|
|
||||||
for i in "${!STORAGES[@]}"; do
|
for i in "${!STORAGES[@]}"; do
|
||||||
STORAGE_OPTIONS+=("$i" "${STORAGES[$i]}")
|
STORAGE_CHOICES+=("$i" "${STORAGES[$i]}" "off")
|
||||||
done
|
done
|
||||||
|
|
||||||
STORAGE_INDEX=$(dialog --clear --stdout \
|
STORAGE_INDEX=$(dialog --title "Storage Auswahl" --radiolist \
|
||||||
--title "LXC RootFS Storage wählen" \
|
"Welcher Storage für RootFS?" 15 50 5 \
|
||||||
--menu "Wähle den Storage für den LXC RootFS" 15 50 5 \
|
"${STORAGE_CHOICES[@]}" 3>&1 1>&2 2>&3 3>&-)
|
||||||
"${STORAGE_OPTIONS[@]}")
|
|
||||||
|
|
||||||
if [ $? -ne 0 ]; then
|
|
||||||
echo -e "${RED}${INDENT}Abgebrochen${RESET}"
|
|
||||||
clear
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
STORAGE="${STORAGES[$STORAGE_INDEX]}"
|
STORAGE="${STORAGES[$STORAGE_INDEX]}"
|
||||||
|
|
||||||
# ---- Root-Passwort abfragen ----
|
|
||||||
ROOTPASS=$(dialog --clear --stdout --title "Root-Passwort für LXC" \
|
|
||||||
--insecure --passwordbox "Gib ein Root-Passwort für den LXC ein:" 10 50)
|
|
||||||
if [ $? -ne 0 ]; then
|
|
||||||
echo -e "${RED}${INDENT}Abgebrochen${RESET}"
|
|
||||||
clear
|
clear
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# ---- LXC Settings ----
|
# ---- VMBR Auswahl ----
|
||||||
|
mapfile -t BRIDGES < <(grep -Po '^auto \K.*' /etc/network/interfaces)
|
||||||
|
BRIDGE_CHOICES=()
|
||||||
|
for i in "${!BRIDGES[@]}"; do
|
||||||
|
BRIDGE_CHOICES+=("$i" "${BRIDGES[$i]}" "off")
|
||||||
|
done
|
||||||
|
|
||||||
|
BRIDGE_INDEX=$(dialog --title "Bridge Auswahl" --radiolist \
|
||||||
|
"Welche Bridge soll der LXC nutzen?" 15 50 5 \
|
||||||
|
"${BRIDGE_CHOICES[@]}" 3>&1 1>&2 2>&3 3>&-)
|
||||||
|
BRIDGE="${BRIDGES[$BRIDGE_INDEX]}"
|
||||||
|
clear
|
||||||
|
|
||||||
|
# ---- IP / Netzwerk ----
|
||||||
IP="10.60.10.2/24"
|
IP="10.60.10.2/24"
|
||||||
GATEWAY="10.60.10.1"
|
GATEWAY="10.60.10.1"
|
||||||
CORES=1
|
CORES=1
|
||||||
MEMORY=512
|
MEMORY=512
|
||||||
SWAP=0
|
SWAP=0
|
||||||
ROOTFS_SIZE=8
|
ROOTFS_SIZE=8
|
||||||
BRIDGE="xx_vmbrmgt"
|
|
||||||
|
|
||||||
# ---- Template automatisch wählen ----
|
# ---- Template automatisch wählen ----
|
||||||
pveam update >/dev/null
|
dialog --infobox "Suche aktuelles Debian 13 Template..." 5 50
|
||||||
|
pveam update
|
||||||
TEMPLATE_NAME=$(pveam available | awk '/debian-13-standard_.*_amd64\.tar\.zst/ {print $2}' | tail -n1)
|
TEMPLATE_NAME=$(pveam available | awk '/debian-13-standard_.*_amd64\.tar\.zst/ {print $2}' | tail -n1)
|
||||||
|
|
||||||
if [[ -z "$TEMPLATE_NAME" ]]; then
|
if [[ -z "$TEMPLATE_NAME" ]]; then
|
||||||
dialog --msgbox "Kein Debian 13 Template gefunden!" 10 50
|
dialog --msgbox "Kein Debian 13 Template gefunden!" 8 50
|
||||||
clear
|
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
# ---- Temp-Log für Status ----
|
||||||
|
LOGFILE=$(mktemp)
|
||||||
|
|
||||||
|
run_with_progress() {
|
||||||
|
local CMD="$1"
|
||||||
|
echo -e ">>> $CMD" >> "$LOGFILE"
|
||||||
|
bash -c "$CMD" >> "$LOGFILE" 2>&1 &
|
||||||
|
PID=$!
|
||||||
|
dialog --title "LXC Setup: $HOSTNAME" --progressbox "$LOGFILE" 20 80
|
||||||
|
wait $PID
|
||||||
|
}
|
||||||
|
|
||||||
# ---- Template prüfen / herunterladen ----
|
# ---- Template prüfen / herunterladen ----
|
||||||
TEMPLATE_PATH="/var/lib/vz/template/cache/$TEMPLATE_NAME"
|
TEMPLATE_PATH="/var/lib/vz/template/cache/$TEMPLATE_NAME"
|
||||||
if [[ ! -f "$TEMPLATE_PATH" ]]; then
|
if [[ ! -f "$TEMPLATE_PATH" ]]; then
|
||||||
dialog --infobox "Template $TEMPLATE_NAME wird heruntergeladen..." 5 50
|
run_with_progress "pveam download local $TEMPLATE_NAME"
|
||||||
pveam download local "$TEMPLATE_NAME"
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# ---- Container erstellen ----
|
# ---- LXC erstellen ----
|
||||||
dialog --infobox "Erstelle unprivilegierten LXC $HOSTNAME (VMID: $VMID)..." 5 50
|
|
||||||
|
|
||||||
CREATE_CMD="pct create $VMID local:vztmpl/$TEMPLATE_NAME \
|
CREATE_CMD="pct create $VMID local:vztmpl/$TEMPLATE_NAME \
|
||||||
--hostname $HOSTNAME \
|
--hostname $HOSTNAME \
|
||||||
--cores $CORES \
|
--cores $CORES \
|
||||||
@@ -102,36 +104,34 @@ CREATE_CMD="pct create $VMID local:vztmpl/$TEMPLATE_NAME \
|
|||||||
--swap $SWAP \
|
--swap $SWAP \
|
||||||
--rootfs $STORAGE:$ROOTFS_SIZE \
|
--rootfs $STORAGE:$ROOTFS_SIZE \
|
||||||
--net0 name=eth0,bridge=$BRIDGE,ip=$IP,gw=$GATEWAY,type=veth \
|
--net0 name=eth0,bridge=$BRIDGE,ip=$IP,gw=$GATEWAY,type=veth \
|
||||||
--unprivileged 1 \
|
--unprivileged 1"
|
||||||
--password $ROOTPASS"
|
|
||||||
|
|
||||||
eval $CREATE_CMD || {
|
if [[ -n "$ROOTPASS" ]]; then
|
||||||
dialog --msgbox "Fehler beim Erstellen des LXC!" 10 50
|
CREATE_CMD="$CREATE_CMD --password $ROOTPASS"
|
||||||
clear
|
fi
|
||||||
exit 1
|
|
||||||
}
|
|
||||||
|
|
||||||
# ---- WebUI-Konsole aktivieren ----
|
run_with_progress "$CREATE_CMD"
|
||||||
|
|
||||||
|
# ---- WebUI-Konsole aktivieren (modern) ----
|
||||||
CONF_FILE="/etc/pve/lxc/$VMID.conf"
|
CONF_FILE="/etc/pve/lxc/$VMID.conf"
|
||||||
echo "lxc.tty.max = 2" >> "$CONF_FILE"
|
echo "lxc.tty.max = 2" >> "$CONF_FILE"
|
||||||
echo "lxc.pty.max = 2" >> "$CONF_FILE"
|
echo "lxc.pty.max = 2" >> "$CONF_FILE"
|
||||||
echo "features: nesting=1,keyctl=1" >> "$CONF_FILE"
|
echo "features: nesting=1,keyctl=1" >> "$CONF_FILE"
|
||||||
|
|
||||||
# ---- Autostart aktivieren ----
|
# ---- Autostart aktivieren ----
|
||||||
pct set $VMID --onboot 1
|
run_with_progress "pct set $VMID --onboot 1"
|
||||||
|
|
||||||
# ---- Container starten ----
|
# ---- Container starten ----
|
||||||
dialog --infobox "Starte LXC..." 5 50
|
run_with_progress "pct start $VMID"
|
||||||
pct start $VMID
|
|
||||||
|
|
||||||
# ---- Newt installieren ----
|
# ---- Software im LXC installieren ----
|
||||||
dialog --infobox "Installiere Newt-PVE-Mgnt im LXC..." 5 50
|
run_with_progress "pct exec $VMID -- bash -c '
|
||||||
pct exec $VMID -- bash -c "
|
|
||||||
apt update &&
|
apt update &&
|
||||||
apt install -y curl sudo &&
|
apt install -y curl sudo &&
|
||||||
curl -fsSL https://gitea.vmd55888.de/manuel.maier/update-install-newt/raw/branch/main/install_newt_v2.sh -o install_newt_v2.sh &&
|
curl -fsSL https://gitea.vmd55888.de/manuel.maier/update-install-newt/raw/branch/main/install_newt_v2.sh -o install_newt_v2.sh &&
|
||||||
bash ./install_newt_v2.sh --install
|
bash ./install_newt_v2.sh --install
|
||||||
"
|
'"
|
||||||
|
|
||||||
dialog --msgbox "✔ Unprivilegierter LXC $HOSTNAME (VMID $VMID) erstellt, gestartet und Autostart aktiviert!" 10 50
|
dialog --msgbox "✔ Unprivilegierter LXC $HOSTNAME (VMID $VMID) erstellt, gestartet und Autostart aktiviert!" 8 60
|
||||||
clear
|
clear
|
||||||
|
rm -f "$LOGFILE"
|
||||||
Reference in New Issue
Block a user