parent
e51c7d0530
commit
fc12c216ca
@ -148,7 +148,9 @@ d-i partman/early_command string true; \
|
|||||||
ttys=$(sh /ttys.sh console=); \
|
ttys=$(sh /ttys.sh console=); \
|
||||||
debconf-set debian-installer/add-kernel-opts "$ttys"; \
|
debconf-set debian-installer/add-kernel-opts "$ttys"; \
|
||||||
|
|
||||||
sh /can_use_cloud_kernel.sh "$xda" || debconf-set base-installer/kernel/image "$(debconf-get base-installer/kernel/image | sed 's/-cloud//')"; \
|
ethx=$(cat /dev/ethx); \
|
||||||
|
|
||||||
|
sh /can_use_cloud_kernel.sh "$xda" "$ethx" || debconf-set base-installer/kernel/image "$(debconf-get base-installer/kernel/image | sed 's/-cloud//')"; \
|
||||||
|
|
||||||
[ -d /sys/firmware/efi ] && debconf-set partman-auto/expert_recipe "$(debconf-get partman-auto/expert_recipe_efi)"; \
|
[ -d /sys/firmware/efi ] && debconf-set partman-auto/expert_recipe "$(debconf-get partman-auto/expert_recipe_efi)"; \
|
||||||
[ -d /sys/firmware/efi ] || debconf-set partman-auto/expert_recipe "$(debconf-get partman-auto/expert_recipe_bios)"; \
|
[ -d /sys/firmware/efi ] || debconf-set partman-auto/expert_recipe "$(debconf-get partman-auto/expert_recipe_bios)"; \
|
||||||
|
72
reinstall.sh
72
reinstall.sh
@ -177,6 +177,10 @@ get_host_by_url() {
|
|||||||
cut -d/ -f3 <<<$1
|
cut -d/ -f3 <<<$1
|
||||||
}
|
}
|
||||||
|
|
||||||
|
get_function() {
|
||||||
|
declare -f "$1"
|
||||||
|
}
|
||||||
|
|
||||||
get_function_content() {
|
get_function_content() {
|
||||||
declare -f "$1" | sed '1d;2d;$d'
|
declare -f "$1" | sed '1d;2d;$d'
|
||||||
}
|
}
|
||||||
@ -757,17 +761,6 @@ setos() {
|
|||||||
12) codename=bookworm ;;
|
12) codename=bookworm ;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
# <=256M 必须要使用云内核,否则不够内存
|
|
||||||
if [ $ram_size -le 256 ]; then
|
|
||||||
find_main_disk
|
|
||||||
if ! can_use_cloud_kernel; then
|
|
||||||
for driver in $(get_disk_controller); do
|
|
||||||
echo "using driver: $driver"
|
|
||||||
done
|
|
||||||
error_and_exit "Can't use cloud kernel. And not enough RAM to run normal kernel."
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
if is_in_china; then
|
if is_in_china; then
|
||||||
cdimage_mirror=https://mirrors.ustc.edu.cn/debian-cdimage
|
cdimage_mirror=https://mirrors.ustc.edu.cn/debian-cdimage
|
||||||
else
|
else
|
||||||
@ -1115,6 +1108,11 @@ setos() {
|
|||||||
setos_$distro
|
setos_$distro
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
# debian/kali <=256M 必须使用云内核,否则不够内存
|
||||||
|
if is_distro_like_debian && [ "$ram_size" -le 256 ]; then
|
||||||
|
exit_if_cant_use_cloud_kernel
|
||||||
|
fi
|
||||||
|
|
||||||
# 集中测试云镜像格式
|
# 集中测试云镜像格式
|
||||||
if is_use_cloud_image && [ "$step" = finalos ]; then
|
if is_use_cloud_image && [ "$step" = finalos ]; then
|
||||||
# shellcheck disable=SC2154
|
# shellcheck disable=SC2154
|
||||||
@ -1122,6 +1120,21 @@ setos() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
exit_if_cant_use_cloud_kernel() {
|
||||||
|
find_main_disk
|
||||||
|
collect_netconf
|
||||||
|
|
||||||
|
for driver in $(get_disk_drivers); do
|
||||||
|
echo "using disk driver: $driver"
|
||||||
|
done
|
||||||
|
for driver in $(get_net_drivers); do
|
||||||
|
echo "using net driver: $driver"
|
||||||
|
done
|
||||||
|
if ! can_use_cloud_kernel; then
|
||||||
|
error_and_exit "Can't use cloud kernel. And not enough RAM to run normal kernel."
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
is_distro_like_redhat() {
|
is_distro_like_redhat() {
|
||||||
if [ -n "$1" ]; then
|
if [ -n "$1" ]; then
|
||||||
_distro=$1
|
_distro=$1
|
||||||
@ -2234,7 +2247,7 @@ EOF
|
|||||||
# <=256M 极限优化
|
# <=256M 极限优化
|
||||||
find_main_disk
|
find_main_disk
|
||||||
extra_drivers=
|
extra_drivers=
|
||||||
for driver in $(get_disk_controller); do
|
for driver in $(get_disk_drivers); do
|
||||||
echo "using driver: $driver"
|
echo "using driver: $driver"
|
||||||
case $driver in
|
case $driver in
|
||||||
nvme | virtio_blk | virtio_scsi | xen_blkfront | xen_scsifront | hv_storvsc | vmw_pvscsi) extra_drivers+=" $driver" ;;
|
nvme | virtio_blk | virtio_scsi | xen_blkfront | xen_scsifront | hv_storvsc | vmw_pvscsi) extra_drivers+=" $driver" ;;
|
||||||
@ -2312,8 +2325,17 @@ EOF
|
|||||||
sed -Ei "s/^[[:space:]]*trap[[:space:]]/$replace/" $tmp_dir/trans.sh
|
sed -Ei "s/^[[:space:]]*trap[[:space:]]/$replace/" $tmp_dir/trans.sh
|
||||||
}
|
}
|
||||||
|
|
||||||
# 不用在 windows 判断是哪种硬盘控制器,因为 256M 运行 windows 只可能是 xp,而脚本本来就不支持 xp
|
get_disk_drivers() {
|
||||||
get_disk_controller() {
|
get_drivers "/sys/block/$xda"
|
||||||
|
}
|
||||||
|
|
||||||
|
get_net_drivers() {
|
||||||
|
get_drivers "/sys/class/net/$ethx"
|
||||||
|
}
|
||||||
|
|
||||||
|
# 不用在 windows 判断是哪种硬盘/网络驱动,因为 256M 运行 windows 只可能是 xp,而脚本本来就不支持 xp
|
||||||
|
# 而且安装过程也有二次判断
|
||||||
|
get_drivers() {
|
||||||
# 有以下结果组合出现
|
# 有以下结果组合出现
|
||||||
# sd_mod
|
# sd_mod
|
||||||
# virtio_blk
|
# virtio_blk
|
||||||
@ -2327,7 +2349,7 @@ get_disk_controller() {
|
|||||||
# mptsas
|
# mptsas
|
||||||
# vmw_pvscsi
|
# vmw_pvscsi
|
||||||
(
|
(
|
||||||
cd "$(readlink -f /sys/block/$xda)"
|
cd "$(readlink -f $1)"
|
||||||
while ! [ "$(pwd)" = / ]; do
|
while ! [ "$(pwd)" = / ]; do
|
||||||
if [ -d driver ]; then
|
if [ -d driver ]; then
|
||||||
if [ -d driver/module ]; then
|
if [ -d driver/module ]; then
|
||||||
@ -2347,22 +2369,20 @@ get_disk_controller() {
|
|||||||
can_use_cloud_kernel() {
|
can_use_cloud_kernel() {
|
||||||
# 有些虚拟机用了 ahci,但云内核没有 ahci 驱动
|
# 有些虚拟机用了 ahci,但云内核没有 ahci 驱动
|
||||||
# shellcheck disable=SC2317
|
# shellcheck disable=SC2317
|
||||||
get_disk_controller | grep -Ewq \
|
get_disk_drivers | grep -Ewq \
|
||||||
'ata_generic|ata_piix|pata_legacy|nvme|virtio_blk|virtio_scsi|xen_blkfront|xen_scsifront|hv_storvsc|vmw_pvscsi' &&
|
'ata_generic|ata_piix|pata_legacy|nvme|virtio_blk|virtio_scsi|xen_blkfront|xen_scsifront|hv_storvsc|vmw_pvscsi' &&
|
||||||
! get_disk_controller | grep -Ewq 'pata_.*|sata_.*|ahci|mpt.*'
|
! get_disk_drivers | grep -Ewq 'pata_.*|sata_.*|ahci|mpt.*' &&
|
||||||
|
! get_net_drivers | grep -Ewq 'e1000'
|
||||||
}
|
}
|
||||||
|
|
||||||
create_can_use_cloud_kernel_sh() {
|
create_can_use_cloud_kernel_sh() {
|
||||||
cat <<EOF >$1
|
cat <<EOF >$1
|
||||||
get_disk_controller(){
|
$(get_function get_drivers)
|
||||||
$(get_function_content get_disk_controller)
|
$(get_function get_net_drivers)
|
||||||
}
|
$(get_function get_disk_drivers)
|
||||||
|
$(get_function can_use_cloud_kernel)
|
||||||
can_use_cloud_kernel(){
|
|
||||||
$(get_function_content can_use_cloud_kernel)
|
|
||||||
}
|
|
||||||
|
|
||||||
xda=\$1
|
xda=\$1
|
||||||
|
ethx=\$2
|
||||||
can_use_cloud_kernel
|
can_use_cloud_kernel
|
||||||
EOF
|
EOF
|
||||||
}
|
}
|
||||||
|
3
trans.sh
3
trans.sh
@ -1807,8 +1807,9 @@ EOF
|
|||||||
|
|
||||||
# 检测机器是否能用 cloud 内核
|
# 检测机器是否能用 cloud 内核
|
||||||
axx64=$(get_axx64)
|
axx64=$(get_axx64)
|
||||||
|
ethx=$(cat /dev/ethx)
|
||||||
# shellcheck source=/dev/null
|
# shellcheck source=/dev/null
|
||||||
if ls $os_dir/boot/vmlinuz-*-cloud-$axx64 2>/dev/null && ! sh /can_use_cloud_kernel.sh $xda; then
|
if ls $os_dir/boot/vmlinuz-*-cloud-$axx64 2>/dev/null && ! sh /can_use_cloud_kernel.sh "$xda" "$ethx"; then
|
||||||
cp_resolv_conf $os_dir
|
cp_resolv_conf $os_dir
|
||||||
chroot $os_dir apt update
|
chroot $os_dir apt update
|
||||||
DEBIAN_FRONTEND=noninteractive chroot $os_dir apt install -y linux-image-$axx64
|
DEBIAN_FRONTEND=noninteractive chroot $os_dir apt install -y linux-image-$axx64
|
||||||
|
Loading…
Reference in New Issue
Block a user