core: 优化代码
This commit is contained in:
parent
ae012a79f1
commit
c21bf52d41
18
reinstall.sh
18
reinstall.sh
@ -1061,6 +1061,10 @@ setos() {
|
||||
if is_efi; then
|
||||
install_pkg hexdump $img_type
|
||||
|
||||
# openwrt 镜像 efi part type 不是 esp
|
||||
# 因此改成检测 fat?
|
||||
# https://downloads.openwrt.org/releases/23.05.3/targets/x86/64/openwrt-23.05.3-x86-64-generic-ext4-combined-efi.img.gz
|
||||
|
||||
# od 在 coreutils 里面,好像要配合 tr 才能删除空格
|
||||
# hexdump 在 util-linux / bsdmainutils 里面
|
||||
# xxd 要单独安装,el 在 vim-common 里面
|
||||
@ -2186,7 +2190,14 @@ build_extra_cmdline() {
|
||||
}
|
||||
|
||||
echo_tmp_ttys() {
|
||||
if false; then
|
||||
curl -L $confhome/ttys.sh | sh -s "console="
|
||||
else
|
||||
case "$basearch" in
|
||||
x86_64) echo "console=ttyS0,115200n8 console=tty0" ;;
|
||||
aarch64) echo "console=ttyS0,115200n8 console=ttyAMA0,115200n8 console=tty0" ;;
|
||||
esac
|
||||
fi
|
||||
}
|
||||
|
||||
get_entry_name() {
|
||||
@ -2229,11 +2240,10 @@ build_nextos_cmdline() {
|
||||
else
|
||||
# debian arm 在没有ttyAMA0的机器上(aws t4g),最少要设置一个tty才能启动
|
||||
# 只设置tty0也行,但安装过程ttyS0没有显示
|
||||
nextos_cmdline+=" console=ttyAMA0,115200 console=ttyS0,115200 console=tty0"
|
||||
nextos_cmdline+=" $(echo_tmp_ttys)"
|
||||
fi
|
||||
else
|
||||
# nextos_cmdline+=" $(echo_tmp_ttys)"
|
||||
nextos_cmdline+=" console=ttyAMA0,115200 console=ttyS0,115200 console=tty0"
|
||||
nextos_cmdline+=" $(echo_tmp_ttys)"
|
||||
fi
|
||||
# nextos_cmdline+=" mem=256M"
|
||||
# nextos_cmdline+=" lowmem=+1"
|
||||
@ -2279,9 +2289,9 @@ mod_initrd_debian_kali() {
|
||||
|
||||
# hack 2
|
||||
# 修改 /var/lib/dpkg/info/netcfg.postinst 运行我们的脚本
|
||||
# shellcheck disable=SC1091,SC2317
|
||||
netcfg() {
|
||||
#!/bin/sh
|
||||
# shellcheck source=/dev/null
|
||||
. /usr/share/debconf/confmodule
|
||||
db_progress START 0 5 debian-installer/netcfg/title
|
||||
|
||||
|
181
trans.sh
181
trans.sh
@ -3,7 +3,7 @@
|
||||
# shellcheck disable=SC2086,SC3047,SC3036,SC3010,SC3001
|
||||
# alpine 默认使用 busybox ash
|
||||
|
||||
# 命令出错终止运行,将进入到登录界面,防止失联
|
||||
# 出错后停止运行,将进入到登录界面,防止失联
|
||||
set -eE
|
||||
|
||||
# debian 安装版、ubuntu 安装版、el/ol 安装版不使用该密码
|
||||
@ -35,12 +35,7 @@ trap_err() {
|
||||
}
|
||||
|
||||
is_run_from_locald() {
|
||||
[[ "$0" = /etc/local.d/* ]]
|
||||
}
|
||||
|
||||
should_hold_after_boot() {
|
||||
# shellcheck disable=SC2154
|
||||
[ "$hold" = 1 ] # && is_run_from_locald
|
||||
[[ "$0" = "/etc/local.d/*" ]]
|
||||
}
|
||||
|
||||
add_community_repo() {
|
||||
@ -301,13 +296,6 @@ get_all_disks() {
|
||||
ls /sys/block/ | grep -Ev '^(loop|sr|nbd)'
|
||||
}
|
||||
|
||||
setup_tty_and_log() {
|
||||
# 显示输出到前台
|
||||
# script -f /dev/tty0
|
||||
dev_ttys=$(get_ttys /dev/)
|
||||
exec > >(tee -a $dev_ttys /reinstall.log) 2>&1
|
||||
}
|
||||
|
||||
extract_env_from_cmdline() {
|
||||
# 提取 finalos/extra 到变量
|
||||
for prefix in finalos extra; do
|
||||
@ -3980,74 +3968,32 @@ EOF
|
||||
cat "$grub_cfg"
|
||||
}
|
||||
|
||||
# 脚本入口
|
||||
# debian initrd 会寻找 main
|
||||
# 并调用本文件的 create_ifupdown_config 方法
|
||||
: main
|
||||
trans() {
|
||||
mod_motd
|
||||
cat /proc/cmdline
|
||||
clear_previous
|
||||
add_community_repo
|
||||
|
||||
# 无参数运行
|
||||
# 复制本脚本到 /trans.sh,除非路径相同
|
||||
# 用于打印错误或者再次运行
|
||||
if ! [ "$(readlink -f "$0")" = /trans.sh ]; then
|
||||
cp -f "$0" /trans.sh
|
||||
fi
|
||||
|
||||
# 还原改动,不然本脚本会被复制到新系统
|
||||
rm -f /etc/local.d/trans.start
|
||||
rm -f /etc/runlevels/default/local
|
||||
|
||||
trap 'trap_err $LINENO $?' ERR
|
||||
extract_env_from_cmdline
|
||||
|
||||
# 带参数运行,则重新下载脚本
|
||||
if [ "$1" = "update" ]; then
|
||||
# shellcheck disable=SC2154
|
||||
wget -O /trans.sh "$confhome/trans.sh"
|
||||
chmod +x /trans.sh
|
||||
exec /trans.sh
|
||||
fi
|
||||
|
||||
# 允许 ramdisk 使用所有内存,默认是 50%
|
||||
mount / -o remount,size=100%
|
||||
|
||||
# arm要手动从硬件同步时间,避免访问https出错
|
||||
# do 机器第二次运行会报错
|
||||
hwclock -s || true
|
||||
|
||||
# 设置密码,安装并打开 ssh
|
||||
echo "root:$PASSWORD" | chpasswd
|
||||
printf '\nyes' | setup-sshd
|
||||
|
||||
if should_hold_after_boot; then
|
||||
exit
|
||||
fi
|
||||
|
||||
mod_motd
|
||||
setup_tty_and_log
|
||||
cat /proc/cmdline
|
||||
clear_previous
|
||||
add_community_repo
|
||||
|
||||
# 需要在重新分区之前,找到主硬盘
|
||||
# 重新运行脚本时,可指定 xda
|
||||
# xda=sda ash trans.start
|
||||
if [ -z "$xda" ]; then
|
||||
# 需要在重新分区之前,找到主硬盘
|
||||
# 重新运行脚本时,可指定 xda
|
||||
# xda=sda ash trans.start
|
||||
if [ -z "$xda" ]; then
|
||||
find_xda
|
||||
fi
|
||||
fi
|
||||
|
||||
if [ "$distro" != "alpine" ]; then
|
||||
if [ "$distro" != "alpine" ]; then
|
||||
setup_nginx_if_enough_ram
|
||||
setup_udev_util_linux
|
||||
fi
|
||||
fi
|
||||
|
||||
# dd qemu 切换成云镜像模式,暂时没用到
|
||||
if [ "$distro" = "dd" ] && [ "$img_type" = "qemu" ]; then
|
||||
# dd qemu 切换成云镜像模式,暂时没用到
|
||||
if [ "$distro" = "dd" ] && [ "$img_type" = "qemu" ]; then
|
||||
# 移到 reinstall.sh ?
|
||||
distro=any
|
||||
cloud_image=1
|
||||
fi
|
||||
fi
|
||||
|
||||
if is_use_cloud_image; then
|
||||
if is_use_cloud_image; then
|
||||
case "$img_type" in
|
||||
qemu)
|
||||
create_part
|
||||
@ -4076,7 +4022,7 @@ if is_use_cloud_image; then
|
||||
modify_os_on_disk linux
|
||||
;;
|
||||
esac
|
||||
elif [ "$distro" = "dd" ]; then
|
||||
elif [ "$distro" = "dd" ]; then
|
||||
case "$img_type" in
|
||||
gzip | xz)
|
||||
dd_gzip_xz
|
||||
@ -4085,7 +4031,7 @@ elif [ "$distro" = "dd" ]; then
|
||||
qemu) # dd qemu 不可能到这里,因为上面已处理
|
||||
;;
|
||||
esac
|
||||
else
|
||||
else
|
||||
# 安装模式
|
||||
case "$distro" in
|
||||
alpine)
|
||||
@ -4108,22 +4054,91 @@ else
|
||||
esac
|
||||
;;
|
||||
esac
|
||||
fi
|
||||
fi
|
||||
|
||||
# 需要用到 lsblk efibootmgr ,只要 1M 左右容量
|
||||
# 因此 alpine 不单独处理
|
||||
if is_efi; then
|
||||
# 需要用到 lsblk efibootmgr ,只要 1M 左右容量
|
||||
# 因此 alpine 不单独处理
|
||||
if is_efi; then
|
||||
del_invalid_efi_entry
|
||||
add_fallback_efi_to_nvram
|
||||
fi
|
||||
|
||||
echo 'done'
|
||||
# 让 web 输出全部内容
|
||||
sleep 5
|
||||
}
|
||||
|
||||
# 脚本入口
|
||||
# debian initrd 会寻找 main
|
||||
# 并调用本文件的 create_ifupdown_config 方法
|
||||
: main
|
||||
|
||||
# 复制脚本
|
||||
# 用于打印错误或者再次运行
|
||||
# 路径相同则不用复制
|
||||
# 重点:要在删除脚本之前复制
|
||||
if ! [ "$(readlink -f "$0")" = /trans.sh ]; then
|
||||
cp -f "$0" /trans.sh
|
||||
fi
|
||||
trap 'trap_err $LINENO $?' ERR
|
||||
|
||||
# 删除本脚本,不然会被复制到新系统
|
||||
rm -f /etc/local.d/trans.start
|
||||
rm -f /etc/runlevels/default/local
|
||||
|
||||
# 提取变量
|
||||
extract_env_from_cmdline
|
||||
|
||||
# 带参数运行部分
|
||||
# 重新下载并 exec 运行新脚本
|
||||
if [ "$1" = "update" ]; then
|
||||
# shellcheck disable=SC2154
|
||||
wget -O /trans.sh "$confhome/trans.sh"
|
||||
chmod +x /trans.sh
|
||||
exec /trans.sh
|
||||
fi
|
||||
|
||||
sync
|
||||
echo 'done'
|
||||
# 无参数运行部分
|
||||
# 允许 ramdisk 使用所有内存,默认是 50%
|
||||
mount / -o remount,size=100%
|
||||
|
||||
# arm要手动从硬件同步时间,避免访问https出错
|
||||
# do 机器第二次运行会报错
|
||||
hwclock -s || true
|
||||
|
||||
# 设置密码,安装并打开 ssh
|
||||
echo "root:$PASSWORD" | chpasswd
|
||||
printf '\nyes' | setup-sshd
|
||||
|
||||
# shellcheck disable=SC2154
|
||||
if [ "$hold" = 1 ]; then
|
||||
if is_run_from_locald; then
|
||||
exit
|
||||
fi
|
||||
fi
|
||||
|
||||
# 正式运行重装
|
||||
# shellcheck disable=SC2046,SC2194
|
||||
case 1 in
|
||||
1)
|
||||
# ChatGPT 说这种性能最高
|
||||
exec > >(exec tee -a $(get_ttys /dev/) /reinstall.log) 2>&1
|
||||
trans
|
||||
;;
|
||||
2)
|
||||
exec > >(tee -a $(get_ttys /dev/) /reinstall.log) 2>&1
|
||||
trans
|
||||
;;
|
||||
3)
|
||||
trans 2>&1 | tee -a $(get_ttys /dev/) /reinstall.log
|
||||
;;
|
||||
esac
|
||||
|
||||
if [ "$hold" = 2 ]; then
|
||||
exit
|
||||
fi
|
||||
|
||||
cd /
|
||||
# 让 web 输出全部内容
|
||||
sleep 5
|
||||
# swapoff -a
|
||||
# umount ?
|
||||
sync
|
||||
reboot
|
||||
|
Loading…
Reference in New Issue
Block a user