debian: 256M 内存模式添加更多驱动,安装云镜像时也判断能否用云内核

This commit is contained in:
bin456789 2024-05-22 21:37:30 +08:00
parent 135576e95c
commit d2a3673107
No known key found for this signature in database
GPG Key ID: EE301B386DE6C11B
3 changed files with 255 additions and 131 deletions

View File

@ -135,7 +135,7 @@ d-i finish-install/reboot_in_progress note
ttys=$(wget --tries=5 $confhome/ttys.sh -O- | sh -s console=); \ ttys=$(wget --tries=5 $confhome/ttys.sh -O- | sh -s console=); \
debconf-set debian-installer/add-kernel-opts "$ttys"; \ debconf-set debian-installer/add-kernel-opts "$ttys"; \
. /can_use_cloud_kernel.sh || debconf-set base-installer/kernel/image $(debconf-get base-installer/kernel/image | sed 's/-cloud//'); \ sh /can_use_cloud_kernel.sh "$xda" || 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)"; \

View File

@ -745,6 +745,17 @@ 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
@ -1905,17 +1916,17 @@ build_nextos_cmdline() {
if is_distro_like_debian $nextos_distro; then if is_distro_like_debian $nextos_distro; then
if [ "$basearch" = "x86_64" ]; then if [ "$basearch" = "x86_64" ]; then
# debian 安装界面不遵循最后一个 tty 为主 tty 的规则 # debian installer 好像第一个 tty 是主 tty
# 设置ttyS0,tty0,安装界面还是显示在ttyS0 # 设置ttyS0,tty0,安装界面还是显示在ttyS0
: :
else else
# debian arm 在没有ttyAMA0的机器上aws t4g最少要设置一个tty才能启动 # debian arm 在没有ttyAMA0的机器上aws t4g最少要设置一个tty才能启动
# 只设置tty0也行但安装过程ttyS0没有显示 # 只设置tty0也行但安装过程ttyS0没有显示
nextos_cmdline+=" console=ttyS0,115200 console=ttyAMA0,115200 console=tty0" nextos_cmdline+=" console=ttyAMA0,115200 console=ttyS0,115200 console=tty0"
fi fi
else else
# nextos_cmdline+=" $(echo_tmp_ttys)" # nextos_cmdline+=" $(echo_tmp_ttys)"
nextos_cmdline+=" console=ttyS0,115200 console=ttyAMA0,115200 console=tty0" nextos_cmdline+=" console=ttyAMA0,115200 console=ttyS0,115200 console=tty0"
fi fi
# nextos_cmdline+=" mem=256M" # nextos_cmdline+=" mem=256M"
# nextos_cmdline+=" lowmem=+1" # nextos_cmdline+=" lowmem=+1"
@ -1954,7 +1965,7 @@ mkdir_clear() {
mkdir -p $dir mkdir -p $dir
} }
mod_initrd_debian() { mod_initrd_debian_kali() {
# hack 1 # hack 1
# 允许设置 ipv4 onlink 网关 # 允许设置 ipv4 onlink 网关
sed -Ei 's,&&( onlink=),||\1,' etc/udhcpc/default.script sed -Ei 's,&&( onlink=),||\1,' etc/udhcpc/default.script
@ -2014,6 +2025,9 @@ EOF
db_progress STEP 1 db_progress STEP 1
} }
# 直接覆盖 net-retriever方便调试
# curl -Lo /usr/lib/debian-installer/retriever/net-retriever $confhome/net-retriever
collect_netconf collect_netconf
is_in_china && is_in_china=true || is_in_china=false is_in_china && is_in_china=true || is_in_china=false
netconf="'$mac_addr' '$ipv4_addr' '$ipv4_gateway' '$ipv6_addr' '$ipv6_gateway' '$is_in_china'" netconf="'$mac_addr' '$ipv4_addr' '$ipv4_gateway' '$ipv6_addr' '$ipv6_gateway' '$is_in_china'"
@ -2036,6 +2050,11 @@ EOF
# shellcheck disable=SC2154 # shellcheck disable=SC2154
if [ "$value" = standard ] && echo "$disabled_list" | grep -qx "$package"; then if [ "$value" = standard ] && echo "$disabled_list" | grep -qx "$package"; then
line="Priority: optional" line="Priority: optional"
elif [[ "$package" = ata-modules* ]]; then
# 改成强制安装
# 因为是 pata-modules sata-modules scsi-modules 的依赖
# 但我们没安装它们,也就不会自动安装 ata-modules
line="Priority: standard"
fi fi
;; ;;
esac esac
@ -2087,14 +2106,18 @@ EOF
# https://github.com/linuxhw/LsPCI?tab=readme-ov-file#storageata-pci # https://github.com/linuxhw/LsPCI?tab=readme-ov-file#storageata-pci
# https://debian.pkgs.org/12/debian-main-amd64/linux-image-6.1.0-18-cloud-amd64_6.1.76-1_amd64.deb.html # https://debian.pkgs.org/12/debian-main-amd64/linux-image-6.1.0-18-cloud-amd64_6.1.76-1_amd64.deb.html
# 以下是 debian-installer 有的驱动,这些驱动云内核不一定都有,(+)表示有 # https://deb.debian.org/debian/pool/main/l/linux-signed-amd64/
# scsi-core-modules 是 ata-modules 的依赖,包含 sd_mod.ko(+) scsi_mod.ko(+) # https://deb.debian.org/debian/dists/bookworm/main/debian-installer/binary-all/Packages.xz
# ata-modules 是下方模块的依赖Priority 是 optional。只有 ata_generic.ko(+) 和 libata.ko(+) 两个驱动 # https://deb.debian.org/debian/dists/bookworm/main/debian-installer/binary-amd64/Packages.xz
# pata-modules 里面的驱动都是 pata_ 开头 # 以下是 debian-installer 有的驱动,这些驱动云内核不一定都有,(+)表示云内核有
# 但只有 pata_legacy.ko(+) 在云内核中 # scsi-core-modules 默认安装(不用修改),是 ata-modules 的依赖
# sata-modules 里面的驱动大部分是 sata_ 开头的,其他重要的还有 ahci.ko libahci.ko ata_piix.ko(+) # 包含 sd_mod.ko(+) scsi_mod.ko(+) scsi_transport_fc.ko(+) scsi_transport_sas.ko(+) scsi_transport_spi.ko(+)
# ata-modules 默认可选(改成必装),是下方模块的依赖。只有 ata_generic.ko(+) 和 libata.ko(+) 两个驱动
# pata-modules 默认安装(改成可选),里面的驱动都是 pata_ 开头,但只有 pata_legacy.ko(+) 在云内核中
# sata-modules 默认安装(改成可选),里面的驱动大部分是 sata_ 开头的,其他重要的还有 ahci.ko libahci.ko ata_piix.ko(+)
# 云内核没有 sata 模块,也没有内嵌,有一个 CONFIG_SATA_HOST=ylibata-$(CONFIG_SATA_HOST) += libata-sata.o # 云内核没有 sata 模块,也没有内嵌,有一个 CONFIG_SATA_HOST=ylibata-$(CONFIG_SATA_HOST) += libata-sata.o
# scsi-modules 包含 virtio_scsi.ko(+) virtio_blk.ko(+) # scsi-modules 默认安装(改成可选),包含 nvme.ko(+) 和各种虚拟化驱动(+)
download_and_extract_udeb() { download_and_extract_udeb() {
package=$1 package=$1
@ -2127,38 +2150,12 @@ EOF
} }
# 不用在 windows 判断是哪种硬盘控制器,因为 256M 运行 windows 只可能是 xp而脚本本来就不支持 xp # 不用在 windows 判断是哪种硬盘控制器,因为 256M 运行 windows 只可能是 xp而脚本本来就不支持 xp
get_disk_controller() {
(
cd "$(readlink -f /sys/block/$xda)"
while ! [ "$(pwd)" = / ]; do
if [ -d driver ]; then
basename "$(readlink -f driver)"
fi
cd ..
done
)
}
can_use_cloud_kernel() {
# xen 是 vbd
# 有些虚拟机用了 ahci但云内核没有 ahci 驱动
# shellcheck disable=SC2317
get_disk_controller | grep -Ewq \
'ata_generic|ata_piix|pata_legacy|nvme|virtio_blk|virtio_scsi|vbd|hv_storvsc|vmw_pvscsi'
}
# 在 debian installer 中判断能否用云内核 # 在 debian installer 中判断能否用云内核
cat <<EOF >can_use_cloud_kernel.sh create_can_use_cloud_kernel_sh can_use_cloud_kernel.sh
get_disk_controller(){
$(get_function_content get_disk_controller)
}
can_use_cloud_kernel(){ # 可以节省一点内存?
$(get_function_content can_use_cloud_kernel) echo 'export DEBCONF_DROP_TRANSLATIONS=1' |
} insert_into_file lib/debian-installer/menu before 'exec debconf'
can_use_cloud_kernel
EOF
# 提前下载 fdisk # 提前下载 fdisk
# 因为 fdisk-udeb 包含 fdisk 和 sfdisk提前下载可减少占用 # 因为 fdisk-udeb 包含 fdisk 和 sfdisk提前下载可减少占用
@ -2177,47 +2174,53 @@ EOF
for driver in $(get_disk_controller); do for driver in $(get_disk_controller); do
echo "using driver: $driver" echo "using driver: $driver"
case $driver in case $driver in
# xen 是 vbd nvme | virtio_blk | virtio_scsi | xen_blkfront | xen_scsifront | hv_storvsc | vmw_pvscsi) extra_drivers+=" $driver" ;;
nvme | virtio_blk | virtio_scsi | vbd | hv_storvsc | vmw_pvscsi) extra_drivers+=" $driver" ;; pata_legacy) sed -i '/^pata-modules/d' $net_retriever ;; # 属于 pata-modules
pata_legacy) sed -i '/^pata-modules/d' $net_retriever ;; ata_piix) sed -i '/^sata-modules/d' $net_retriever ;; # 属于 sata-modules
pata_* | sata_* | ahci) error_and_exit "Cloud kernel does not support this driver: $driver" ;; ata_generic) ;; # 属于 ata-modules不用处理因为我们设置强制安装了 ata-modules
esac esac
done done
# extra drivers # extra drivers
# 先不管 xen vmware # xen 还需要以下两个?
# kernel/drivers/xen/xen-scsiback.ko
# kernel/drivers/block/xen-blkback/xen-blkback.ko
# 但反查也找不到 curl https://deb.debian.org/debian/dists/bookworm/main/Contents-udeb-amd64.gz | zcat | grep xen
if [ -n "$extra_drivers" ]; then if [ -n "$extra_drivers" ]; then
mkdir_clear $tmp/scsi mkdir_clear $tmp/scsi
download_and_extract_udeb scsi-modules-$kver-di $tmp/scsi download_and_extract_udeb scsi-modules-$kver-di $tmp/scsi
udeb_drivers_dir=$tmp/scsi/lib/modules/$kver/kernel/drivers
( (
cd lib/modules/*/kernel/drivers/ cd lib/modules/*/kernel/drivers/
mkdir -p block scsi nvme/host
for driver in $extra_drivers; do for driver in $extra_drivers; do
echo "adding driver: $driver" echo "adding driver: $driver"
case $driver in case $driver in
# debian 模块没有压缩
# kali 模块有压缩
# 因此要有 *
nvme) nvme)
mkdir -p nvme/host cp -fv $udeb_drivers_dir/nvme/host/nvme.ko* nvme/host/
cp -f $tmp/scsi/lib/modules/*/kernel/drivers/nvme/host/nvme.ko nvme/host/ cp -fv $udeb_drivers_dir/nvme/host/nvme-core.ko* nvme/host/
cp -f $tmp/scsi/lib/modules/*/kernel/drivers/nvme/host/nvme-core.ko nvme/host/
;;
virtio_blk)
mkdir -p block
cp -f $tmp/scsi/lib/modules/*/kernel/drivers/block/virtio_blk.ko block/
;;
virtio_scsi)
mkdir -p scsi
cp -f $tmp/scsi/lib/modules/*/kernel/drivers/scsi/virtio_scsi.ko scsi/
;;
hv_storvsc)
mkdir -p scsi
cp -f $tmp/scsi/lib/modules/*/kernel/drivers/scsi/hv_storvsc.ko scsi/
cp -f $tmp/scsi/lib/modules/*/kernel/drivers/scsi/scsi_transport_fc.ko scsi/
;; ;;
virtio_blk) cp -fv $udeb_drivers_dir/block/virtio_blk.ko* block/ ;;
virtio_scsi) cp -fv $udeb_drivers_dir/scsi/virtio_scsi.ko* scsi/ ;;
# xen 的横杠特别不同
xen_blkfront) cp -fv $udeb_drivers_dir/block/xen-blkfront.ko* block/ ;;
xen_scsifront) cp -fv $udeb_drivers_dir/scsi/xen-scsifront.ko* scsi/ ;;
hv_storvsc) cp -fv $udeb_drivers_dir/scsi/hv_storvsc.ko* scsi/ ;;
vmw_pvscsi) cp -fv $udeb_drivers_dir/scsi/vmw_pvscsi.ko* scsi/ ;;
esac esac
done done
) )
fi fi
fi fi
# amd64)
# level1=737 # MT=754108, qemu: -m 780
# level2=424 # MT=433340, qemu: -m 460
# min=316 # MT=322748, qemu: -m 350
# 将 use_level 2 9 修改为 use_level 1 # 将 use_level 2 9 修改为 use_level 1
# x86 use_level 2 会出现 No root file system is defined. # x86 use_level 2 会出现 No root file system is defined.
# arm 即使 use_level 1 也会出现 No root file system is defined. # arm 即使 use_level 1 也会出现 No root file system is defined.
@ -2246,6 +2249,58 @@ 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_controller() {
# 有以下结果组合出现
# sd_mod
# virtio_blk
# virtio_scsi
# virtio_pci
# pcieport
# xen_blkfront
# ahci
# nvme
(
cd "$(readlink -f /sys/block/$xda)"
while ! [ "$(pwd)" = / ]; do
if [ -d driver ]; then
if [ -d driver/module ]; then
# 显示全名,例如 xen_blkfront sd_mod
# 但 ahci 没有这个文件,所以 else 不能省略
basename "$(readlink -f driver/module)"
else
# 不显示全名,例如 vbd sd
basename "$(readlink -f driver)"
fi
fi
cd ..
done
)
}
can_use_cloud_kernel() {
# 有些虚拟机用了 ahci但云内核没有 ahci 驱动
# shellcheck disable=SC2317
get_disk_controller | grep -Ewq \
'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.*'
}
create_can_use_cloud_kernel_sh() {
cat <<EOF >$1
get_disk_controller(){
$(get_function_content get_disk_controller)
}
can_use_cloud_kernel(){
$(get_function_content can_use_cloud_kernel)
}
xda=\$1
can_use_cloud_kernel
EOF
}
mod_initrd_alpine() { mod_initrd_alpine() {
# hack 1 virt 内核添加 ipv6 模块 # hack 1 virt 内核添加 ipv6 模块
if virt_dir=$(ls -d $tmp_dir/lib/modules/*-virt 2>/dev/null); then if virt_dir=$(ls -d $tmp_dir/lib/modules/*-virt 2>/dev/null); then
@ -2350,6 +2405,15 @@ EOF
chmod a+x \$sysroot/etc/local.d/trans.start chmod a+x \$sysroot/etc/local.d/trans.start
ln -s /etc/init.d/local \$sysroot/etc/runlevels/default/ ln -s /etc/init.d/local \$sysroot/etc/runlevels/default/
EOF EOF
# 判断云镜像 debain 能否用云内核
if is_distro_like_debian; then
create_can_use_cloud_kernel_sh can_use_cloud_kernel.sh
insert_into_file init before '^exec (/bin/busybox )?switch_root' <<EOF
cp /can_use_cloud_kernel.sh \$sysroot/
chmod a+x \$sysroot/can_use_cloud_kernel.sh
EOF
fi
} }
mod_initrd() { mod_initrd() {
@ -2381,16 +2445,32 @@ mod_initrd() {
curl -Lo $tmp_dir/alpine-network.sh $confhome/alpine-network.sh curl -Lo $tmp_dir/alpine-network.sh $confhome/alpine-network.sh
if is_distro_like_debian $nextos_distro; then if is_distro_like_debian $nextos_distro; then
mod_initrd_debian mod_initrd_debian_kali
else else
mod_initrd_$nextos_distro mod_initrd_$nextos_distro
fi fi
# alpine live 不精简 initrd
# 因为不知道用户想干什么,可能会用到精简的文件
if is_virt && ! is_alpine_live; then
remove_useless_initrd_files
fi
# 重建
# 注意要用 cpio -H newc 不要用 cpio -c ,不同版本的 -c 作用不一样,很坑
# -c Use the old portable (ASCII) archive format
# -c Identical to "-H newc", use the new (SVR4)
# portable format.If you wish the old portable
# (ASCII) archive format, use "-H odc" instead.
find . | cpio --quiet -o -H newc | gzip -1 >/reinstall-initrd
cd - >/dev/null
}
remove_useless_initrd_files() {
# 显示精简前的大小 # 显示精简前的大小
du -sh . du -sh .
# 删除 initrd 里面没用的文件/驱动 # 删除 initrd 里面没用的文件/驱动
if is_virt && ! is_alpine_live; then
rm -rf bin/brltty rm -rf bin/brltty
rm -rf etc/brltty rm -rf etc/brltty
rm -rf sbin/wpa_supplicant rm -rf sbin/wpa_supplicant
@ -2434,19 +2514,9 @@ mod_initrd() {
rm -rf $item rm -rf $item
done done
) )
fi
# 显示精简后的大小 # 显示精简后的大小
du -sh . du -sh .
# 重建
# 注意要用 cpio -H newc 不要用 cpio -c ,不同版本的 -c 作用不一样,很坑
# -c Use the old portable (ASCII) archive format
# -c Identical to "-H newc", use the new (SVR4)
# portable format.If you wish the old portable
# (ASCII) archive format, use "-H odc" instead.
find . | cpio --quiet -o -H newc | gzip -1 >/reinstall-initrd
cd - >/dev/null
} }
# 脚本入口 # 脚本入口
@ -2550,8 +2620,9 @@ tmp=/reinstall-tmp
mkdir_clear "$tmp" mkdir_clear "$tmp"
# 强制忽略/强制添加 --ci 参数 # 强制忽略/强制添加 --ci 参数
# debian 不强制忽略 ci 留作测试
case "$distro" in case "$distro" in
dd | windows | netboot.xyz | debian | kali | alpine | arch | gentoo) dd | windows | netboot.xyz | kali | alpine | arch | gentoo)
if is_use_cloud_image; then if is_use_cloud_image; then
echo "ignored --ci" echo "ignored --ci"
cloud_image=0 cloud_image=0

View File

@ -1689,6 +1689,36 @@ EOF
fi fi
} }
get_axx64() {
case "$(uname -m)" in
x86_64) echo amd64 ;;
aarch_64) echo arm64 ;;
esac
}
cp_resolv_conf() {
os_dir=$1
# -e / -f 坏软连接,返回 false
# -L 坏软连接,返回 true
if { [ -e $os_dir/etc/resolv.conf ] || [ -L $os_dir/etc/resolv.conf ]; } &&
! { [ -e $os_dir/etc/resolv.conf.orig ] || [ -L $os_dir/etc/resolv.conf.orig ]; }; then
mv $os_dir/etc/resolv.conf $os_dir/etc/resolv.conf.orig
fi
cp -f /etc/resolv.conf $os_dir/etc/resolv.conf
}
rm_resolv_conf() {
os_dir=$1
rm -f $os_dir/etc/resolv.conf $os_dir/etc/resolv.conf.orig
}
restore_resolv_conf() {
os_dir=$1
if [ -f $os_dir/etc/resolv.conf.orig ]; then
mv -f $os_dir/etc/resolv.conf.orig $os_dir/etc/resolv.conf
fi
}
modify_linux() { modify_linux() {
os_dir=$1 os_dir=$1
@ -1738,20 +1768,38 @@ EOF
# 修复 onlink 网关 # 修复 onlink 网关
add_onlink_script_if_need add_onlink_script_if_need
if grep -E '^(10|11)' $os_dir/etc/debian_version; then
mv $os_dir/etc/resolv.conf $os_dir/etc/resolv.conf.orig
cp -f /etc/resolv.conf $os_dir/etc/resolv.conf
mount_pseudo_fs $os_dir mount_pseudo_fs $os_dir
# 检测机器是否能用 cloud 内核
axx64=$(get_axx64)
# shellcheck source=/dev/null
if ls $os_dir/boot/vmlinuz-*-cloud-$axx64 2>/dev/null && ! sh /can_use_cloud_kernel.sh $xda; then
cp_resolv_conf $os_dir
chroot $os_dir apt update
DEBIAN_FRONTEND=noninteractive chroot $os_dir apt install -y linux-image-$axx64
# 标记云内核包
# apt-mark showmanual 结果为空,返回值也是 0
if pkgs=$(chroot $os_dir apt-mark showmanual linux-*-cloud-$axx64 | grep .); then
chroot $os_dir apt-mark auto $pkgs
# 使用 autoremove
chroot_apt_autoremove $os_dir
fi
restore_resolv_conf $os_dir
fi
if grep -E '^(10|11)' $os_dir/etc/debian_version; then
cp_resolv_conf $os_dir
chroot $os_dir apt update chroot $os_dir apt update
if true; then if true; then
# 将 debian 10/11 设置为 12 一样的网络管理器 # 将 debian 10/11 设置为 12 一样的网络管理器
# 可解决 ifupdown dhcp 不支持 24位掩码+不规则网关的问题 # 可解决 ifupdown dhcp 不支持 24位掩码+不规则网关的问题
chroot $os_dir apt update
DEBIAN_FRONTEND=noninteractive chroot $os_dir apt install -y netplan.io DEBIAN_FRONTEND=noninteractive chroot $os_dir apt install -y netplan.io
chroot $os_dir systemctl disable networking resolvconf chroot $os_dir systemctl disable networking resolvconf
chroot $os_dir systemctl enable systemd-networkd systemd-resolved chroot $os_dir systemctl enable systemd-networkd systemd-resolved
rm -f $os_dir/etc/resolv.conf $os_dir/etc/resolv.conf.orig rm_resolv_conf $os_dir
ln -sf ../run/systemd/resolve/stub-resolv.conf $os_dir/etc/resolv.conf ln -sf ../run/systemd/resolve/stub-resolv.conf $os_dir/etc/resolv.conf
insert_into_file $os_dir/etc/cloud/cloud.cfg.d/99_fallback.cfg after '#cloud-config' <<EOF insert_into_file $os_dir/etc/cloud/cloud.cfg.d/99_fallback.cfg after '#cloud-config' <<EOF
system_info: system_info:
@ -1762,10 +1810,9 @@ EOF
else else
# debian 10/11 默认不支持 rdnss要安装 rdnssd 或者 nm # debian 10/11 默认不支持 rdnss要安装 rdnssd 或者 nm
chroot $os_dir apt update
DEBIAN_FRONTEND=noninteractive chroot $os_dir apt install -y rdnssd DEBIAN_FRONTEND=noninteractive chroot $os_dir apt install -y rdnssd
# 不会自动建立链接,因此不能删除 # 不会自动建立链接,因此不能删除
mv $os_dir/etc/resolv.conf.orig $os_dir/etc/resolv.conf restore_resolv_conf $os_dir
fi fi
fi fi
fi fi
@ -2012,6 +2059,15 @@ yum() {
fi fi
} }
chroot_apt_autoremove() {
os_dir=$1
conf=$os_dir/etc/apt/apt.conf.d/01autoremove
sed -i.orig 's/VersionedKernelPackages/x/; s/NeverAutoRemove/x/' $conf
DEBIAN_FRONTEND=noninteractive chroot $os_dir apt autoremove --purge -y
mv $conf.orig $conf
}
install_qcow_by_copy() { install_qcow_by_copy() {
mount_nouuid() { mount_nouuid() {
case "$fs" in case "$fs" in
@ -2289,15 +2345,12 @@ EOF
# 标记旧内核包 # 标记旧内核包
# 注意排除 linux-base # 注意排除 linux-base
pkgs=$(chroot $os_dir apt-mark showmanual linux-* | grep -E 'generic|virtual|kvm' | grep -v $flavor) if pkgs=$(chroot $os_dir apt-mark showmanual linux-* | grep -E 'generic|virtual|kvm' | grep -v $flavor); then
chroot $os_dir apt-mark auto $pkgs chroot $os_dir apt-mark auto $pkgs
# 使用 autoremove # 使用 autoremove
conf=$os_dir/etc/apt/apt.conf.d/01autoremove chroot_apt_autoremove $os_dir
sed -i.orig 's/VersionedKernelPackages/x/; s/NeverAutoRemove/x/' $conf fi
DEBIAN_FRONTEND=noninteractive chroot $os_dir apt autoremove --purge -y
mv $conf.orig $conf
# 安装 bios 引导 # 安装 bios 引导
if ! is_efi; then if ! is_efi; then
chroot $os_dir grub-install /dev/$xda chroot $os_dir grub-install /dev/$xda
@ -2345,7 +2398,7 @@ EOF
sed -i '/[[:space:]]\/boot\/efi[[:space:]]/d' $os_dir/etc/fstab sed -i '/[[:space:]]\/boot\/efi[[:space:]]/d' $os_dir/etc/fstab
fi fi
mv $os_dir/etc/resolv.conf.orig $os_dir/etc/resolv.conf restore_resolv_conf $os_dir
} }
case "$distro" in case "$distro" in