mirror of
https://github.com/vdsm/virtual-dsm.git
synced 2025-11-09 19:43:41 +08:00
Compare commits
2 Commits
v7.37
...
51cedfb50e
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
51cedfb50e | ||
|
|
6afb3f1acc |
16
.github/workflows/build.yml
vendored
16
.github/workflows/build.yml
vendored
@@ -2,6 +2,20 @@ name: Build
|
|||||||
|
|
||||||
on:
|
on:
|
||||||
workflow_dispatch:
|
workflow_dispatch:
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- master
|
||||||
|
paths-ignore:
|
||||||
|
- '**/*.md'
|
||||||
|
- '**/*.yml'
|
||||||
|
- '**/*.js'
|
||||||
|
- '**/*.css'
|
||||||
|
- '**/*.html'
|
||||||
|
- 'web/**'
|
||||||
|
- '.gitignore'
|
||||||
|
- '.dockerignore'
|
||||||
|
- '.github/**'
|
||||||
|
- '.github/workflows/**'
|
||||||
|
|
||||||
concurrency:
|
concurrency:
|
||||||
group: build
|
group: build
|
||||||
@@ -22,7 +36,7 @@ jobs:
|
|||||||
steps:
|
steps:
|
||||||
-
|
-
|
||||||
name: Checkout
|
name: Checkout
|
||||||
uses: actions/checkout@v5
|
uses: actions/checkout@v4
|
||||||
with:
|
with:
|
||||||
fetch-depth: 0
|
fetch-depth: 0
|
||||||
-
|
-
|
||||||
|
|||||||
4
.github/workflows/check.yml
vendored
4
.github/workflows/check.yml
vendored
@@ -9,7 +9,7 @@ jobs:
|
|||||||
steps:
|
steps:
|
||||||
-
|
-
|
||||||
name: Checkout
|
name: Checkout
|
||||||
uses: actions/checkout@v5
|
uses: actions/checkout@v4
|
||||||
-
|
-
|
||||||
name: Run ShellCheck
|
name: Run ShellCheck
|
||||||
uses: ludeeus/action-shellcheck@master
|
uses: ludeeus/action-shellcheck@master
|
||||||
@@ -17,7 +17,7 @@ jobs:
|
|||||||
SHELLCHECK_OPTS: -x --source-path=src -e SC2001 -e SC2034 -e SC2064 -e SC2317 -e SC2153 -e SC2028
|
SHELLCHECK_OPTS: -x --source-path=src -e SC2001 -e SC2034 -e SC2064 -e SC2317 -e SC2153 -e SC2028
|
||||||
-
|
-
|
||||||
name: Lint Dockerfile
|
name: Lint Dockerfile
|
||||||
uses: hadolint/hadolint-action@v3.2.0
|
uses: hadolint/hadolint-action@v3.1.0
|
||||||
with:
|
with:
|
||||||
dockerfile: Dockerfile
|
dockerfile: Dockerfile
|
||||||
ignore: DL3008,DL3003,DL3006,DL3013
|
ignore: DL3008,DL3003,DL3006,DL3013
|
||||||
|
|||||||
2
.github/workflows/hub.yml
vendored
2
.github/workflows/hub.yml
vendored
@@ -12,7 +12,7 @@ jobs:
|
|||||||
dockerHubDescription:
|
dockerHubDescription:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v5
|
- uses: actions/checkout@v4
|
||||||
-
|
-
|
||||||
name: Docker Hub Description
|
name: Docker Hub Description
|
||||||
uses: peter-evans/dockerhub-description@v4
|
uses: peter-evans/dockerhub-description@v4
|
||||||
|
|||||||
@@ -1,5 +1,3 @@
|
|||||||
# syntax=docker/dockerfile:1
|
|
||||||
|
|
||||||
FROM qemux/qemu-host:2.05 AS builder
|
FROM qemux/qemu-host:2.05 AS builder
|
||||||
|
|
||||||
# FROM golang as builder
|
# FROM golang as builder
|
||||||
|
|||||||
122
scripts/virtual-dsm-lxc-gpu.sh
Normal file
122
scripts/virtual-dsm-lxc-gpu.sh
Normal file
@@ -0,0 +1,122 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Constants
|
||||||
|
CONFIG_DIR="/etc/pve/lxc"
|
||||||
|
TMP_DIR="/tmp"
|
||||||
|
|
||||||
|
# Function to display log messages
|
||||||
|
log() {
|
||||||
|
echo -e "$1"
|
||||||
|
}
|
||||||
|
|
||||||
|
# Function to display error and exit
|
||||||
|
function display_error_and_exit() {
|
||||||
|
log "Error: $1 Exiting."
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
# Function to display information
|
||||||
|
function display_info {
|
||||||
|
clear
|
||||||
|
log "This script is used to configure prerequisites to run Synology Virtual DSM"
|
||||||
|
log "in a Docker container inside an unprivileged Proxmox LXC container."
|
||||||
|
log "Please run this script on the Proxmox host, not inside the LXC container.\n"
|
||||||
|
}
|
||||||
|
|
||||||
|
# Check for root privileges
|
||||||
|
if [ "$EUID" -ne 0 ]; then
|
||||||
|
display_error_and_exit "Please run this script as root."
|
||||||
|
fi
|
||||||
|
|
||||||
|
display_info
|
||||||
|
|
||||||
|
read -p "Do you want to continue? (y/n): " choice
|
||||||
|
|
||||||
|
if [[ $choice == "y" || $choice == "Y" ]]; then
|
||||||
|
read -p "Enter the LXC Container ID (CT ID): " ct_id
|
||||||
|
read -p "Enter the vGPU card ID (e.g. card1 = 1): " gpu_card
|
||||||
|
read -p "Enter the vGPU renderD ID (e.g. renderD129 = 129): " gpu_renderd
|
||||||
|
|
||||||
|
# Check if ct_id is a non-empty numeric value
|
||||||
|
if [[ ! $ct_id =~ ^[0-9]+$ ]]; then
|
||||||
|
display_error_and_exit "Invalid LXC Container ID. Please enter a numeric value."
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Check if gpu_card is a non-empty numeric value
|
||||||
|
if [[ ! $gpu_card =~ ^[0-9]+$ ]]; then
|
||||||
|
display_error_and_exit "Invalid vGPU card number. Please enter a numeric value."
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Check if gpu_renderd is a non-empty numeric value
|
||||||
|
if [[ ! $gpu_renderd =~ ^[0-9]+$ ]]; then
|
||||||
|
display_error_and_exit "Invalid vGPU renderD number. Please enter a numeric value."
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Check if the configuration file exists
|
||||||
|
config_file="$CONFIG_DIR/$ct_id.conf"
|
||||||
|
if [[ ! -f "$config_file" ]]; then
|
||||||
|
display_error_and_exit "Configuration file $config_file does not exist."
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Check if the LXC container is running
|
||||||
|
container_status=$(pct status $ct_id 2>&1)
|
||||||
|
if [[ "$container_status" == *"running"* ]]; then
|
||||||
|
log "Stopping running LXC container $ct_id..."
|
||||||
|
pct stop $ct_id || display_error_and_exit "Failed to stop LXC container $ct_id."
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Remove existing dev folder and tun, kvm, and vhost-net devices
|
||||||
|
if [[ -d "/dev-$ct_id" ]]; then
|
||||||
|
log "Removing existing /dev-$ct_id folder..."
|
||||||
|
rm -r "/dev-$ct_id" || display_error_and_exit "Failed to remove existing /dev-$ct_id folder."
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Function to configure devices
|
||||||
|
function configure_device() {
|
||||||
|
device=$1
|
||||||
|
module=$2
|
||||||
|
major=$3
|
||||||
|
minor=$4
|
||||||
|
|
||||||
|
log "Configuring $device..."
|
||||||
|
mkdir -p "/dev-$ct_id/net" || display_error_and_exit "Failed to create /dev-$ct_id/net"
|
||||||
|
mkdir -p "/dev-$ct_id/dri" || display_error_and_exit "Failed to create /dev-$ct_id/dri"
|
||||||
|
mknod "/dev-$ct_id/$device" c $major $minor || display_error_and_exit "Failed to mknod /dev-$ct_id/$device"
|
||||||
|
chown 100000:100000 "/dev-$ct_id/$device" || display_error_and_exit "Failed to chown /dev-$ct_id/$device"
|
||||||
|
|
||||||
|
#log "Checking if /dev-$ct_id/$device exists..."
|
||||||
|
if ! [[ -e "/dev-$ct_id/$device" ]]; then
|
||||||
|
display_error_and_exit "/dev-$ct_id/$device should have been created but does not exist."
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# Configure devices
|
||||||
|
configure_device "net/tun" "tun" 10 200
|
||||||
|
configure_device "kvm" "kvm" 10 232
|
||||||
|
configure_device "vhost-net" "vhost-net" 10 238
|
||||||
|
configure_device "dri/card0" "card0" 226 $gpu_card
|
||||||
|
configure_device "dri/renderD128" "renderD128" 226 $gpu_renderd
|
||||||
|
|
||||||
|
# Check and add configuration lines to /et/pve/lxc/<CT ID>.conf
|
||||||
|
log "Checking and adding configuration to $config_file..."
|
||||||
|
lines_to_add=(
|
||||||
|
"lxc.mount.entry: /dev-$ct_id/net/tun dev/net/tun none bind,create=file 0 0"
|
||||||
|
"lxc.mount.entry: /dev-$ct_id/kvm dev/kvm none bind,create=file 0 0"
|
||||||
|
"lxc.mount.entry: /dev-$ct_id/vhost-net dev/vhost-net none bind,create=file 0 0"
|
||||||
|
"lxc.mount.entry: /dev-$ct_id/dri/card0 dev/dri/card0 none bind,create=file 0 0"
|
||||||
|
"lxc.mount.entry: /dev-$ct_id/dri/renderD128 dev/dri/renderD128 none bind,create=file 0 0"
|
||||||
|
)
|
||||||
|
|
||||||
|
# Error handling for config file changes
|
||||||
|
for line in "${lines_to_add[@]}"; do
|
||||||
|
if ! grep -qF "$line" "$config_file"; then
|
||||||
|
echo "$line" >> "$config_file" || display_error_and_exit "Failed to add line '$line' to $config_file."
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
log "Configuration completed successfully.\n\nStart the docker image (vdsm/virtual-dsm:latest) inside the LXC container."
|
||||||
|
|
||||||
|
else
|
||||||
|
clear
|
||||||
|
log "\nScript aborted. No changes were made."
|
||||||
|
fi
|
||||||
105
scripts/virtual-dsm-lxc.sh
Normal file
105
scripts/virtual-dsm-lxc.sh
Normal file
@@ -0,0 +1,105 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Constants
|
||||||
|
CONFIG_DIR="/etc/pve/lxc"
|
||||||
|
TMP_DIR="/tmp"
|
||||||
|
|
||||||
|
# Function to display log messages
|
||||||
|
log() {
|
||||||
|
echo -e "$1"
|
||||||
|
}
|
||||||
|
|
||||||
|
# Function to display error and exit
|
||||||
|
function display_error_and_exit() {
|
||||||
|
log "Error: $1 Exiting."
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
# Function to display information
|
||||||
|
function display_info {
|
||||||
|
clear
|
||||||
|
log "This script is used to configure prerequisites to run Synology Virtual DSM"
|
||||||
|
log "in a Docker container inside an unprivileged Proxmox LXC container."
|
||||||
|
log "Please run this script on the Proxmox host, not inside the LXC container.\n"
|
||||||
|
}
|
||||||
|
|
||||||
|
# Check for root privileges
|
||||||
|
if [ "$EUID" -ne 0 ]; then
|
||||||
|
display_error_and_exit "Please run this script as root."
|
||||||
|
fi
|
||||||
|
|
||||||
|
display_info
|
||||||
|
|
||||||
|
read -p "Do you want to continue? (y/n): " choice
|
||||||
|
|
||||||
|
if [[ $choice == "y" || $choice == "Y" ]]; then
|
||||||
|
read -p "Enter the LXC Container ID (CT ID): " ct_id
|
||||||
|
|
||||||
|
# Check if ct_id is a non-empty numeric value
|
||||||
|
if [[ ! $ct_id =~ ^[0-9]+$ ]]; then
|
||||||
|
display_error_and_exit "Invalid LXC Container ID. Please enter a numeric value."
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Check if the configuration file exists
|
||||||
|
config_file="$CONFIG_DIR/$ct_id.conf"
|
||||||
|
if [[ ! -f "$config_file" ]]; then
|
||||||
|
display_error_and_exit "Configuration file $config_file does not exist."
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Check if the LXC container is running
|
||||||
|
container_status=$(pct status $ct_id 2>&1)
|
||||||
|
if [[ "$container_status" == *"running"* ]]; then
|
||||||
|
log "Stopping running LXC container $ct_id..."
|
||||||
|
pct stop $ct_id || display_error_and_exit "Failed to stop LXC container $ct_id."
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Remove existing dev folder and tun, kvm, and vhost-net devices
|
||||||
|
if [[ -d "/dev-$ct_id" ]]; then
|
||||||
|
log "Removing existing /dev-$ct_id folder..."
|
||||||
|
rm -r "/dev-$ct_id" || display_error_and_exit "Failed to remove existing /dev-$ct_id folder."
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Function to configure devices
|
||||||
|
function configure_device() {
|
||||||
|
device=$1
|
||||||
|
module=$2
|
||||||
|
major=$3
|
||||||
|
minor=$4
|
||||||
|
|
||||||
|
log "Configuring $device..."
|
||||||
|
mkdir -p "/dev-$ct_id/net" || display_error_and_exit "Failed to create /dev-$ct_id/net"
|
||||||
|
mknod "/dev-$ct_id/$device" c $major $minor || display_error_and_exit "Failed to mknod /dev-$ct_id/$device"
|
||||||
|
chown 100000:100000 "/dev-$ct_id/$device" || display_error_and_exit "Failed to chown /dev-$ct_id/$device"
|
||||||
|
|
||||||
|
#log "Checking if /dev-$ct_id/$device exists..."
|
||||||
|
if ! [[ -e "/dev-$ct_id/$device" ]]; then
|
||||||
|
display_error_and_exit "/dev-$ct_id/$device should have been created but does not exist."
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# Configure devices
|
||||||
|
configure_device "net/tun" "tun" 10 200
|
||||||
|
configure_device "kvm" "kvm" 10 232
|
||||||
|
configure_device "vhost-net" "vhost-net" 10 238
|
||||||
|
|
||||||
|
# Check and add configuration lines to /et/pve/lxc/<CT ID>.conf
|
||||||
|
log "Checking and adding configuration to $config_file..."
|
||||||
|
lines_to_add=(
|
||||||
|
"lxc.mount.entry: /dev-$ct_id/net/tun dev/net/tun none bind,create=file 0 0"
|
||||||
|
"lxc.mount.entry: /dev-$ct_id/kvm dev/kvm none bind,create=file 0 0"
|
||||||
|
"lxc.mount.entry: /dev-$ct_id/vhost-net dev/vhost-net none bind,create=file 0 0"
|
||||||
|
)
|
||||||
|
|
||||||
|
# Error handling for config file changes
|
||||||
|
for line in "${lines_to_add[@]}"; do
|
||||||
|
if ! grep -qF "$line" "$config_file"; then
|
||||||
|
echo "$line" >> "$config_file" || display_error_and_exit "Failed to add line '$line' to $config_file."
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
log "Configuration completed successfully.\n\nStart the docker image (vdsm/virtual-dsm:latest) inside the LXC container."
|
||||||
|
|
||||||
|
else
|
||||||
|
clear
|
||||||
|
log "\nScript aborted. No changes were made."
|
||||||
|
fi
|
||||||
@@ -320,7 +320,7 @@ convertDisk() {
|
|||||||
|
|
||||||
msg="Conversion of $DISK_DESC"
|
msg="Conversion of $DISK_DESC"
|
||||||
html "$msg completed..."
|
html "$msg completed..."
|
||||||
info "$msg to $DST_FMT completed successfully!"
|
info "$msg to $DST_FMT completed succesfully!"
|
||||||
|
|
||||||
return 0
|
return 0
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -209,9 +209,8 @@ configureNAT() {
|
|||||||
|
|
||||||
# Check port forwarding flag
|
# Check port forwarding flag
|
||||||
if [[ $(< /proc/sys/net/ipv4/ip_forward) -eq 0 ]]; then
|
if [[ $(< /proc/sys/net/ipv4/ip_forward) -eq 0 ]]; then
|
||||||
{ sysctl -w net.ipv4.ip_forward=1 > /dev/null 2>&1; rc=$?; } || :
|
{ sysctl -w net.ipv4.ip_forward=1 > /dev/null; rc=$?; } || :
|
||||||
if (( rc != 0 )) || [[ $(< /proc/sys/net/ipv4/ip_forward) -eq 0 ]]; then
|
if (( rc != 0 )) || [[ $(< /proc/sys/net/ipv4/ip_forward) -eq 0 ]]; then
|
||||||
[[ "$PODMAN" == [Yy1]* ]] && return 1
|
|
||||||
error "IP forwarding is disabled. $ADD_ERR --sysctl net.ipv4.ip_forward=1"
|
error "IP forwarding is disabled. $ADD_ERR --sysctl net.ipv4.ip_forward=1"
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -4,12 +4,12 @@ set -Eeuo pipefail
|
|||||||
# Configure QEMU for graceful shutdown
|
# Configure QEMU for graceful shutdown
|
||||||
|
|
||||||
API_CMD=6
|
API_CMD=6
|
||||||
|
API_TIMEOUT=50
|
||||||
API_HOST="127.0.0.1:2210"
|
API_HOST="127.0.0.1:2210"
|
||||||
: "${API_TIMEOUT:="50"}" # API Call timeout
|
|
||||||
|
|
||||||
QEMU_TERM=""
|
QEMU_TERM=""
|
||||||
QEMU_PORT=7100
|
QEMU_PORT=7100
|
||||||
: "${QEMU_TIMEOUT:="50"}" # QEMU Termination timeout
|
QEMU_TIMEOUT=50
|
||||||
QEMU_DIR="/run/shm"
|
QEMU_DIR="/run/shm"
|
||||||
QEMU_PID="$QEMU_DIR/qemu.pid"
|
QEMU_PID="$QEMU_DIR/qemu.pid"
|
||||||
QEMU_LOG="$QEMU_DIR/qemu.log"
|
QEMU_LOG="$QEMU_DIR/qemu.log"
|
||||||
|
|||||||
24
src/proc.sh
24
src/proc.sh
@@ -128,30 +128,6 @@ else
|
|||||||
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ "$ARGUMENTS" == *"-cpu host,"* ]]; then
|
|
||||||
|
|
||||||
args="${ARGUMENTS} "
|
|
||||||
prefix="${args/-cpu host,*/}"
|
|
||||||
suffix="${args/*-cpu host,/}"
|
|
||||||
param="${suffix%% *}"
|
|
||||||
suffix="${suffix#* }"
|
|
||||||
args="${prefix}${suffix}"
|
|
||||||
ARGUMENTS="${args::-1}"
|
|
||||||
|
|
||||||
if [ -z "$CPU_FLAGS" ]; then
|
|
||||||
CPU_FLAGS="$param"
|
|
||||||
else
|
|
||||||
CPU_FLAGS+=",$param"
|
|
||||||
fi
|
|
||||||
|
|
||||||
else
|
|
||||||
|
|
||||||
if [[ "$ARGUMENTS" == *"-cpu host"* ]]; then
|
|
||||||
ARGUMENTS="${ARGUMENTS//-cpu host/}"
|
|
||||||
fi
|
|
||||||
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -z "$CPU_FLAGS" ]; then
|
if [ -z "$CPU_FLAGS" ]; then
|
||||||
if [ -z "$CPU_FEATURES" ]; then
|
if [ -z "$CPU_FEATURES" ]; then
|
||||||
CPU_FLAGS="$CPU_MODEL"
|
CPU_FLAGS="$CPU_MODEL"
|
||||||
|
|||||||
@@ -69,10 +69,6 @@ if [ ! -d "$STORAGE" ]; then
|
|||||||
error "Storage folder ($STORAGE) not found!" && exit 13
|
error "Storage folder ($STORAGE) not found!" && exit 13
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ ! -w "$STORAGE" ]; then
|
|
||||||
error "Storage folder ($STORAGE) is not writeable!" && exit 13
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Check filesystem
|
# Check filesystem
|
||||||
FS=$(stat -f -c %T "$STORAGE")
|
FS=$(stat -f -c %T "$STORAGE")
|
||||||
|
|
||||||
@@ -160,7 +156,6 @@ setCountry() {
|
|||||||
[ -z "$COUNTRY" ] && getCountry "https://ifconfig.co/json" ".country_iso"
|
[ -z "$COUNTRY" ] && getCountry "https://ifconfig.co/json" ".country_iso"
|
||||||
[ -z "$COUNTRY" ] && getCountry "https://api.ip2location.io" ".country_code"
|
[ -z "$COUNTRY" ] && getCountry "https://api.ip2location.io" ".country_code"
|
||||||
[ -z "$COUNTRY" ] && getCountry "https://ipinfo.io/json" ".country"
|
[ -z "$COUNTRY" ] && getCountry "https://ipinfo.io/json" ".country"
|
||||||
[ -z "$COUNTRY" ] && getCountry "https://api.ipquery.io/?format=json" ".location.country_code"
|
|
||||||
[ -z "$COUNTRY" ] && getCountry "https://api.myip.com" ".cc"
|
[ -z "$COUNTRY" ] && getCountry "https://api.myip.com" ".cc"
|
||||||
|
|
||||||
return 0
|
return 0
|
||||||
|
|||||||
@@ -130,10 +130,7 @@ cpu() {
|
|||||||
cpu="${cpu// 12 Core/}"
|
cpu="${cpu// 12 Core/}"
|
||||||
cpu="${cpu// 16 Core/}"
|
cpu="${cpu// 16 Core/}"
|
||||||
cpu="${cpu// 32 Core/}"
|
cpu="${cpu// 32 Core/}"
|
||||||
cpu="${cpu// 48 Core/}"
|
|
||||||
cpu="${cpu// 64 Core/}"
|
cpu="${cpu// 64 Core/}"
|
||||||
cpu="${cpu// 96 Core/}"
|
|
||||||
cpu="${cpu// 128 Core/}"
|
|
||||||
cpu="${cpu//7th Gen /}"
|
cpu="${cpu//7th Gen /}"
|
||||||
cpu="${cpu//8th Gen /}"
|
cpu="${cpu//8th Gen /}"
|
||||||
cpu="${cpu//9th Gen /}"
|
cpu="${cpu//9th Gen /}"
|
||||||
|
|||||||
Reference in New Issue
Block a user