redhat: 支持安装 oracle linux
This commit is contained in:
parent
1979233c02
commit
993b165959
@ -26,7 +26,7 @@ One-click reinstallation script
|
|||||||
| Alpine | 256 MB | 1 GB |
|
| Alpine | 256 MB | 1 GB |
|
||||||
| Debian / Kali | 256 MB | 1~1.5 GB ^ |
|
| Debian / Kali | 256 MB | 1~1.5 GB ^ |
|
||||||
| Ubuntu | 512 MB \* | 2 GB |
|
| Ubuntu | 512 MB \* | 2 GB |
|
||||||
| CentOS / Alma / Rocky | 512 MB \* | 5 GB |
|
| CentOS / Alma / Rocky / Oracle | 512 MB \* | 5 GB |
|
||||||
| Fedora | 512 MB \* | 5 GB |
|
| Fedora | 512 MB \* | 5 GB |
|
||||||
| openSUSE | 512 MB \* | 5 GB |
|
| openSUSE | 512 MB \* | 5 GB |
|
||||||
| Arch | 512 MB | 5 GB |
|
| Arch | 512 MB | 5 GB |
|
||||||
@ -85,6 +85,7 @@ All features can be used on both Linux and Windows.
|
|||||||
|
|
||||||
```bash
|
```bash
|
||||||
bash reinstall.sh centos 7|8|9 (8|9 for the stream version)
|
bash reinstall.sh centos 7|8|9 (8|9 for the stream version)
|
||||||
|
oracle 7|8|9
|
||||||
alma 8|9
|
alma 8|9
|
||||||
rocky 8|9
|
rocky 8|9
|
||||||
fedora 38|39|40
|
fedora 38|39|40
|
||||||
|
@ -26,7 +26,7 @@
|
|||||||
| Alpine | 256 MB | 1 GB |
|
| Alpine | 256 MB | 1 GB |
|
||||||
| Debian / Kali | 256 MB | 1~1.5 GB ^ |
|
| Debian / Kali | 256 MB | 1~1.5 GB ^ |
|
||||||
| Ubuntu | 512 MB \* | 2 GB |
|
| Ubuntu | 512 MB \* | 2 GB |
|
||||||
| CentOS / Alma / Rocky | 512 MB \* | 5 GB |
|
| CentOS / Alma / Rocky / Oracle | 512 MB \* | 5 GB |
|
||||||
| Fedora | 512 MB \* | 5 GB |
|
| Fedora | 512 MB \* | 5 GB |
|
||||||
| openSUSE | 512 MB \* | 5 GB |
|
| openSUSE | 512 MB \* | 5 GB |
|
||||||
| Arch | 512 MB | 5 GB |
|
| Arch | 512 MB | 5 GB |
|
||||||
@ -85,6 +85,7 @@ certutil -urlcache -f -split https://mirror.ghproxy.com/https://raw.githubuserco
|
|||||||
|
|
||||||
```bash
|
```bash
|
||||||
bash reinstall.sh centos 7|8|9 (8|9 为 stream 版本)
|
bash reinstall.sh centos 7|8|9 (8|9 为 stream 版本)
|
||||||
|
oracle 7|8|9
|
||||||
alma 8|9
|
alma 8|9
|
||||||
rocky 8|9
|
rocky 8|9
|
||||||
fedora 38|39|40
|
fedora 38|39|40
|
||||||
|
@ -16,8 +16,11 @@ chpasswd:
|
|||||||
password: 123@@@
|
password: 123@@@
|
||||||
type: text
|
type: text
|
||||||
runcmd:
|
runcmd:
|
||||||
# opensuse tumbleweed 有 /etc/ssh/sshd_config.d/ 文件夹,没有 /etc/ssh/sshd_config,有/usr/etc/ssh/sshd_config
|
# opensuse tumbleweed 镜像有 /etc/ssh/sshd_config.d/ 文件夹,没有 /etc/ssh/sshd_config,有/usr/etc/ssh/sshd_config
|
||||||
- grep 'Include.*/etc/ssh/sshd_config.d' /etc/ssh/sshd_config && mkdir -p /etc/ssh/sshd_config.d && echo "PermitRootLogin yes" >/etc/ssh/sshd_config.d/01-permitrootlogin.conf || echo "PermitRootLogin yes" >>/etc/ssh/sshd_config
|
# opensuse tumbleweed cloud-init 直接创建并写入 /etc/ssh/sshd_config,造成默认配置丢失
|
||||||
|
# 下面这行删除 clout-init 创建的 sshd_config
|
||||||
|
- test $(wc -l </etc/ssh/sshd_config) -le 1 && cat /etc/ssh/sshd_config >>/etc/ssh/sshd_config.d/50-cloud-init.conf && rm -f /etc/ssh/sshd_config
|
||||||
|
- echo "PermitRootLogin yes" >/etc/ssh/sshd_config.d/01-permitrootlogin.conf || sed -Ei 's/^#?PermitRootLogin.*/PermitRootLogin yes/' /etc/ssh/sshd_config
|
||||||
- systemctl restart sshd || systemctl restart ssh
|
- systemctl restart sshd || systemctl restart ssh
|
||||||
- touch /etc/cloud/cloud-init.disabled
|
- touch /etc/cloud/cloud-init.disabled
|
||||||
# ubuntu 镜像运行 echo -e '\nDone' ,-e 会被显示出来
|
# ubuntu 镜像运行 echo -e '\nDone' ,-e 会被显示出来
|
||||||
|
@ -52,7 +52,7 @@ if not errorlevel 1 (
|
|||||||
)
|
)
|
||||||
|
|
||||||
rem pkgs 改动了才重新运行 Cygwin 安装程序
|
rem pkgs 改动了才重新运行 Cygwin 安装程序
|
||||||
set pkgs="curl,cpio,p7zip,bind-utils,ipcalc,dos2unix,binutils"
|
set pkgs="curl,cpio,p7zip,bind-utils,ipcalc,dos2unix,binutils,jq"
|
||||||
set tags=%tmp%\cygwin-installed-!pkgs!
|
set tags=%tmp%\cygwin-installed-!pkgs!
|
||||||
if not exist !tags! (
|
if not exist !tags! (
|
||||||
rem win10 arm 支持运行 x86 软件
|
rem win10 arm 支持运行 x86 软件
|
||||||
|
38
reinstall.sh
38
reinstall.sh
@ -27,6 +27,7 @@ usage_and_exit() {
|
|||||||
fi
|
fi
|
||||||
cat <<EOF
|
cat <<EOF
|
||||||
Usage: $reinstall____ centos 7|8|9
|
Usage: $reinstall____ centos 7|8|9
|
||||||
|
oracle 7|8|9
|
||||||
alma 8|9
|
alma 8|9
|
||||||
rocky 8|9
|
rocky 8|9
|
||||||
fedora 38|39|40
|
fedora 38|39|40
|
||||||
@ -1050,10 +1051,30 @@ setos() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
setos_oracle() {
|
||||||
|
if is_use_cloud_image; then
|
||||||
|
# ci
|
||||||
|
install_pkg jq
|
||||||
|
mirror=https://yum.oracle.com
|
||||||
|
|
||||||
|
[ "$basearch" = aarch64 ] &&
|
||||||
|
template_prefix=ol${releasever}_${basearch}-cloud ||
|
||||||
|
template_prefix=ol${releasever}
|
||||||
|
curl -Lo $tmp/oracle.json $mirror/templates/OracleLinux/$template_prefix-template.json
|
||||||
|
dir=$(jq -r .base_url $tmp/oracle.json)
|
||||||
|
file=$(jq -r .kvm.image $tmp/oracle.json)
|
||||||
|
ci_image=$mirror$dir/$file
|
||||||
|
|
||||||
|
eval ${step}_img=${ci_image}
|
||||||
|
else
|
||||||
|
:
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
eval ${step}_distro=$distro
|
eval ${step}_distro=$distro
|
||||||
eval ${step}_releasever=$releasever
|
eval ${step}_releasever=$releasever
|
||||||
|
|
||||||
if is_distro_like_redhat $distro; then
|
if is_distro_like_redhat $distro && ! [ "$distro" = oracle ]; then
|
||||||
setos_redhat
|
setos_redhat
|
||||||
else
|
else
|
||||||
setos_$distro
|
setos_$distro
|
||||||
@ -1067,7 +1088,7 @@ setos() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
is_distro_like_redhat() {
|
is_distro_like_redhat() {
|
||||||
[ "$distro" = centos ] || [ "$distro" = alma ] || [ "$distro" = rocky ] || [ "$distro" = fedora ]
|
[ "$distro" = centos ] || [ "$distro" = alma ] || [ "$distro" = rocky ] || [ "$distro" = fedora ] || [ "$distro" = oracle ]
|
||||||
}
|
}
|
||||||
|
|
||||||
is_distro_like_debian() {
|
is_distro_like_debian() {
|
||||||
@ -1082,6 +1103,7 @@ verify_os_name() {
|
|||||||
|
|
||||||
for os in \
|
for os in \
|
||||||
'centos 7|8|9' \
|
'centos 7|8|9' \
|
||||||
|
'oracle 7|8|9' \
|
||||||
'alma 8|9' \
|
'alma 8|9' \
|
||||||
'rocky 8|9' \
|
'rocky 8|9' \
|
||||||
'fedora 38|39|40' \
|
'fedora 38|39|40' \
|
||||||
@ -1200,7 +1222,11 @@ install_pkg() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
is_need_epel_repo() {
|
is_need_epel_repo() {
|
||||||
[ "$pkg" = dpkg ] && { [ "$pkg_mgr" = yum ] || [ "$pkg_mgr" = dnf ]; }
|
case "$pkg" in
|
||||||
|
dpkg) [ "$pkg_mgr" = yum ] || [ "$pkg_mgr" = dnf ] ;;
|
||||||
|
jq) [ "$pkg_mgr" = yum ] ;; # el7/ol7
|
||||||
|
*) false ;;
|
||||||
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
add_epel_repo() {
|
add_epel_repo() {
|
||||||
@ -1292,7 +1318,7 @@ check_ram() {
|
|||||||
netboot.xyz) echo 0 ;;
|
netboot.xyz) echo 0 ;;
|
||||||
alpine | debian | kali | dd) echo 256 ;;
|
alpine | debian | kali | dd) echo 256 ;;
|
||||||
arch | gentoo | windows) echo 512 ;;
|
arch | gentoo | windows) echo 512 ;;
|
||||||
centos | alma | rocky | fedora | ubuntu) echo 1024 ;;
|
centos | alma | rocky | fedora | oracle | ubuntu) echo 1024 ;;
|
||||||
opensuse) echo -1 ;; # 没有安装模式
|
opensuse) echo -1 ;; # 没有安装模式
|
||||||
esac
|
esac
|
||||||
)
|
)
|
||||||
@ -1307,7 +1333,7 @@ check_ram() {
|
|||||||
|
|
||||||
has_cloud_image=$(
|
has_cloud_image=$(
|
||||||
case "$distro" in
|
case "$distro" in
|
||||||
centos | alma | rocky | fedora | debian | ubuntu | opensuse) echo true ;;
|
centos | alma | rocky | oracle | fedora | debian | ubuntu | opensuse) echo true ;;
|
||||||
netboot.xyz | alpine | dd | arch | gentoo | kali | windows) echo false ;;
|
netboot.xyz | alpine | dd | arch | gentoo | kali | windows) echo false ;;
|
||||||
esac
|
esac
|
||||||
)
|
)
|
||||||
@ -2510,7 +2536,7 @@ dd | windows | netboot.xyz | debian | kali | alpine | arch | gentoo)
|
|||||||
cloud_image=0
|
cloud_image=0
|
||||||
fi
|
fi
|
||||||
;;
|
;;
|
||||||
centos | alma | rocky | ubuntu | fedora | opensuse)
|
centos | alma | rocky | oracle | ubuntu | fedora | opensuse)
|
||||||
cloud_image=1
|
cloud_image=1
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
113
trans.sh
113
trans.sh
@ -334,6 +334,12 @@ umount_all() {
|
|||||||
|
|
||||||
# 可能脚本不是首次运行,先清理之前的残留
|
# 可能脚本不是首次运行,先清理之前的残留
|
||||||
clear_previous() {
|
clear_previous() {
|
||||||
|
if is_have_cmd vgchange; then
|
||||||
|
umount -R /os /nbd || true
|
||||||
|
vgchange -an
|
||||||
|
apk add device-mapper
|
||||||
|
dmsetup remove_all
|
||||||
|
fi
|
||||||
disconnect_qcow
|
disconnect_qcow
|
||||||
swapoff -a
|
swapoff -a
|
||||||
umount_all
|
umount_all
|
||||||
@ -1311,7 +1317,7 @@ create_part() {
|
|||||||
elif is_use_cloud_image; then
|
elif is_use_cloud_image; then
|
||||||
installer_part_size="$(get_ci_installer_part_size)"
|
installer_part_size="$(get_ci_installer_part_size)"
|
||||||
# 这几个系统不使用dd,而是复制文件
|
# 这几个系统不使用dd,而是复制文件
|
||||||
if [ "$distro" = centos ] || [ "$distro" = alma ] || [ "$distro" = rocky ] ||
|
if [ "$distro" = centos ] || [ "$distro" = alma ] || [ "$distro" = rocky ] || [ "$distro" = oracle ] ||
|
||||||
[ "$distro" = ubuntu ]; then
|
[ "$distro" = ubuntu ]; then
|
||||||
fs="$(get_os_fs)"
|
fs="$(get_os_fs)"
|
||||||
if is_efi; then
|
if is_efi; then
|
||||||
@ -1521,7 +1527,7 @@ create_cloud_init_network_config() {
|
|||||||
# centos7 不认识 static6,但可改成 static,作用相同
|
# centos7 不认识 static6,但可改成 static,作用相同
|
||||||
# https://github.com/canonical/cloud-init/commit/dacdd30080bd8183d1f1c1dc9dbcbc8448301529
|
# https://github.com/canonical/cloud-init/commit/dacdd30080bd8183d1f1c1dc9dbcbc8448301529
|
||||||
if [ -f /os/etc/system-release-cpe ] &&
|
if [ -f /os/etc/system-release-cpe ] &&
|
||||||
grep centos:7 /os/etc/system-release-cpe; then
|
grep -E 'centos:7|oracle:linux:7' /os/etc/system-release-cpe; then
|
||||||
type_ipv6_static=static
|
type_ipv6_static=static
|
||||||
else
|
else
|
||||||
type_ipv6_static=static6
|
type_ipv6_static=static6
|
||||||
@ -1728,7 +1734,7 @@ EOF
|
|||||||
|
|
||||||
# debian 网络问题
|
# debian 网络问题
|
||||||
# 注意 ubuntu 也有 /etc/debian_version
|
# 注意 ubuntu 也有 /etc/debian_version
|
||||||
if [ -f $os_dir/etc/debian_version ]; then
|
if false && [ "$distro" = debian ]; then
|
||||||
# 修复 onlink 网关
|
# 修复 onlink 网关
|
||||||
add_onlink_script_if_need
|
add_onlink_script_if_need
|
||||||
|
|
||||||
@ -1924,11 +1930,7 @@ disable_selinux_kdump() {
|
|||||||
releasever=$(awk -F: '{ print $5 }' <$os_dir/etc/system-release-cpe)
|
releasever=$(awk -F: '{ print $5 }' <$os_dir/etc/system-release-cpe)
|
||||||
|
|
||||||
if ! chroot $os_dir command -v grubby; then
|
if ! chroot $os_dir command -v grubby; then
|
||||||
if [ "$releasever" = 7 ]; then
|
yum install grubby
|
||||||
chroot $os_dir yum -y --disablerepo=* --enablerepo=base,updates grubby
|
|
||||||
else
|
|
||||||
chroot $os_dir dnf -y --disablerepo=* --enablerepo=baseos --setopt=install_weak_deps=False grubby
|
|
||||||
fi
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# selinux
|
# selinux
|
||||||
@ -1983,26 +1985,34 @@ disconnect_qcow() {
|
|||||||
get_os_fs() {
|
get_os_fs() {
|
||||||
case "$distro" in
|
case "$distro" in
|
||||||
ubuntu) echo ext4 ;;
|
ubuntu) echo ext4 ;;
|
||||||
centos | alma | rocky) echo xfs ;;
|
centos | alma | rocky | oracle) echo xfs ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
get_ci_installer_part_size() {
|
get_ci_installer_part_size() {
|
||||||
case "$distro" in
|
case "$distro" in
|
||||||
centos | alma | rocky) echo 2GiB ;;
|
centos | alma | rocky | oracle) echo 2GiB ;;
|
||||||
*) echo 1GiB ;;
|
*) echo 1GiB ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
install_qcow_by_copy() {
|
yum() {
|
||||||
yum() {
|
if [ "$distro" = oracle ]; then
|
||||||
|
if [ "$releasever" = 7 ]; then
|
||||||
|
chroot /os/ yum -y --disablerepo=* --enablerepo=ol${releasever}_latest "$@"
|
||||||
|
else
|
||||||
|
chroot /os/ dnf -y --disablerepo=* --enablerepo=ol${releasever}_baseos_latest --setopt=install_weak_deps=False "$@"
|
||||||
|
fi
|
||||||
|
else
|
||||||
if [ "$releasever" = 7 ]; then
|
if [ "$releasever" = 7 ]; then
|
||||||
chroot /os/ yum -y --disablerepo=* --enablerepo=base,updates "$@"
|
chroot /os/ yum -y --disablerepo=* --enablerepo=base,updates "$@"
|
||||||
else
|
else
|
||||||
chroot /os/ dnf -y --disablerepo=* --enablerepo=baseos --setopt=install_weak_deps=False "$@"
|
chroot /os/ dnf -y --disablerepo=* --enablerepo=baseos --setopt=install_weak_deps=False "$@"
|
||||||
fi
|
fi
|
||||||
}
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
install_qcow_by_copy() {
|
||||||
mount_nouuid() {
|
mount_nouuid() {
|
||||||
case "$fs" in
|
case "$fs" in
|
||||||
ext4) mount "$@" ;;
|
ext4) mount "$@" ;;
|
||||||
@ -2024,14 +2034,24 @@ install_qcow_by_copy() {
|
|||||||
esac
|
esac
|
||||||
)
|
)
|
||||||
|
|
||||||
fs="$(get_os_fs)"
|
|
||||||
|
|
||||||
connect_qcow
|
connect_qcow
|
||||||
|
|
||||||
|
# 镜像分区格式
|
||||||
|
# centos/rocky/alma: xfs
|
||||||
|
# oracle x86_64: lvm + xfs
|
||||||
|
# oracle aarch64 cloud: ext4
|
||||||
|
if lsblk -f /dev/nbd0p* | grep LVM2_member; then
|
||||||
|
apk add lvm2
|
||||||
|
lvscan
|
||||||
|
lvchange -ay vg_main
|
||||||
|
os_part=mapper/vg_main-lv_root
|
||||||
|
boot_part=nbd0p1
|
||||||
|
else
|
||||||
# TODO: 改成循环mount找出os+fstab查找剩余分区?
|
# TODO: 改成循环mount找出os+fstab查找剩余分区?
|
||||||
os_part=$(lsblk /dev/nbd0p*[0-9] --sort SIZE -no NAME,FSTYPE | grep $fs | tail -1 | cut -d' ' -f1)
|
os_part=$(lsblk /dev/nbd0p* --sort SIZE -no NAME,FSTYPE | grep -E 'ext4|xfs' | tail -1 | cut -d' ' -f1)
|
||||||
efi_part=$(lsblk /dev/nbd0p*[0-9] --sort SIZE -no NAME,FSTYPE | grep fat | tail -1 | cut -d' ' -f1)
|
boot_part=$(lsblk /dev/nbd0p* --sort SIZE -no NAME,FSTYPE | grep -E 'ext4|xfs' | sed '$d' | tail -1 | cut -d' ' -f1)
|
||||||
boot_part=$(lsblk /dev/nbd0p*[0-9] --sort SIZE -no NAME,FSTYPE | grep $fs | sed '$d' | tail -1 | cut -d' ' -f1)
|
efi_part=$(lsblk /dev/nbd0p* --sort SIZE -no NAME,FSTYPE | grep fat | tail -1 | cut -d' ' -f1)
|
||||||
|
fi
|
||||||
|
|
||||||
os_part_uuid=$(lsblk /dev/$os_part -no UUID)
|
os_part_uuid=$(lsblk /dev/$os_part -no UUID)
|
||||||
if [ -n "$efi_part" ]; then
|
if [ -n "$efi_part" ]; then
|
||||||
@ -2081,6 +2101,9 @@ install_qcow_by_copy() {
|
|||||||
|
|
||||||
# 取消挂载 nbd
|
# 取消挂载 nbd
|
||||||
umount /nbd/ /nbd-boot/ /nbd-efi/ || true
|
umount /nbd/ /nbd-boot/ /nbd-efi/ || true
|
||||||
|
if is_have_cmd vgchange; then
|
||||||
|
vgchange -an
|
||||||
|
fi
|
||||||
disconnect_qcow
|
disconnect_qcow
|
||||||
|
|
||||||
# 已复制并断开连接 qcow,可删除 qemu-img
|
# 已复制并断开连接 qcow,可删除 qemu-img
|
||||||
@ -2108,7 +2131,7 @@ install_qcow_by_copy() {
|
|||||||
# cloud-init
|
# cloud-init
|
||||||
download_cloud_init_config /os
|
download_cloud_init_config /os
|
||||||
|
|
||||||
modify_el() {
|
modify_el_ol() {
|
||||||
# resolv.conf
|
# resolv.conf
|
||||||
cp /etc/resolv.conf /os/etc/resolv.conf
|
cp /etc/resolv.conf /os/etc/resolv.conf
|
||||||
|
|
||||||
@ -2119,7 +2142,7 @@ install_qcow_by_copy() {
|
|||||||
truncate_machine_id /os
|
truncate_machine_id /os
|
||||||
|
|
||||||
# centos 7 yum 可能会使用 ipv6,即使没有 ipv6 网络
|
# centos 7 yum 可能会使用 ipv6,即使没有 ipv6 网络
|
||||||
if grep 'centos:7' /os/etc/system-release-cpe; then
|
if grep -E 'centos:7|oracle:linux:7' /os/etc/system-release-cpe; then
|
||||||
if [ "$(cat /dev/ipv6_has_internet)" = "0" ]; then
|
if [ "$(cat /dev/ipv6_has_internet)" = "0" ]; then
|
||||||
echo 'ip_resolve=4' >>/os/etc/yum.conf
|
echo 'ip_resolve=4' >>/os/etc/yum.conf
|
||||||
fi
|
fi
|
||||||
@ -2132,18 +2155,37 @@ install_qcow_by_copy() {
|
|||||||
# 为 centos 7 ci 安装 NetworkManager
|
# 为 centos 7 ci 安装 NetworkManager
|
||||||
# 1. 能够自动配置 onlink 网关
|
# 1. 能够自动配置 onlink 网关
|
||||||
# 2. 解决 cloud-init 关闭了 ra,因为 nm 无视内核 ra 设置
|
# 2. 解决 cloud-init 关闭了 ra,因为 nm 无视内核 ra 设置
|
||||||
if grep 'centos:7' /os/etc/system-release-cpe; then
|
if grep -E 'centos:7|oracle:linux:7' /os/etc/system-release-cpe; then
|
||||||
yum install -y NetworkManager
|
yum install -y NetworkManager
|
||||||
chroot /os/ systemctl enable NetworkManager
|
chroot /os/ systemctl enable NetworkManager
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# fstab 删除 boot 分区
|
# fstab 删除多余分区
|
||||||
# alma/rocky 镜像本身有boot分区,但我们不需要
|
# alma/rocky 镜像有 boot 分区
|
||||||
|
# oracle 镜像有 swap 分区
|
||||||
sed -i '/[[:space:]]\/boot[[:space:]]/d' /os/etc/fstab
|
sed -i '/[[:space:]]\/boot[[:space:]]/d' /os/etc/fstab
|
||||||
|
sed -i '/[[:space:]]swap[[:space:]]/d' /os/etc/fstab
|
||||||
|
|
||||||
|
# oracle linux 系统盘从 lvm 改成 uuid 挂载
|
||||||
|
sed -i "s,/dev/mapper/vg_main-lv_root,UUID=$os_part_uuid," /os/etc/fstab
|
||||||
|
if ls /os/boot/loader/entries/*.conf 2>/dev/null; then
|
||||||
|
sed -i "s,/dev/mapper/vg_main-lv_root,UUID=$os_part_uuid," /os/boot/loader/entries/*.conf
|
||||||
|
fi
|
||||||
|
|
||||||
|
# oracle linux 移除 lvm cmdline
|
||||||
|
if ! chroot /os command -v grubby; then
|
||||||
|
yum install grubby
|
||||||
|
fi
|
||||||
|
chroot /os grubby --update-kernel ALL --remove-args "resume rd.lvm.lv"
|
||||||
|
chroot /os grubby --update-kernel ALL --args UUID=$os_part_uuid
|
||||||
|
if [ "$releasever" -eq 7 ]; then
|
||||||
|
# el7 上面那条 grubby 命令不能设置 /etc/default/grub
|
||||||
|
sed -i 's/ rd.lvm.lv=[^ "]*//g' /os/etc/default/grub
|
||||||
|
fi
|
||||||
|
|
||||||
# fstab 添加 efi 分区
|
# fstab 添加 efi 分区
|
||||||
if is_efi; then
|
if is_efi; then
|
||||||
# centos 要创建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
|
||||||
@ -2153,9 +2195,6 @@ install_qcow_by_copy() {
|
|||||||
sed -i '/[[:space:]]\/boot\/efi[[:space:]]/d' /os/etc/fstab
|
sed -i '/[[:space:]]\/boot\/efi[[:space:]]/d' /os/etc/fstab
|
||||||
fi
|
fi
|
||||||
|
|
||||||
distro_full=$(awk -F: '{ print $3 }' </os/etc/system-release-cpe)
|
|
||||||
releasever=$(awk -F: '{ print $5 }' </os/etc/system-release-cpe)
|
|
||||||
|
|
||||||
remove_grub_conflict_files() {
|
remove_grub_conflict_files() {
|
||||||
# bios 和 efi 转换前先删除
|
# bios 和 efi 转换前先删除
|
||||||
|
|
||||||
@ -2171,8 +2210,8 @@ install_qcow_by_copy() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
# 安装 efi 引导
|
# 安装 efi 引导
|
||||||
# 只有centos镜像没有efi,其他系统镜像已经从efi分区复制了文件
|
# 只有centos 和 oracle x86_64 镜像没有efi,其他系统镜像已经从efi分区复制了文件
|
||||||
if [ "$distro" = "centos" ] && is_efi; then
|
if is_efi && [ -z "$efi_part" ]; then
|
||||||
remove_grub_conflict_files
|
remove_grub_conflict_files
|
||||||
[ "$(uname -m)" = x86_64 ] && arch=x64 || arch=aa64
|
[ "$(uname -m)" = x86_64 ] && arch=x64 || arch=aa64
|
||||||
yum install efibootmgr grub2-efi-$arch grub2-efi-$arch-modules shim-$arch
|
yum install efibootmgr grub2-efi-$arch grub2-efi-$arch-modules shim-$arch
|
||||||
@ -2192,10 +2231,16 @@ install_qcow_by_copy() {
|
|||||||
sed -i -E 's,((linux|initrd) /),\1boot/,g' /os/boot/loader/entries/*.conf
|
sed -i -E 's,((linux|initrd) /),\1boot/,g' /os/boot/loader/entries/*.conf
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
if is_efi; then
|
||||||
|
# oracle linux 文件夹是 redhat
|
||||||
|
# shellcheck disable=SC2010
|
||||||
|
distro_efi=$(cd /os/boot/efi/EFI/ && ls -d -- * | grep -Eiv BOOT)
|
||||||
|
fi
|
||||||
|
|
||||||
# efi 分区 grub.cfg
|
# efi 分区 grub.cfg
|
||||||
# https://github.com/rhinstaller/anaconda/blob/346b932a26a19b339e9073c049b08bdef7f166c3/pyanaconda/modules/storage/bootloader/efi.py#L198
|
# https://github.com/rhinstaller/anaconda/blob/346b932a26a19b339e9073c049b08bdef7f166c3/pyanaconda/modules/storage/bootloader/efi.py#L198
|
||||||
if is_efi && [ "$releasever" -ge 9 ]; then
|
if is_efi && [ "$releasever" -ge 9 ]; then
|
||||||
cat <<EOF >/os/boot/efi/EFI/$distro_full/grub.cfg
|
cat <<EOF >/os/boot/efi/EFI/$distro_efi/grub.cfg
|
||||||
search --no-floppy --fs-uuid --set=dev $os_part_uuid
|
search --no-floppy --fs-uuid --set=dev $os_part_uuid
|
||||||
set prefix=(\$dev)/boot/grub2
|
set prefix=(\$dev)/boot/grub2
|
||||||
export \$prefix
|
export \$prefix
|
||||||
@ -2205,7 +2250,7 @@ EOF
|
|||||||
|
|
||||||
# 主 grub.cfg
|
# 主 grub.cfg
|
||||||
if is_efi && [ "$releasever" -le 8 ]; then
|
if is_efi && [ "$releasever" -le 8 ]; then
|
||||||
chroot /os/ grub2-mkconfig -o /boot/efi/EFI/$distro_full/grub.cfg
|
chroot /os/ grub2-mkconfig -o /boot/efi/EFI/$distro_efi/grub.cfg
|
||||||
else
|
else
|
||||||
chroot /os/ grub2-mkconfig -o /boot/grub2/grub.cfg
|
chroot /os/ grub2-mkconfig -o /boot/grub2/grub.cfg
|
||||||
fi
|
fi
|
||||||
@ -2240,6 +2285,8 @@ EOF
|
|||||||
# minimal 20.04/22.04 kvm # 后台 vnc 无显示
|
# minimal 20.04/22.04 kvm # 后台 vnc 无显示
|
||||||
# minimal 24.04 virtual
|
# minimal 24.04 virtual
|
||||||
|
|
||||||
|
# debian cloud 内核不支持 ahci,ubuntu virtual 支持
|
||||||
|
|
||||||
# 标记旧内核包
|
# 标记旧内核包
|
||||||
# 注意排除 linux-base
|
# 注意排除 linux-base
|
||||||
pkgs=$(chroot $os_dir apt-mark showmanual linux-* | grep -E 'generic|virtual|kvm' | grep -v $flavor)
|
pkgs=$(chroot $os_dir apt-mark showmanual linux-* | grep -E 'generic|virtual|kvm' | grep -v $flavor)
|
||||||
@ -2303,7 +2350,7 @@ EOF
|
|||||||
|
|
||||||
case "$distro" in
|
case "$distro" in
|
||||||
ubuntu) modify_ubuntu ;;
|
ubuntu) modify_ubuntu ;;
|
||||||
*) modify_el ;;
|
*) modify_el_ol ;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
# 删除installer分区,重启后cloud init会自动扩容
|
# 删除installer分区,重启后cloud init会自动扩容
|
||||||
@ -3161,7 +3208,7 @@ if is_use_cloud_image; then
|
|||||||
create_part
|
create_part
|
||||||
download_qcow
|
download_qcow
|
||||||
case "$distro" in
|
case "$distro" in
|
||||||
centos | alma | rocky)
|
centos | alma | rocky | oracle)
|
||||||
# 这几个系统云镜像系统盘是8~9g xfs,而我们的目标是能在5g硬盘上运行,因此改成复制系统文件
|
# 这几个系统云镜像系统盘是8~9g xfs,而我们的目标是能在5g硬盘上运行,因此改成复制系统文件
|
||||||
install_qcow_by_copy
|
install_qcow_by_copy
|
||||||
;;
|
;;
|
||||||
|
Loading…
Reference in New Issue
Block a user