create_pve-mgnt-lxc.sh aktualisiert

This commit is contained in:
2026-01-27 11:54:25 +01:00
parent a92c571672
commit 1e568183e4

View File

@@ -1,111 +1,81 @@
#!/bin/bash #!/bin/bash
# =====================================================
# Proxmox VE: Debian 13 LXC automatisch erstellen
# Hostname: <Host>-MGNT
# Unprivilegiert
# Automatisches Debian 13 Template
# WebUI-Konsole funktioniert
# Autostart aktiviert
# =====================================================
# ---- Konfiguration ---- ### === Konfiguration ===
IP="10.60.10.2/24" CTID=301
HOSTNAME="debian-lxc"
TEMPLATE_STORAGE="local"
TEMPLATE_NAME="debian-13-standard_13.1-2_amd64.tar.zst"
ROOTFS_STORAGE="local-lvm"
ROOTFS_SIZE="4G"
BRIDGE="xx_vmbrmgt"
IP_ADDR="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
STORAGE="local-lvm"
ROOTFS_SIZE=8
BRIDGE="xx_vmbrmgt"
MIN_VMID=300
# ---- Farben / Layout ---- ### === Checks ===
BOLD="\033[1m" if ! command -v pct &>/dev/null; then
GREEN="\033[32m" echo "❌ pct nicht gefunden läuft das Script auf einem Proxmox Host?"
CYAN="\033[36m"
RESET="\033[0m"
INDENT=" "
# ---- Root Check ----
if [[ $EUID -ne 0 ]]; then
echo -e "${BOLD}${INDENT}Bitte als Root ausführen!${RESET}"
exit 1 exit 1
fi fi
# ---- Root-Passwort abfragen ---- ### === Template prüfen ===
read -s -p "Root-Passwort für LXC: " ROOTPASS if [ ! -f "/var/lib/vz/template/cache/${TEMPLATE_NAME}" ]; then
echo echo "❌ Template ${TEMPLATE_NAME} nicht gefunden!"
echo "👉 Bitte vorher herunterladen:"
# ---- Dynamischer Hostname ---- echo " pveam download ${TEMPLATE_STORAGE} ${TEMPLATE_NAME}"
HOSTNAME="$(hostname)-MGNT"
echo -e "${INDENT}LXC-Hostname wird: $HOSTNAME"
# ---- Nächste freie VMID ab 300 ----
VMID=$MIN_VMID
while pct status $VMID &>/dev/null; do
((VMID++))
done
echo -e "${INDENT}Nächste freie VMID: $VMID"
# ---- Template automatisch wählen ----
echo -e "${INDENT}Suche aktuelles Debian 13 Template..."
pveam update
TEMPLATE_NAME=$(pveam available | awk '/debian-13-standard_.*_amd64\.tar\.zst/ {print $2}' | tail -n1)
if [[ -z "$TEMPLATE_NAME" ]]; then
echo -e "${BOLD}${INDENT}Kein Debian 13 Template gefunden!${RESET}"
exit 1 exit 1
fi fi
echo -e "${INDENT}Gefundenes Template: $TEMPLATE_NAME"
# ---- Template prüfen / herunterladen ---- ### === LXC erstellen ===
TEMPLATE_PATH="/var/lib/vz/template/cache/$TEMPLATE_NAME" echo "🚀 Erstelle unprivilegierten LXC ${CTID}..."
if [[ ! -f "$TEMPLATE_PATH" ]]; then
echo -e "${INDENT}Template nicht vorhanden, lade herunter..." pct create ${CTID} \
pveam download local $TEMPLATE_NAME ${TEMPLATE_STORAGE}:vztmpl/${TEMPLATE_NAME} \
else --hostname ${HOSTNAME} \
echo -e "${INDENT}Template bereits vorhanden" --cores ${CORES} \
--memory ${MEMORY} \
--swap ${SWAP} \
--rootfs ${ROOTFS_STORAGE}:${ROOTFS_SIZE} \
--net0 name=eth0,bridge=${BRIDGE},ip=${IP_ADDR},gw=${GATEWAY} \
--unprivileged 1 \
--features nesting=1 \
--onboot 1 \
--tty 2 \
--pty 1 \
--ostype debian \
--start 0
if [ $? -ne 0 ]; then
echo "❌ Fehler beim Erstellen des LXCs"
exit 1
fi fi
# ---- LXC erstellen ---- ### === LXC starten ===
echo -e "${INDENT}Erstelle unprivilegierten LXC $HOSTNAME (VMID: $VMID)..." echo "▶️ Starte LXC..."
pct start ${CTID}
CREATE_CMD="pct create $VMID local:vztmpl/$TEMPLATE_NAME \ ### === Warten bis Container läuft ===
--hostname $HOSTNAME \ echo "⏳ Warte auf LXC..."
--cores $CORES \ sleep 5
--memory $MEMORY \
--swap $SWAP \
--rootfs $STORAGE:$ROOTFS_SIZE \
--net0 name=eth0,bridge=$BRIDGE,ip=$IP,gw=$GATEWAY,type=veth \
--unprivileged 1"
# Passwort hinzufügen, falls gesetzt ### === Pakete im LXC installieren ===
if [[ -n "$ROOTPASS" ]]; then echo "📦 Installiere Pakete im LXC..."
CREATE_CMD="$CREATE_CMD --password $ROOTPASS" pct exec ${CTID} -- bash -c "
fi apt update &&
apt upgrade -y &&
apt install -y curl sudo
"
# Ausführen ### === Newt Installer ausführen ===
eval $CREATE_CMD echo "🧩 Installiere NEWT Client..."
pct exec ${CTID} -- bash -c "
curl -fsSL https://gitea.vmd55888.de/manuel.maier/update-install-newt/raw/branch/main/install_newt_v2.sh -o install_newt_v2.sh &&
chmod +x install_newt_v2.sh &&
bash ./install_newt_v2.sh --install
"
# ---- WebUI-Konsole aktivieren (modern) ---- echo "✅ Fertig! LXC ${CTID} läuft, Autostart aktiv, Console funktioniert 🎉"
CONF_FILE="/etc/pve/lxc/$VMID.conf"
echo -e "${INDENT}Aktiviere WebUI-Konsole..."
echo "lxc.tty.max = 2" >> "$CONF_FILE"
echo "lxc.pty.max = 2" >> "$CONF_FILE"
echo "features: nesting=1,keyctl=1" >> "$CONF_FILE"
# ---- Autostart aktivieren ----
echo -e "${INDENT}Aktiviere Autostart..."
pct set $VMID --onboot 1
# ---- Container starten ----
echo -e "${INDENT}Starte LXC..."
pct start $VMID
echo -e "${INDENT}Installiere Newt-PVE-Mgnt"
pct exec $VMID -- bash -c "\
apt update && 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 && \
bash ./install_newt_v2.sh --install"
echo -e "${GREEN}${INDENT}✔ Unprivilegierter LXC $HOSTNAME (VMID $VMID) erstellt, gestartet und Autostart aktiviert!${RESET}"