mirror of
https://github.com/vdsm/virtual-dsm.git
synced 2025-02-24 13:30:02 +08:00
Installation
Installation
This commit is contained in:
commit
dea458f2a9
@ -38,15 +38,17 @@ rm -rf "$TMP" && mkdir -p "$TMP"
|
|||||||
|
|
||||||
if [ ! -f "${RDC}" ]; then
|
if [ ! -f "${RDC}" ]; then
|
||||||
|
|
||||||
RD="$TMP/rd.gz"
|
|
||||||
info "Install: Downloading installer..."
|
info "Install: Downloading installer..."
|
||||||
|
|
||||||
|
RD="$TMP/rd.gz"
|
||||||
|
POS="65627648-71021835"
|
||||||
|
VERIFY="b4215a4b213ff5154db0488f92c87864"
|
||||||
LOC="$DL/release/7.0.1/42218/DSM_VirtualDSM_42218.pat"
|
LOC="$DL/release/7.0.1/42218/DSM_VirtualDSM_42218.pat"
|
||||||
|
|
||||||
{ curl -r 65627648-71021835 -sfk -o "$RD" "$LOC"; rc=$?; } || :
|
{ curl -r "$POS" -sfk -o "$RD" "$LOC"; rc=$?; } || :
|
||||||
(( rc != 0 )) && error "Failed to download $LOC, reason: $rc" && exit 60
|
(( rc != 0 )) && error "Failed to download $LOC, reason: $rc" && exit 60
|
||||||
|
|
||||||
SUM=$(md5sum "$RD" | cut -f 1 -d " ")
|
SUM=$(md5sum "$RD" | cut -f 1 -d " ")
|
||||||
VERIFY="b4215a4b213ff5154db0488f92c87864"
|
|
||||||
|
|
||||||
if [ "$SUM" != "$VERIFY" ]; then
|
if [ "$SUM" != "$VERIFY" ]; then
|
||||||
|
|
||||||
@ -57,7 +59,7 @@ if [ ! -f "${RDC}" ]; then
|
|||||||
{ wget "$LOC" -O "$PAT" -q --no-check-certificate --show-progress "$PROGRESS"; rc=$?; } || :
|
{ wget "$LOC" -O "$PAT" -q --no-check-certificate --show-progress "$PROGRESS"; rc=$?; } || :
|
||||||
(( rc != 0 )) && error "Failed to download $LOC, reason: $rc" && exit 60
|
(( rc != 0 )) && error "Failed to download $LOC, reason: $rc" && exit 60
|
||||||
|
|
||||||
tar --extract --file="$PAT" --directory="$TMP/." rd.gz
|
tar --extract --file="$PAT" --directory="$(dirname "${RD}")"/. "$(basename "${RD}")"
|
||||||
rm "$PAT"
|
rm "$PAT"
|
||||||
|
|
||||||
fi
|
fi
|
||||||
@ -66,10 +68,11 @@ if [ ! -f "${RDC}" ]; then
|
|||||||
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
set +e
|
{ xz -dc <"$RDC" >"$TMP/rd" 2>/dev/null; rc=$?; } || :
|
||||||
xz -dc <"$RDC" >"$TMP/rd" 2>/dev/null || true
|
(( rc != 1 )) && error "Failed to unxz $RDC, reason $rc" && exit 91
|
||||||
(cd "$TMP" && cpio -idm <"$TMP/rd" 2>/dev/null)
|
|
||||||
set -e
|
{ (cd "$TMP" && cpio -idm <"$TMP/rd" 2>/dev/null); rc=$?; } || :
|
||||||
|
(( rc != 0 )) && error "Failed to cpio $RDC, reason $rc" && exit 92
|
||||||
|
|
||||||
mkdir -p /run/extract
|
mkdir -p /run/extract
|
||||||
for file in $TMP/usr/lib/libcurl.so.4 \
|
for file in $TMP/usr/lib/libcurl.so.4 \
|
||||||
@ -140,13 +143,10 @@ SYSTEM_SIZE=4954537983
|
|||||||
# Check free diskspace
|
# Check free diskspace
|
||||||
SPACE=$(df --output=avail -B 1 "$TMP" | tail -n 1)
|
SPACE=$(df --output=avail -B 1 "$TMP" | tail -n 1)
|
||||||
|
|
||||||
if (( SYSTEM_SIZE > SPACE )); then
|
(( SYSTEM_SIZE > SPACE )) && error "Not enough free space to create a 4 GB system disk." && exit 87
|
||||||
error "Not enough free space to create a 4 GB system disk." && exit 87
|
|
||||||
fi
|
|
||||||
|
|
||||||
if ! fallocate -l "${SYSTEM_SIZE}" "${SYSTEM}"; then
|
if ! fallocate -l "${SYSTEM_SIZE}" "${SYSTEM}"; then
|
||||||
rm -f "${SYSTEM}"
|
rm -f "${SYSTEM}" && error "Could not allocate a file for the system disk." && exit 88
|
||||||
error "Could not allocate a file for the system disk." && exit 88
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ "${ALLOCATE}" == [Zz]* ]]; then
|
if [[ "${ALLOCATE}" == [Zz]* ]]; then
|
||||||
@ -155,17 +155,11 @@ if [[ "${ALLOCATE}" == [Zz]* ]]; then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
# Check if file exists
|
# Check if file exists
|
||||||
if [ ! -f "${SYSTEM}" ]; then
|
[ ! -f "${SYSTEM}" ] && error "System disk does not exist ($SYSTEM)" && exit 89
|
||||||
error "System disk does not exist ($SYSTEM)" && exit 89
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Check the filesize
|
# Check the filesize
|
||||||
SIZE=$(stat -c%s "${SYSTEM}")
|
SIZE=$(stat -c%s "${SYSTEM}")
|
||||||
|
[[ SIZE -ne SYSTEM_SIZE ]] && rm -f "${SYSTEM}" && error "System disk has the wrong size: ${SIZE}" && exit 90
|
||||||
if [[ SIZE -ne SYSTEM_SIZE ]]; then
|
|
||||||
rm -f "${SYSTEM}"
|
|
||||||
error "System disk has the wrong size: ${SIZE}" && exit 90
|
|
||||||
fi
|
|
||||||
|
|
||||||
PART="$TMP/partition.fdisk"
|
PART="$TMP/partition.fdisk"
|
||||||
|
|
||||||
@ -186,7 +180,6 @@ info "Install: Extracting system partition..."
|
|||||||
MOUNT="$TMP/system"
|
MOUNT="$TMP/system"
|
||||||
|
|
||||||
rm -rf "$MOUNT" && mkdir -p "$MOUNT"
|
rm -rf "$MOUNT" && mkdir -p "$MOUNT"
|
||||||
|
|
||||||
mv -f "$HDA.tgz" "$HDA.txz"
|
mv -f "$HDA.tgz" "$HDA.txz"
|
||||||
|
|
||||||
tar xpfJ "$HDP.txz" --absolute-names -C "$MOUNT/"
|
tar xpfJ "$HDP.txz" --absolute-names -C "$MOUNT/"
|
||||||
|
@ -21,6 +21,7 @@ trap 'error "Status $? while: ${BASH_COMMAND} (line $LINENO/$BASH_LINENO)"' ERR
|
|||||||
|
|
||||||
STORAGE="/storage"
|
STORAGE="/storage"
|
||||||
KERNEL=$(uname -r | cut -b 1)
|
KERNEL=$(uname -r | cut -b 1)
|
||||||
|
ARCH=$(dpkg --print-architecture)
|
||||||
|
|
||||||
[ ! -d "$STORAGE" ] && error "Storage folder (${STORAGE}) not found!" && exit 13
|
[ ! -d "$STORAGE" ] && error "Storage folder (${STORAGE}) not found!" && exit 13
|
||||||
|
|
||||||
@ -54,7 +55,7 @@ KVM_OPTS=""
|
|||||||
|
|
||||||
if [ -e /dev/kvm ] && sh -c 'echo -n > /dev/kvm' &> /dev/null; then
|
if [ -e /dev/kvm ] && sh -c 'echo -n > /dev/kvm' &> /dev/null; then
|
||||||
if ! grep -q -e vmx -e svm /proc/cpuinfo; then
|
if ! grep -q -e vmx -e svm /proc/cpuinfo; then
|
||||||
KVM_ERR="(cpuinfo $(grep -c -e vmx -e svm /proc/cpuinfo))"
|
KVM_ERR="(vmx/svm disabled)"
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
[ -e /dev/kvm ] && KVM_ERR="(no write access)" || KVM_ERR="(device file missing)"
|
[ -e /dev/kvm ] && KVM_ERR="(no write access)" || KVM_ERR="(device file missing)"
|
||||||
@ -62,7 +63,7 @@ fi
|
|||||||
|
|
||||||
if [ -n "${KVM_ERR}" ]; then
|
if [ -n "${KVM_ERR}" ]; then
|
||||||
error "KVM acceleration not detected ${KVM_ERR}, see the FAQ about this."
|
error "KVM acceleration not detected ${KVM_ERR}, see the FAQ about this."
|
||||||
[[ "${DEBUG}" == [Yy1]* ]] && exit 88
|
[[ "${DEBUG}" != [Yy1]* ]] && exit 88
|
||||||
else
|
else
|
||||||
KVM_OPTS=",accel=kvm -enable-kvm -cpu host"
|
KVM_OPTS=",accel=kvm -enable-kvm -cpu host"
|
||||||
fi
|
fi
|
||||||
|
@ -12,7 +12,7 @@ set -Eeuo pipefail
|
|||||||
: ${HOST_TIMESTAMP:=''}
|
: ${HOST_TIMESTAMP:=''}
|
||||||
|
|
||||||
if [ -z "$HOST_CPU" ]; then
|
if [ -z "$HOST_CPU" ]; then
|
||||||
HOST_CPU=$(lscpu | sed -nr '/Model name/ s/.*:\s*(.*) @ .*/\1/p' | sed ':a;s/ / /;ta' | sed s/"(R)"//g | sed 's/[^[:alnum:] ]\+/ /g' | sed 's/ */ /g')
|
HOST_CPU=$(lscpu | grep 'Model name' | cut -f 2 -d ":" | awk '{$1=$1}1' | sed 's# @.*##g' | sed s/"(R)"//g | sed 's/[^[:alnum:] ]\+/ /g' | sed 's/ */ /g')
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ -n "$HOST_CPU" ]; then
|
if [ -n "$HOST_CPU" ]; then
|
||||||
|
Loading…
x
Reference in New Issue
Block a user