mirror of
https://github.com/bin456789/reinstall.git
synced 2026-04-23 06:24:14 +08:00
Compare commits
11 Commits
f0b3a475fc
...
main
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
ae3ad40c75 | ||
|
|
2d676731bb | ||
|
|
93e83dfc58 | ||
|
|
e93d71680c | ||
|
|
f0fc83a060 | ||
|
|
07d8018db3 | ||
|
|
e104735538 | ||
|
|
43e226cc5c | ||
|
|
c6000c16ab | ||
|
|
8dd873d7dd | ||
|
|
41c4df9fdb |
10
README.en.md
10
README.en.md
@@ -337,15 +337,15 @@ bash reinstall.sh netboot.xyz
|
|||||||
|
|
||||||
- Windows (Vista ~ 11)
|
- Windows (Vista ~ 11)
|
||||||
- Windows Server (2008 ~ 2025)
|
- Windows Server (2008 ~ 2025)
|
||||||
- Windows Server Essentials \*
|
- Windows Server Essentials
|
||||||
- Windows Server (Semi) Annual Channel \*
|
- Windows Server (Semi) Annual Channel
|
||||||
- Hyper-V Server \*
|
- Hyper-V Server
|
||||||
- Azure Local (Azure Stack HCI) \*
|
- Azure Local (Azure Stack HCI)
|
||||||
|
|
||||||
#### Method 1: Let the Script Automatically Search for ISO
|
#### Method 1: Let the Script Automatically Search for ISO
|
||||||
|
|
||||||
- The script will search for ISOs from <https://massgrave.dev/genuine-installation-media>, a site that collects official ISOs.
|
- The script will search for ISOs from <https://massgrave.dev/genuine-installation-media>, a site that collects official ISOs.
|
||||||
- Systems marked with \* do not support automatic ISO searching.
|
- Only supports ISOs searching for Windows 10, 11, Server 2019, 2022, 2025.
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
bash reinstall.sh windows \
|
bash reinstall.sh windows \
|
||||||
|
|||||||
10
README.md
10
README.md
@@ -337,15 +337,15 @@ bash reinstall.sh netboot.xyz
|
|||||||
|
|
||||||
- Windows (Vista ~ 11)
|
- Windows (Vista ~ 11)
|
||||||
- Windows Server (2008 ~ 2025)
|
- Windows Server (2008 ~ 2025)
|
||||||
- Windows Server Essentials \*
|
- Windows Server Essentials
|
||||||
- Windows Server (Semi) Annual Channel \*
|
- Windows Server (Semi) Annual Channel
|
||||||
- Hyper-V Server \*
|
- Hyper-V Server
|
||||||
- Azure Local (Azure Stack HCI) \*
|
- Azure Local (Azure Stack HCI)
|
||||||
|
|
||||||
#### 方法 1: 让脚本自动查找 ISO
|
#### 方法 1: 让脚本自动查找 ISO
|
||||||
|
|
||||||
- 脚本会从 <https://massgrave.dev/genuine-installation-media> 查找 ISO,该网站专门提供官方 ISO 下载
|
- 脚本会从 <https://massgrave.dev/genuine-installation-media> 查找 ISO,该网站专门提供官方 ISO 下载
|
||||||
- 上面带 \* 的系统不支持自动查找 ISO
|
- 只支持查找 Windows 10, 11, Server 2019, 2022, 2025 的 ISO
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
bash reinstall.sh windows \
|
bash reinstall.sh windows \
|
||||||
|
|||||||
81
reinstall.sh
81
reinstall.sh
@@ -33,7 +33,9 @@ export LC_ALL=C
|
|||||||
export PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:$PATH
|
export PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:$PATH
|
||||||
|
|
||||||
# 如果不是 bash 的话,继续执行会有语法错误,因此在这里判断是否 bash
|
# 如果不是 bash 的话,继续执行会有语法错误,因此在这里判断是否 bash
|
||||||
if [ -z "$BASH" ]; then
|
if [ -z "$BASH" ] ||
|
||||||
|
# el 的 sh 是 bash 运行在 posix 模式,依然有 $BASH 和 $BASH_VERSION
|
||||||
|
{ [ -n "$BASH" ] && [ -n "$POSIXLY_CORRECT" ]; }; then
|
||||||
if ! command -v bash >/dev/null; then
|
if ! command -v bash >/dev/null; then
|
||||||
if [ -f /etc/alpine-release ]; then
|
if [ -f /etc/alpine-release ]; then
|
||||||
if ! apk add bash; then
|
if ! apk add bash; then
|
||||||
@@ -910,17 +912,7 @@ get_windows_iso_link() {
|
|||||||
get_label_msdn() {
|
get_label_msdn() {
|
||||||
if [ -n "$server" ]; then
|
if [ -n "$server" ]; then
|
||||||
case "$version" in
|
case "$version" in
|
||||||
2008 | '2008 r2')
|
2019 | 2022 | 2025)
|
||||||
case "$edition" in
|
|
||||||
serverweb | serverwebcore) echo _ ;;
|
|
||||||
serverstandard | serverstandardcore) echo _ ;;
|
|
||||||
serverenterprise | serverenterprisecore) echo _ ;;
|
|
||||||
serverdatacenter | serverdatacentercore) echo _ ;;
|
|
||||||
esac
|
|
||||||
;;
|
|
||||||
# massgrave 不提供 2012 下载
|
|
||||||
'2012 r2' | \
|
|
||||||
2016 | 2019 | 2022 | 2025)
|
|
||||||
case "$edition" in
|
case "$edition" in
|
||||||
serverstandard | serverstandardcore) echo _ ;;
|
serverstandard | serverstandardcore) echo _ ;;
|
||||||
serverdatacenter | serverdatacentercore) echo _ ;;
|
serverdatacenter | serverdatacentercore) echo _ ;;
|
||||||
@@ -929,39 +921,6 @@ get_windows_iso_link() {
|
|||||||
esac
|
esac
|
||||||
else
|
else
|
||||||
case "$version" in
|
case "$version" in
|
||||||
vista)
|
|
||||||
case "$edition" in
|
|
||||||
starter)
|
|
||||||
case "$arch_win" in
|
|
||||||
x86) echo _ ;;
|
|
||||||
esac
|
|
||||||
;;
|
|
||||||
homebasic | homepremium | ultimate) echo _ ;;
|
|
||||||
business | enterprise) echo "$edition" ;;
|
|
||||||
esac
|
|
||||||
;;
|
|
||||||
7)
|
|
||||||
case "$edition" in
|
|
||||||
starter)
|
|
||||||
case "$arch_win" in
|
|
||||||
x86) echo starter ;;
|
|
||||||
esac
|
|
||||||
;;
|
|
||||||
homebasic)
|
|
||||||
case "$arch_win" in
|
|
||||||
x86) echo "home basic" ;;
|
|
||||||
esac
|
|
||||||
;;
|
|
||||||
homepremium) echo "home premium" ;;
|
|
||||||
professional | enterprise | ultimate) echo "$edition" ;;
|
|
||||||
esac
|
|
||||||
;;
|
|
||||||
8 | 8.1)
|
|
||||||
case "$edition" in
|
|
||||||
'') echo _ ;; # windows 8.x core
|
|
||||||
pro | enterprise) echo "$edition" ;;
|
|
||||||
esac
|
|
||||||
;;
|
|
||||||
10)
|
10)
|
||||||
case "$edition" in
|
case "$edition" in
|
||||||
home | 'home single language') echo consumer ;;
|
home | 'home single language') echo consumer ;;
|
||||||
@@ -975,9 +934,8 @@ get_windows_iso_link() {
|
|||||||
# iot
|
# iot
|
||||||
'iot enterprise') echo 'iot enterprise' ;;
|
'iot enterprise') echo 'iot enterprise' ;;
|
||||||
# iot ltsc
|
# iot ltsc
|
||||||
'iot enterprise ltsc 2019' | 'iot enterprise ltsc 2021') echo "$edition" ;;
|
'iot enterprise ltsc 2021') echo "$edition" ;;
|
||||||
# ltsc
|
# ltsc
|
||||||
'enterprise 2015 ltsb' | 'enterprise 2016 ltsb' | 'enterprise ltsc 2019') echo "$edition" ;;
|
|
||||||
'enterprise ltsc 2021')
|
'enterprise ltsc 2021')
|
||||||
# arm64 的 enterprise ltsc 2021 要下载 iot enterprise ltsc 2021 iso
|
# arm64 的 enterprise ltsc 2021 要下载 iot enterprise ltsc 2021 iso
|
||||||
case "$arch_win" in
|
case "$arch_win" in
|
||||||
@@ -1038,13 +996,7 @@ get_windows_iso_link() {
|
|||||||
# win10 22h2 arm 有每月发布的 iso,因此不从 msdl 下载
|
# win10 22h2 arm 有每月发布的 iso,因此不从 msdl 下载
|
||||||
# win10/11 ltsc 没有每月发布的 iso,但是 msdl 没有 ltsc 版本
|
# win10/11 ltsc 没有每月发布的 iso,但是 msdl 没有 ltsc 版本
|
||||||
get_label_msdl() {
|
get_label_msdl() {
|
||||||
case "$version" in
|
:
|
||||||
8.1)
|
|
||||||
case "$edition" in
|
|
||||||
'' | pro) echo _ ;;
|
|
||||||
esac
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
}
|
}
|
||||||
|
|
||||||
get_page() {
|
get_page() {
|
||||||
@@ -1056,7 +1008,7 @@ get_windows_iso_link() {
|
|||||||
echo server
|
echo server
|
||||||
else
|
else
|
||||||
case "$version" in
|
case "$version" in
|
||||||
vista | 7 | 8 | 8.1 | 10 | 11)
|
10 | 11)
|
||||||
echo "$version"
|
echo "$version"
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
@@ -1073,9 +1025,7 @@ get_windows_iso_link() {
|
|||||||
label_vlsc=$(get_label_vlsc)
|
label_vlsc=$(get_label_vlsc)
|
||||||
page=$(get_page)
|
page=$(get_page)
|
||||||
|
|
||||||
if [ "$page" = vista ]; then
|
if [ "$page" = server ]; then
|
||||||
page_url=https://massgrave.dev/windows_vista__links
|
|
||||||
elif [ "$page" = server ]; then
|
|
||||||
page_url=https://massgrave.dev/windows-server-links
|
page_url=https://massgrave.dev/windows-server-links
|
||||||
else
|
else
|
||||||
page_url=https://massgrave.dev/windows_${page}_links
|
page_url=https://massgrave.dev/windows_${page}_links
|
||||||
@@ -2321,7 +2271,7 @@ check_ram() {
|
|||||||
is_efi() {
|
is_efi() {
|
||||||
if is_in_windows; then
|
if is_in_windows; then
|
||||||
# bcdedit | grep -qi '^path.*\.efi'
|
# bcdedit | grep -qi '^path.*\.efi'
|
||||||
mountvol | grep -q --text 'EFI'
|
mountvol | grep -q -a 'EFI'
|
||||||
else
|
else
|
||||||
[ -d /sys/firmware/efi ]
|
[ -d /sys/firmware/efi ]
|
||||||
fi
|
fi
|
||||||
@@ -2372,7 +2322,7 @@ is_use_local_extlinux() {
|
|||||||
is_mbr_using_grub() {
|
is_mbr_using_grub() {
|
||||||
find_main_disk
|
find_main_disk
|
||||||
# 各发行版不一定自带 strings hexdump xxd od 命令
|
# 各发行版不一定自带 strings hexdump xxd od 命令
|
||||||
head -c 440 /dev/$xda | grep --text -iq 'GRUB'
|
head -c 440 /dev/$xda | grep -a -iq 'GRUB'
|
||||||
}
|
}
|
||||||
|
|
||||||
to_upper() {
|
to_upper() {
|
||||||
@@ -2966,7 +2916,7 @@ install_grub_linux_efi() {
|
|||||||
info 'download grub efi'
|
info 'download grub efi'
|
||||||
|
|
||||||
# fedora 39 的 efi 无法识别 opensuse tumbleweed 的 xfs
|
# fedora 39 的 efi 无法识别 opensuse tumbleweed 的 xfs
|
||||||
efi_distro=opensuse
|
efi_distro=fedora
|
||||||
|
|
||||||
grub_efi=$(get_grub_efi_filename)
|
grub_efi=$(get_grub_efi_filename)
|
||||||
|
|
||||||
@@ -3116,7 +3066,7 @@ install_grub_win() {
|
|||||||
# 添加引导
|
# 添加引导
|
||||||
# 脚本可能不是首次运行,所以先删除原来的
|
# 脚本可能不是首次运行,所以先删除原来的
|
||||||
id='{1c41f649-1637-52f1-aea8-f96bfebeecc8}'
|
id='{1c41f649-1637-52f1-aea8-f96bfebeecc8}'
|
||||||
bcdedit /enum all | grep --text $id && bcdedit /delete $id
|
bcdedit /enum all | grep -a $id && bcdedit /delete $id
|
||||||
bcdedit /create $id /d "$(get_entry_name)" /application bootsector
|
bcdedit /create $id /d "$(get_entry_name)" /application bootsector
|
||||||
bcdedit /set $id device partition=$c:
|
bcdedit /set $id device partition=$c:
|
||||||
bcdedit /set $id path \\g2ldr
|
bcdedit /set $id path \\g2ldr
|
||||||
@@ -3918,7 +3868,7 @@ This script is outdated, please download reinstall.sh again.
|
|||||||
# -c Identical to "-H newc", use the new (SVR4)
|
# -c Identical to "-H newc", use the new (SVR4)
|
||||||
# portable format.If you wish the old portable
|
# portable format.If you wish the old portable
|
||||||
# (ASCII) archive format, use "-H odc" instead.
|
# (ASCII) archive format, use "-H odc" instead.
|
||||||
find . | cpio --quiet -o -H newc | gzip -1 >/reinstall-initrd
|
find . | cpio --quiet -o -H newc -R 0:0 | gzip -1 >/reinstall-initrd
|
||||||
cd - >/dev/null
|
cd - >/dev/null
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -3964,7 +3914,6 @@ remove_useless_initrd_files() {
|
|||||||
net/wireless \
|
net/wireless \
|
||||||
net/bluetooth \
|
net/bluetooth \
|
||||||
drivers/hid \
|
drivers/hid \
|
||||||
drivers/mmc \
|
|
||||||
drivers/mtd \
|
drivers/mtd \
|
||||||
drivers/usb \
|
drivers/usb \
|
||||||
drivers/ssb \
|
drivers/ssb \
|
||||||
@@ -4200,12 +4149,12 @@ remove_exist_reinstall() {
|
|||||||
remove_exist_reinstall_efi_dir
|
remove_exist_reinstall_efi_dir
|
||||||
|
|
||||||
bcdedit /set '{fwbootmgr}' bootsequence '{bootmgr}'
|
bcdedit /set '{fwbootmgr}' bootsequence '{bootmgr}'
|
||||||
bcdedit /enum bootmgr | grep --text -B3 'reinstall' | awk '{print $2}' | grep '{.*}' |
|
bcdedit /enum bootmgr | grep -a -B3 'reinstall' | awk '{print $2}' | grep '{.*}' |
|
||||||
xargs -I {} cmd /c bcdedit /delete {}
|
xargs -I {} cmd /c bcdedit /delete {}
|
||||||
else
|
else
|
||||||
# bios
|
# bios
|
||||||
id='{1c41f649-1637-52f1-aea8-f96bfebeecc8}'
|
id='{1c41f649-1637-52f1-aea8-f96bfebeecc8}'
|
||||||
if bcdedit /enum all | grep --text "$id"; then
|
if bcdedit /enum all | grep -a "$id"; then
|
||||||
bcdedit /delete "$id"
|
bcdedit /delete "$id"
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|||||||
200
trans.sh
200
trans.sh
@@ -1,6 +1,6 @@
|
|||||||
#!/bin/ash
|
#!/bin/ash
|
||||||
# shellcheck shell=dash
|
# shellcheck shell=dash
|
||||||
# shellcheck disable=SC2086,SC3047,SC3036,SC3010,SC3001,SC3060
|
# shellcheck disable=SC2086,SC3047,SC3036,SC3010,SC3001,SC3060,SC3015
|
||||||
# alpine 默认使用 busybox ash
|
# alpine 默认使用 busybox ash
|
||||||
# 注意 bash 和 ash 以下语句结果不同
|
# 注意 bash 和 ash 以下语句结果不同
|
||||||
# [[ a = '*a' ]] && echo 1
|
# [[ a = '*a' ]] && echo 1
|
||||||
@@ -1263,6 +1263,13 @@ networking = {
|
|||||||
EOF
|
EOF
|
||||||
|
|
||||||
for ethx in $(get_eths); do
|
for ethx in $(get_eths); do
|
||||||
|
# ipv4 使用 DHCP 时显式开启 useDHCP
|
||||||
|
if is_dhcpv4; then
|
||||||
|
cat <<EOF >>$conf_file
|
||||||
|
interfaces.$ethx.useDHCP = true;
|
||||||
|
EOF
|
||||||
|
fi
|
||||||
|
|
||||||
# ipv4
|
# ipv4
|
||||||
if is_staticv4; then
|
if is_staticv4; then
|
||||||
get_netconf_to ipv4_addr
|
get_netconf_to ipv4_addr
|
||||||
@@ -2535,6 +2542,22 @@ is_xda_gt_2t() {
|
|||||||
[ "$disk_size" -gt "$disk_2t" ]
|
[ "$disk_size" -gt "$disk_2t" ]
|
||||||
}
|
}
|
||||||
|
|
||||||
|
is_ends_with_digit() {
|
||||||
|
[[ "$1" =~ [0-9]$ ]]
|
||||||
|
}
|
||||||
|
|
||||||
|
xda() {
|
||||||
|
if [ -n "$1" ]; then
|
||||||
|
if is_ends_with_digit "$xda"; then
|
||||||
|
echo "${xda}p$1"
|
||||||
|
else
|
||||||
|
echo "${xda}$1"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo "$xda"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
create_part() {
|
create_part() {
|
||||||
# 除了 dd 都会用到
|
# 除了 dd 都会用到
|
||||||
info "Create Part"
|
info "Create Part"
|
||||||
@@ -2549,7 +2572,6 @@ create_part() {
|
|||||||
# TODO: 先检测iso链接/各种链接
|
# TODO: 先检测iso链接/各种链接
|
||||||
# wipefs -a /dev/$xda
|
# wipefs -a /dev/$xda
|
||||||
|
|
||||||
# xda*1 星号用于 nvme0n1p1 的字母 p
|
|
||||||
# shellcheck disable=SC2154
|
# shellcheck disable=SC2154
|
||||||
if [ "$distro" = windows ]; then
|
if [ "$distro" = windows ]; then
|
||||||
if ! size_bytes=$(get_link_file_size "$iso"); then
|
if ! size_bytes=$(get_link_file_size "$iso"); then
|
||||||
@@ -2582,10 +2604,10 @@ create_part() {
|
|||||||
set 3 msftdata on
|
set 3 msftdata on
|
||||||
update_part
|
update_part
|
||||||
|
|
||||||
mkfs.fat -n efi /dev/$xda*1 #1 efi
|
mkfs.fat -n efi "/dev/$(xda 1)" #1 efi
|
||||||
dd if=/dev/zero of="$(ls /dev/$xda*2)" bs=1M count=16 #2 msr
|
dd if=/dev/zero of="/dev/$(xda 2)" bs=1M count=16 #2 msr
|
||||||
mkfs.ntfs -f -F -L os /dev/$xda*3 #3 os
|
mkfs.ntfs -f -F -L os "/dev/$(xda 3)" #3 os
|
||||||
mkfs.ntfs -f -F -L installer /dev/$xda*4 #4 installer
|
mkfs.ntfs -f -F -L installer "/dev/$(xda 4)" #4 installer
|
||||||
else
|
else
|
||||||
# bios + mbr 启动盘最大可用 2t
|
# bios + mbr 启动盘最大可用 2t
|
||||||
if is_xda_gt_2t; then
|
if is_xda_gt_2t; then
|
||||||
@@ -2602,13 +2624,10 @@ create_part() {
|
|||||||
set 1 boot on
|
set 1 boot on
|
||||||
update_part
|
update_part
|
||||||
|
|
||||||
mkfs.ntfs -f -F -L os /dev/$xda*1 #1 os
|
mkfs.ntfs -f -F -L os "/dev/$(xda 1)" #1 os
|
||||||
mkfs.ntfs -f -F -L installer /dev/$xda*2 #2 installer
|
mkfs.ntfs -f -F -L installer "/dev/$(xda 2)" #2 installer
|
||||||
fi
|
fi
|
||||||
elif [ "$distro" = fnos ]; then
|
elif [ "$distro" = fnos ]; then
|
||||||
# 先用 100% 分区安装后再缩小没意义,因为小硬盘用 100% 还是装不了
|
|
||||||
# 因此直接用用户输入的分区大小
|
|
||||||
|
|
||||||
# 1. 官方安装器对系统盘大小的定义包含引导分区大小
|
# 1. 官方安装器对系统盘大小的定义包含引导分区大小
|
||||||
# 2. 官方 efi 用的是 1MiB-100M,但我们用 1MiB-101MiB
|
# 2. 官方 efi 用的是 1MiB-100M,但我们用 1MiB-101MiB
|
||||||
|
|
||||||
@@ -2640,47 +2659,53 @@ create_part() {
|
|||||||
# The location 20480MiB is outside of the device /dev/vda.
|
# The location 20480MiB is outside of the device /dev/vda.
|
||||||
# 但是 100% 分区后 end 就是 20480MiB
|
# 但是 100% 分区后 end 就是 20480MiB
|
||||||
|
|
||||||
os_part_end=${expect_m}MiB
|
|
||||||
if [ "$expect_m" -ge "$max_can_use_m" ]; then
|
if [ "$expect_m" -ge "$max_can_use_m" ]; then
|
||||||
echo "Expect size is equal/greater than max size. Setting to 100%"
|
warn "Expect size is equal/greater than max size. Uses max size."
|
||||||
os_part_end=100%
|
NEED_SHRINK_FNOS_OS_PART=false
|
||||||
|
FNOS_OS_PART_END_M=$max_can_use_m
|
||||||
|
else
|
||||||
|
NEED_SHRINK_FNOS_OS_PART=true
|
||||||
|
FNOS_OS_PART_END_M=$expect_m
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# 需关闭这几个特性,否则 grub 无法识别
|
# fnos 的 grub 是 debian 11 的
|
||||||
|
# 需关闭 metadata_csum_seed,否则 grub 会进入 grub rescue 模式,但 efi 下一切正常
|
||||||
|
# orphan_file 不需要关,但是官方安装器安装的系统分区没有这个特性,因此我们也关闭它
|
||||||
ext4_opts="-O ^metadata_csum_seed,^orphan_file"
|
ext4_opts="-O ^metadata_csum_seed,^orphan_file"
|
||||||
|
|
||||||
if is_efi; then
|
if is_efi; then
|
||||||
parted /dev/$xda -s -- \
|
parted /dev/$xda -s -- \
|
||||||
mklabel gpt \
|
mklabel gpt \
|
||||||
mkpart BOOT fat32 1MiB 101MiB \
|
mkpart BOOT fat32 1MiB 101MiB \
|
||||||
mkpart SYSTEM ext4 101MiB $os_part_end \
|
mkpart SYSTEM ext4 101MiB 100% \
|
||||||
set 1 esp on
|
set 1 esp on
|
||||||
update_part
|
update_part
|
||||||
|
|
||||||
mkfs.fat /dev/$xda*1 #1 efi
|
mkfs.fat "/dev/$(xda 1)" #1 efi
|
||||||
mkfs.ext4 -F $ext4_opts /dev/$xda*2 #2 os + installer
|
mkfs.ext4 -F $ext4_opts "/dev/$(xda 2)" #2 os + installer
|
||||||
elif is_xda_gt_2t; then
|
elif is_xda_gt_2t; then
|
||||||
# bios > 2t
|
# bios > 2t
|
||||||
# 官方安装器是 mkpart BOOT 1M 100M,无论 esp 或者 bios_grub 都用这个分区和大小
|
# 官方安装器是 mkpart BOOT 1M 100M,无论 esp 或者 bios_grub 都用这个分区和大小
|
||||||
parted /dev/$xda -s -- \
|
parted /dev/$xda -s -- \
|
||||||
mklabel gpt \
|
mklabel gpt \
|
||||||
mkpart BOOT ext4 1MiB 101MiB \
|
mkpart BOOT ext4 1MiB 101MiB \
|
||||||
mkpart SYSTEM ext4 101MiB $os_part_end \
|
mkpart SYSTEM ext4 101MiB 100% \
|
||||||
set 1 bios_grub on
|
set 1 bios_grub on
|
||||||
update_part
|
update_part
|
||||||
|
|
||||||
echo #1 bios_boot
|
echo #1 bios_boot
|
||||||
mkfs.ext4 -F $ext4_opts /dev/$xda*2 #2 os + installer
|
mkfs.ext4 -F $ext4_opts "/dev/$(xda 2)" #2 os + installer
|
||||||
else
|
else
|
||||||
# bios
|
# bios
|
||||||
parted /dev/$xda -s -- \
|
parted /dev/$xda -s -- \
|
||||||
mklabel msdos \
|
mklabel msdos \
|
||||||
mkpart primary 1MiB 101MiB \
|
mkpart primary 1MiB 101MiB \
|
||||||
mkpart primary 101MiB $os_part_end \
|
mkpart primary 101MiB 100% \
|
||||||
set 2 boot on
|
set 2 boot on
|
||||||
update_part
|
update_part
|
||||||
|
|
||||||
echo #1 官方安装有这个分区
|
echo #1 官方安装有这个分区
|
||||||
mkfs.ext4 -F $ext4_opts /dev/$xda*2 #2 os + installer
|
mkfs.ext4 -F $ext4_opts "/dev/$(xda 2)" #2 os + installer
|
||||||
fi
|
fi
|
||||||
elif is_use_cloud_image; then
|
elif is_use_cloud_image; then
|
||||||
installer_part_size="$(get_cloud_image_part_size)"
|
installer_part_size="$(get_cloud_image_part_size)"
|
||||||
@@ -2700,9 +2725,9 @@ create_part() {
|
|||||||
set 1 esp on
|
set 1 esp on
|
||||||
update_part
|
update_part
|
||||||
|
|
||||||
mkfs.fat -n efi /dev/$xda*1 #1 efi
|
mkfs.fat -n efi "/dev/$(xda 1)" #1 efi
|
||||||
echo #2 os 用目标系统的格式化工具
|
echo #2 os 用目标系统的格式化工具
|
||||||
mkfs.ext4 -F -L installer /dev/$xda*3 #3 installer
|
mkfs.ext4 -F -L installer "/dev/$(xda 3)" #3 installer
|
||||||
else
|
else
|
||||||
parted /dev/$xda -s -- \
|
parted /dev/$xda -s -- \
|
||||||
mklabel gpt \
|
mklabel gpt \
|
||||||
@@ -2714,7 +2739,7 @@ create_part() {
|
|||||||
|
|
||||||
echo #1 bios_boot
|
echo #1 bios_boot
|
||||||
echo #2 os 用目标系统的格式化工具
|
echo #2 os 用目标系统的格式化工具
|
||||||
mkfs.ext4 -F -L installer /dev/$xda*3 #3 installer
|
mkfs.ext4 -F -L installer "/dev/$(xda 3)" #3 installer
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
# 使用 dd qcow2
|
# 使用 dd qcow2
|
||||||
@@ -2725,8 +2750,8 @@ create_part() {
|
|||||||
mkpart '" "' ext4 -$installer_part_size 100%
|
mkpart '" "' ext4 -$installer_part_size 100%
|
||||||
update_part
|
update_part
|
||||||
|
|
||||||
mkfs.ext4 -F -L os /dev/$xda*1 #1 os
|
mkfs.ext4 -F -L os "/dev/$(xda 1)" #1 os
|
||||||
mkfs.ext4 -F -L installer /dev/$xda*2 #2 installer
|
mkfs.ext4 -F -L installer "/dev/$(xda 2)" #2 installer
|
||||||
fi
|
fi
|
||||||
elif [ "$distro" = alpine ] || [ "$distro" = arch ] || [ "$distro" = gentoo ] ||
|
elif [ "$distro" = alpine ] || [ "$distro" = arch ] || [ "$distro" = gentoo ] ||
|
||||||
[ "$distro" = nixos ] || [ "$distro" = aosc ]; then
|
[ "$distro" = nixos ] || [ "$distro" = aosc ]; then
|
||||||
@@ -2743,8 +2768,8 @@ create_part() {
|
|||||||
set 1 boot on
|
set 1 boot on
|
||||||
update_part
|
update_part
|
||||||
|
|
||||||
mkfs.fat /dev/$xda*1 #1 efi
|
mkfs.fat "/dev/$(xda 1)" #1 efi
|
||||||
mkfs.ext4 -F $ext4_opts /dev/$xda*2 #2 os
|
mkfs.ext4 -F $ext4_opts "/dev/$(xda 2)" #2 os
|
||||||
elif is_xda_gt_2t; then
|
elif is_xda_gt_2t; then
|
||||||
# bios > 2t
|
# bios > 2t
|
||||||
parted /dev/$xda -s -- \
|
parted /dev/$xda -s -- \
|
||||||
@@ -2755,7 +2780,7 @@ create_part() {
|
|||||||
update_part
|
update_part
|
||||||
|
|
||||||
echo #1 bios_boot
|
echo #1 bios_boot
|
||||||
mkfs.ext4 -F $ext4_opts /dev/$xda*2 #2 os
|
mkfs.ext4 -F $ext4_opts "/dev/$(xda 2)" #2 os
|
||||||
else
|
else
|
||||||
# bios
|
# bios
|
||||||
parted /dev/$xda -s -- \
|
parted /dev/$xda -s -- \
|
||||||
@@ -2764,7 +2789,7 @@ create_part() {
|
|||||||
set 1 boot on
|
set 1 boot on
|
||||||
update_part
|
update_part
|
||||||
|
|
||||||
mkfs.ext4 -F $ext4_opts /dev/$xda*1 #1 os
|
mkfs.ext4 -F $ext4_opts "/dev/$(xda 1)" #1 os
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
# 安装红帽系或ubuntu
|
# 安装红帽系或ubuntu
|
||||||
@@ -2797,9 +2822,9 @@ create_part() {
|
|||||||
set 1 boot on
|
set 1 boot on
|
||||||
update_part
|
update_part
|
||||||
|
|
||||||
mkfs.fat -n efi /dev/$xda*1 #1 efi
|
mkfs.fat -n efi "/dev/$(xda 1)" #1 efi
|
||||||
mkfs.ext4 -F -L os /dev/$xda*2 #2 os
|
mkfs.ext4 -F -L os "/dev/$(xda 2)" #2 os
|
||||||
mkfs.ext4 -F -L installer $ext4_opts /dev/$xda*3 #2 installer
|
mkfs.ext4 -F -L installer $ext4_opts "/dev/$(xda 3)" #2 installer
|
||||||
elif is_xda_gt_2t; then
|
elif is_xda_gt_2t; then
|
||||||
# bios > 2t
|
# bios > 2t
|
||||||
parted /dev/$xda -s -- \
|
parted /dev/$xda -s -- \
|
||||||
@@ -2811,8 +2836,8 @@ create_part() {
|
|||||||
update_part
|
update_part
|
||||||
|
|
||||||
echo #1 bios_boot
|
echo #1 bios_boot
|
||||||
mkfs.ext4 -F -L os /dev/$xda*2 #2 os
|
mkfs.ext4 -F -L os "/dev/$(xda 2)" #2 os
|
||||||
mkfs.ext4 -F -L installer $ext4_opts /dev/$xda*3 #3 installer
|
mkfs.ext4 -F -L installer $ext4_opts "/dev/$(xda 3)" #3 installer
|
||||||
else
|
else
|
||||||
# bios
|
# bios
|
||||||
parted /dev/$xda -s -- \
|
parted /dev/$xda -s -- \
|
||||||
@@ -2822,8 +2847,8 @@ create_part() {
|
|||||||
set 1 boot on
|
set 1 boot on
|
||||||
update_part
|
update_part
|
||||||
|
|
||||||
mkfs.ext4 -F -L os /dev/$xda*1 #1 os
|
mkfs.ext4 -F -L os "/dev/$(xda 1)" #1 os
|
||||||
mkfs.ext4 -F -L installer $ext4_opts /dev/$xda*2 #2 installer
|
mkfs.ext4 -F -L installer $ext4_opts "/dev/$(xda 2)" #2 installer
|
||||||
fi
|
fi
|
||||||
update_part
|
update_part
|
||||||
fi
|
fi
|
||||||
@@ -3918,7 +3943,9 @@ modify_os_on_disk() {
|
|||||||
|
|
||||||
mkdir -p /os
|
mkdir -p /os
|
||||||
# 按分区容量大到小,依次寻找系统分区
|
# 按分区容量大到小,依次寻找系统分区
|
||||||
for part in $(lsblk /dev/$xda*[0-9] --sort SIZE -no NAME | tac); do
|
# lsblk /dev/mmcblk0* 会列出 mmcblk0boot0 mmcblk0boot1
|
||||||
|
# lsblk /dev/mmcblk0 不会列出 mmcblk0boot0 mmcblk0boot1
|
||||||
|
for part in $(lsblk /dev/$xda --filter 'TYPE == "part"' --sort SIZE -no NAME | tac); do
|
||||||
# btrfs挂载的是默认子卷,如果没有默认子卷,挂载的是根目录
|
# btrfs挂载的是默认子卷,如果没有默认子卷,挂载的是根目录
|
||||||
# fedora 云镜像没有默认子卷,且系统在root子卷中
|
# fedora 云镜像没有默认子卷,且系统在root子卷中
|
||||||
if mount -o ro /dev/$part /os; then
|
if mount -o ro /dev/$part /os; then
|
||||||
@@ -4448,7 +4475,7 @@ install_fnos() {
|
|||||||
|
|
||||||
# 挂载 /os
|
# 挂载 /os
|
||||||
mkdir -p /os
|
mkdir -p /os
|
||||||
mount /dev/$xda*2 /os
|
mount "/dev/$(xda 2)" /os
|
||||||
|
|
||||||
# 下载并挂载 iso
|
# 下载并挂载 iso
|
||||||
mkdir -p /os/installer /iso
|
mkdir -p /os/installer /iso
|
||||||
@@ -4489,7 +4516,7 @@ install_fnos() {
|
|||||||
# 挂载 /os/boot/efi
|
# 挂载 /os/boot/efi
|
||||||
if is_efi; then
|
if is_efi; then
|
||||||
mkdir -p /os/boot/efi
|
mkdir -p /os/boot/efi
|
||||||
mount -o "$(echo "$fstab_line_efi" | awk '{print $4}')" /dev/$xda*1 /os/boot/efi
|
mount -o "$(echo "$fstab_line_efi" | awk '{print $4}')" "/dev/$(xda 1)" /os/boot/efi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# 复制系统
|
# 复制系统
|
||||||
@@ -4501,6 +4528,36 @@ install_fnos() {
|
|||||||
# 删除 installer (trimfs.tgz)
|
# 删除 installer (trimfs.tgz)
|
||||||
rm -rf /os/installer
|
rm -rf /os/installer
|
||||||
|
|
||||||
|
# 缩小分区
|
||||||
|
if $NEED_SHRINK_FNOS_OS_PART; then
|
||||||
|
info "Shrink fnos os partition"
|
||||||
|
|
||||||
|
# 取消挂载
|
||||||
|
if is_efi; then
|
||||||
|
umount /os/boot/efi
|
||||||
|
fi
|
||||||
|
umount /os
|
||||||
|
|
||||||
|
# 101M 是 efi + bios_grub 分区,即使 bios 引导飞牛官方安装器也会生成一个 100M 预留分区
|
||||||
|
# 99M 是预留的文件系统和分区表的差值
|
||||||
|
# 一共 200M
|
||||||
|
apk add e2fsprogs-extra parted
|
||||||
|
e2fsck -p -f "/dev/$(xda 2)"
|
||||||
|
resize2fs "/dev/$(xda 2)" "$((FNOS_OS_PART_END_M - 200))M"
|
||||||
|
update_part
|
||||||
|
printf "yes" | parted /dev/$xda resizepart 2 "$((FNOS_OS_PART_END_M))MiB" ---pretend-input-tty
|
||||||
|
update_part
|
||||||
|
resize2fs "/dev/$(xda 2)"
|
||||||
|
update_part
|
||||||
|
apk del e2fsprogs-extra parted
|
||||||
|
|
||||||
|
# 重新挂载
|
||||||
|
mount "/dev/$(xda 2)" /os
|
||||||
|
if is_efi; then
|
||||||
|
mount -o "$(echo "$fstab_line_efi" | awk '{print $4}')" "/dev/$(xda 1)" /os/boot/efi
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
# 挂载 proc sys dev
|
# 挂载 proc sys dev
|
||||||
mount_pseudo_fs /os
|
mount_pseudo_fs /os
|
||||||
|
|
||||||
@@ -4520,7 +4577,7 @@ install_fnos() {
|
|||||||
# fstab
|
# fstab
|
||||||
{
|
{
|
||||||
# /
|
# /
|
||||||
uuid=$(lsblk /dev/$xda*2 -no UUID)
|
uuid=$(lsblk "/dev/$(xda 2)" -no UUID)
|
||||||
echo "$fstab_line_os" | sed "s/%s/$uuid/"
|
echo "$fstab_line_os" | sed "s/%s/$uuid/"
|
||||||
|
|
||||||
# swapfile
|
# swapfile
|
||||||
@@ -4529,7 +4586,7 @@ install_fnos() {
|
|||||||
|
|
||||||
# /boot/efi
|
# /boot/efi
|
||||||
if is_efi; then
|
if is_efi; then
|
||||||
uuid=$(lsblk /dev/$xda*1 -no UUID)
|
uuid=$(lsblk "/dev/$(xda 1)" -no UUID)
|
||||||
echo "$fstab_line_efi" | sed "s/%s/$uuid/"
|
echo "$fstab_line_efi" | sed "s/%s/$uuid/"
|
||||||
fi
|
fi
|
||||||
} >$os_dir/etc/fstab
|
} >$os_dir/etc/fstab
|
||||||
@@ -4655,7 +4712,7 @@ install_qcow_by_copy() {
|
|||||||
if is_efi; then
|
if is_efi; then
|
||||||
# centos/oracle 要创建efi条目
|
# centos/oracle 要创建efi条目
|
||||||
if ! grep /boot/efi /os/etc/fstab; then
|
if ! grep /boot/efi /os/etc/fstab; then
|
||||||
efi_part_uuid=$(lsblk /dev/$xda*1 -no UUID)
|
efi_part_uuid=$(lsblk "/dev/$(xda 1)" -no UUID)
|
||||||
echo "UUID=$efi_part_uuid /boot/efi vfat $efi_mount_opts 0 0" >>/os/etc/fstab
|
echo "UUID=$efi_part_uuid /boot/efi vfat $efi_mount_opts 0 0" >>/os/etc/fstab
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
@@ -4990,7 +5047,7 @@ EOF
|
|||||||
# 因为 24.04 fsuuid 对应 boot 分区
|
# 因为 24.04 fsuuid 对应 boot 分区
|
||||||
efi_grub_cfg=$os_dir/boot/efi/EFI/ubuntu/grub.cfg
|
efi_grub_cfg=$os_dir/boot/efi/EFI/ubuntu/grub.cfg
|
||||||
if is_efi; then
|
if is_efi; then
|
||||||
os_uuid=$(lsblk -rno UUID /dev/$xda*2)
|
os_uuid=$(lsblk -rno UUID "/dev/$(xda 2)")
|
||||||
sed -Ei "s|[0-9a-f-]{36}|$os_uuid|i" $efi_grub_cfg
|
sed -Ei "s|[0-9a-f-]{36}|$os_uuid|i" $efi_grub_cfg
|
||||||
|
|
||||||
# 24.04 移除 boot 分区后,需要添加 /boot 路径
|
# 24.04 移除 boot 分区后,需要添加 /boot 路径
|
||||||
@@ -5004,7 +5061,7 @@ EOF
|
|||||||
if [ -e $force_partuuid_cfg ]; then
|
if [ -e $force_partuuid_cfg ]; then
|
||||||
if is_virt; then
|
if is_virt; then
|
||||||
# 更改写死的 partuuid
|
# 更改写死的 partuuid
|
||||||
os_part_uuid=$(lsblk -rno PARTUUID /dev/$xda*2)
|
os_part_uuid=$(lsblk -rno PARTUUID "/dev/$(xda 2)")
|
||||||
sed -i "s/^GRUB_FORCE_PARTUUID=.*/GRUB_FORCE_PARTUUID=$os_part_uuid/" $force_partuuid_cfg
|
sed -i "s/^GRUB_FORCE_PARTUUID=.*/GRUB_FORCE_PARTUUID=$os_part_uuid/" $force_partuuid_cfg
|
||||||
else
|
else
|
||||||
# 独服不应该使用 initrdless boot
|
# 独服不应该使用 initrdless boot
|
||||||
@@ -5155,8 +5212,8 @@ EOF
|
|||||||
mount_nouuid /dev/$os_part /nbd/
|
mount_nouuid /dev/$os_part /nbd/
|
||||||
mount_pseudo_fs /nbd/
|
mount_pseudo_fs /nbd/
|
||||||
case "$os_part_fstype" in
|
case "$os_part_fstype" in
|
||||||
ext4) chroot /nbd mkfs.ext4 -F -L "$os_part_label" -U "$os_part_uuid" /dev/$xda*2 ;;
|
ext4) chroot /nbd mkfs.ext4 -F -L "$os_part_label" -U "$os_part_uuid" "/dev/$(xda 2)" ;;
|
||||||
xfs) chroot /nbd mkfs.xfs -f -L "$os_part_label" -m uuid=$os_part_uuid /dev/$xda*2 ;;
|
xfs) chroot /nbd mkfs.xfs -f -L "$os_part_label" -m uuid=$os_part_uuid "/dev/$(xda 2)" ;;
|
||||||
esac
|
esac
|
||||||
umount -R /nbd/
|
umount -R /nbd/
|
||||||
|
|
||||||
@@ -5164,7 +5221,7 @@ EOF
|
|||||||
|
|
||||||
# 创建并挂载 /os
|
# 创建并挂载 /os
|
||||||
mkdir -p /os
|
mkdir -p /os
|
||||||
mount -o noatime /dev/$xda*2 /os/
|
mount -o noatime "/dev/$(xda 2)" /os/
|
||||||
|
|
||||||
# 如果是 efi 则创建 /os/boot/efi
|
# 如果是 efi 则创建 /os/boot/efi
|
||||||
# 如果镜像有 efi 分区也创建 /os/boot/efi,用于复制 efi 分区的文件
|
# 如果镜像有 efi 分区也创建 /os/boot/efi,用于复制 efi 分区的文件
|
||||||
@@ -5175,7 +5232,7 @@ EOF
|
|||||||
# 预先挂载 /os/boot/efi 因为可能 boot 和 efi 在同一个分区(openeuler 24.03 arm)
|
# 预先挂载 /os/boot/efi 因为可能 boot 和 efi 在同一个分区(openeuler 24.03 arm)
|
||||||
# 复制 boot 时可以会复制 efi 的文件
|
# 复制 boot 时可以会复制 efi 的文件
|
||||||
if is_efi; then
|
if is_efi; then
|
||||||
mount -o $efi_mount_opts /dev/$xda*1 /os/boot/efi/
|
mount -o $efi_mount_opts "/dev/$(xda 1)" /os/boot/efi/
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -5226,7 +5283,7 @@ EOF
|
|||||||
if is_efi && [ -n "$efi_part_uuid" ] && ! [ "$efi_part" = "$os_part" ]; then
|
if is_efi && [ -n "$efi_part_uuid" ] && ! [ "$efi_part" = "$os_part" ]; then
|
||||||
info "Copy efi partition uuid"
|
info "Copy efi partition uuid"
|
||||||
apk add mtools
|
apk add mtools
|
||||||
mlabel -N "$(echo $efi_part_uuid | sed 's/-//')" -i /dev/$xda*1 ::$efi_part_label
|
mlabel -N "$(echo $efi_part_uuid | sed 's/-//')" -i "/dev/$(xda 1)" ::$efi_part_label
|
||||||
apk del mtools
|
apk del mtools
|
||||||
update_part
|
update_part
|
||||||
fi
|
fi
|
||||||
@@ -5240,9 +5297,9 @@ EOF
|
|||||||
|
|
||||||
# 重新挂载 /os /boot/efi
|
# 重新挂载 /os /boot/efi
|
||||||
info "Re-mount disk"
|
info "Re-mount disk"
|
||||||
mount -o noatime /dev/$xda*2 /os/
|
mount -o noatime "/dev/$(xda 2)" /os/
|
||||||
if is_efi; then
|
if is_efi; then
|
||||||
mount -o $efi_mount_opts /dev/$xda*1 /os/boot/efi/
|
mount -o $efi_mount_opts "/dev/$(xda 1)" /os/boot/efi/
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# 创建 swap
|
# 创建 swap
|
||||||
@@ -5462,22 +5519,22 @@ resize_after_install_cloud_image() {
|
|||||||
ext4)
|
ext4)
|
||||||
# debian ci
|
# debian ci
|
||||||
apk add e2fsprogs-extra
|
apk add e2fsprogs-extra
|
||||||
e2fsck -p -f /dev/$xda*$last_part_num
|
e2fsck -p -f "/dev/$(xda $last_part_num)"
|
||||||
resize2fs /dev/$xda*$last_part_num
|
resize2fs "/dev/$(xda $last_part_num)"
|
||||||
apk del e2fsprogs-extra
|
apk del e2fsprogs-extra
|
||||||
;;
|
;;
|
||||||
xfs)
|
xfs)
|
||||||
# opensuse ci
|
# opensuse ci
|
||||||
apk add xfsprogs-extra
|
apk add xfsprogs-extra
|
||||||
mount /dev/$xda*$last_part_num /os
|
mount "/dev/$(xda $last_part_num)" /os
|
||||||
xfs_growfs /dev/$xda*$last_part_num
|
xfs_growfs "/dev/$(xda $last_part_num)"
|
||||||
umount /os
|
umount /os
|
||||||
apk del xfsprogs-extra
|
apk del xfsprogs-extra
|
||||||
;;
|
;;
|
||||||
btrfs)
|
btrfs)
|
||||||
# fedora ci
|
# fedora ci
|
||||||
apk add btrfs-progs
|
apk add btrfs-progs
|
||||||
mount /dev/$xda*$last_part_num /os
|
mount "/dev/$(xda $last_part_num)" /os
|
||||||
btrfs filesystem resize max /os
|
btrfs filesystem resize max /os
|
||||||
umount /os
|
umount /os
|
||||||
apk del btrfs-progs
|
apk del btrfs-progs
|
||||||
@@ -5485,8 +5542,8 @@ resize_after_install_cloud_image() {
|
|||||||
ntfs)
|
ntfs)
|
||||||
# windows dd
|
# windows dd
|
||||||
apk add ntfs-3g-progs
|
apk add ntfs-3g-progs
|
||||||
echo y | ntfsresize /dev/$xda*$last_part_num
|
echo y | ntfsresize "/dev/$(xda $last_part_num)"
|
||||||
ntfsfix -d /dev/$xda*$last_part_num
|
ntfsfix -d "/dev/$(xda $last_part_num)"
|
||||||
apk del ntfs-3g-progs
|
apk del ntfs-3g-progs
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
@@ -5507,12 +5564,12 @@ mount_part_basic_layout() {
|
|||||||
|
|
||||||
# 挂载系统分区
|
# 挂载系统分区
|
||||||
mkdir -p $os_dir
|
mkdir -p $os_dir
|
||||||
mount -t ext4 /dev/${xda}*${os_part_num} $os_dir
|
mount -t ext4 "/dev/$(xda $os_part_num)" $os_dir
|
||||||
|
|
||||||
# 挂载 efi 分区
|
# 挂载 efi 分区
|
||||||
if is_efi; then
|
if is_efi; then
|
||||||
mkdir -p $efi_dir
|
mkdir -p $efi_dir
|
||||||
mount -t vfat -o umask=077 /dev/${xda}*1 $efi_dir
|
mount -t vfat -o umask=077 "/dev/$(xda 1)" $efi_dir
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -5852,7 +5909,7 @@ install_windows() {
|
|||||||
while true; do
|
while true; do
|
||||||
# 匹配成功
|
# 匹配成功
|
||||||
# 改成正确的大小写
|
# 改成正确的大小写
|
||||||
if matched_image_name=$(echo "$all_image_names" | grep -ix "$image_name"); then
|
if matched_image_name=$(printf '%s\n' "$all_image_names" | grep -Fix "$image_name"); then
|
||||||
image_name=$matched_image_name
|
image_name=$matched_image_name
|
||||||
image_index=$(wiminfo "$iso_install_wim" "$image_name" | grep 'Index:' | awk '{print $NF}')
|
image_index=$(wiminfo "$iso_install_wim" "$image_name" | grep 'Index:' | awk '{print $NF}')
|
||||||
break
|
break
|
||||||
@@ -6478,9 +6535,9 @@ EOF
|
|||||||
|
|
||||||
apk add msitools
|
apk add msitools
|
||||||
|
|
||||||
# 8.4.3 的 xenbus 挑创建实例时的初始系统
|
# 8.4.3+ 的 xenbus 驱动挑创建实例时的初始系统
|
||||||
# 初始系统为 windows 的实例支持 8.4.3
|
# 初始系统为 windows 的实例支持 8.4.3+
|
||||||
# 初始系统为 linux 的实例不支持 8.4.3
|
# 初始系统为 linux 的实例不支持 8.4.3+
|
||||||
|
|
||||||
# 初始系统为 linux + 安装 8.4.3
|
# 初始系统为 linux + 安装 8.4.3
|
||||||
# 如果用 msi 安装,则不会启用 xenbus,结果是能启动但无法上网
|
# 如果用 msi 安装,则不会启用 xenbus,结果是能启动但无法上网
|
||||||
@@ -6495,11 +6552,16 @@ EOF
|
|||||||
6.1) $support_sha256 && echo 8.3.5 || echo 8.3.2 ;;
|
6.1) $support_sha256 && echo 8.3.5 || echo 8.3.2 ;;
|
||||||
6.2 | 6.3)
|
6.2 | 6.3)
|
||||||
case "$hypervisor_vendor" in
|
case "$hypervisor_vendor" in
|
||||||
Microsoft) echo 8.4.3 ;; # 实例初始系统为 Windows,能使用 8.4.3
|
Xen) echo 8.3.5 ;; # 实例初始系统为 Linux
|
||||||
Xen) echo 8.3.5 ;; # 实例初始系统为 Linux,不能使用 8.4.3
|
Microsoft) echo 8.4.3 ;; # 实例初始系统为 Windows
|
||||||
|
esac
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
case "$hypervisor_vendor" in
|
||||||
|
Xen) echo 8.3.5 ;; # 实例初始系统为 Linux
|
||||||
|
Microsoft) echo Latest ;; # 实例初始系统为 Windows
|
||||||
esac
|
esac
|
||||||
;;
|
;;
|
||||||
*) echo Latest ;;
|
|
||||||
esac
|
esac
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|||||||
BIN
windows-frpc.xml
BIN
windows-frpc.xml
Binary file not shown.
Reference in New Issue
Block a user