mirror of
https://github.com/bin456789/reinstall.git
synced 2025-01-18 20:39:14 +08:00
core: 修复 cloud-init 没有正确渲染 onlink 网关
This commit is contained in:
parent
7c98d6ae73
commit
d59668b663
200
cloud-init-fix-onlink.sh
Normal file
200
cloud-init-fix-onlink.sh
Normal file
@ -0,0 +1,200 @@
|
||||
#!/bin/bash
|
||||
# 修复 cloud-init 没有正确渲染 onlink 网关
|
||||
|
||||
set -eE
|
||||
|
||||
insert_into_file() {
|
||||
file=$1
|
||||
location=$2
|
||||
regex_to_find=$3
|
||||
|
||||
if [ "$location" = head ]; then
|
||||
bak=$(mktemp)
|
||||
cp "$file" "$bak"
|
||||
cat - "$bak" >"$file"
|
||||
else
|
||||
line_num=$(grep -E -n "$regex_to_find" "$file" | cut -d: -f1)
|
||||
|
||||
found_count=$(echo "$line_num" | wc -l)
|
||||
if [ ! "$found_count" -eq 1 ]; then
|
||||
return 1
|
||||
fi
|
||||
|
||||
case "$location" in
|
||||
before) line_num=$((line_num - 1)) ;;
|
||||
after) ;;
|
||||
*) return 1 ;;
|
||||
esac
|
||||
|
||||
sed -i "${line_num}r /dev/stdin" "$file"
|
||||
fi
|
||||
}
|
||||
|
||||
fix_netplan_conf() {
|
||||
# 修改前
|
||||
# gateway4: 1.1.1.1
|
||||
# gateway6: ::1
|
||||
|
||||
# 修改后
|
||||
# routes:
|
||||
# - to: 0.0.0.0/0
|
||||
# via: 1.1.1.1
|
||||
# on-link: true
|
||||
# routes:
|
||||
# - to: ::/0
|
||||
# via: ::1
|
||||
# on-link: true
|
||||
conf=/etc/netplan/50-cloud-init.yaml
|
||||
if ! [ -f $conf ]; then
|
||||
return
|
||||
fi
|
||||
|
||||
# 判断 bug 是否已经修复
|
||||
if grep 'on-link:' "$conf"; then
|
||||
return
|
||||
fi
|
||||
|
||||
# 获取网关
|
||||
gateways=$(grep 'gateway[4|6]:' $conf | awk '{print $2}')
|
||||
if [ -z "$gateways" ]; then
|
||||
return
|
||||
fi
|
||||
|
||||
# 获取缩进
|
||||
spaces=$(grep 'gateway[4|6]:' $conf | head -1 | grep -o '^[[:space:]]*')
|
||||
|
||||
{
|
||||
# 网关头部
|
||||
cat <<EOF
|
||||
${spaces}routes:
|
||||
EOF
|
||||
# 网关条目
|
||||
for gateway in $gateways; do
|
||||
|
||||
# debian 10 的 cloud-init 不支持 to: default
|
||||
case $gateway in
|
||||
*.*) to='0.0.0.0/0' ;;
|
||||
*:*) to='::/0' ;;
|
||||
esac
|
||||
|
||||
cat <<EOF
|
||||
${spaces} - to: $to
|
||||
${spaces} via: $gateway
|
||||
${spaces} on-link: true
|
||||
EOF
|
||||
|
||||
done
|
||||
} | insert_into_file $conf before 'match:'
|
||||
|
||||
# 删除原来的条目
|
||||
sed -i '/gateway[4|6]:/d' $conf
|
||||
|
||||
# 重新应用配置
|
||||
netplan apply
|
||||
systemctl restart systemd-networkd
|
||||
}
|
||||
|
||||
fix_networkd_conf() {
|
||||
# 修改前 gentoo
|
||||
# [Route]
|
||||
# Gateway=1.1.1.1
|
||||
# Gateway=2602::1
|
||||
|
||||
# 修改前 arch
|
||||
# [Route]
|
||||
# Gateway=1.1.1.1
|
||||
#
|
||||
# [Route]
|
||||
# Gateway=2602::1
|
||||
|
||||
# 修改后
|
||||
# [Route]
|
||||
# Gateway=1.1.1.1
|
||||
# GatewayOnLink=yes
|
||||
#
|
||||
# [Route]
|
||||
# Gateway=2602::1
|
||||
# GatewayOnLink=yes
|
||||
|
||||
if ! confs=$(ls /etc/systemd/network/10-cloud-init-*.network); then
|
||||
return
|
||||
fi
|
||||
|
||||
for conf in $confs; do
|
||||
# 判断 bug 是否已经修复
|
||||
if grep '^GatewayOnLink=' "$conf"; then
|
||||
return
|
||||
fi
|
||||
|
||||
# 获取网关
|
||||
gateways=$(grep '^Gateway=' "$conf" | cut -d= -f2)
|
||||
if [ -z "$gateways" ]; then
|
||||
return
|
||||
fi
|
||||
|
||||
# 删除原来的条目
|
||||
sed -i '/^\[Route\]/d; /^Gateway=/d; /^GatewayOnLink=/d' "$conf"
|
||||
|
||||
# 创建新条目
|
||||
for gateway in $gateways; do
|
||||
echo "
|
||||
[Route]
|
||||
Gateway=$gateway
|
||||
GatewayOnLink=yes
|
||||
"
|
||||
done >>"$conf"
|
||||
done
|
||||
|
||||
# 重新应用配置
|
||||
# networkctl reload 不起作用
|
||||
systemctl restart systemd-networkd
|
||||
}
|
||||
|
||||
fix_wicked_conf() {
|
||||
# https://github.com/openSUSE/wicked/wiki/FAQ#q-why-wicked-does-not-set-my-default-static-route
|
||||
|
||||
# 修改前
|
||||
# default 1.1.1.1 - -
|
||||
# default 2602::1 - -
|
||||
|
||||
# 修改后
|
||||
# 1.1.1.1 - -
|
||||
# 2602::1 - -
|
||||
# default 1.1.1.1 - -
|
||||
# default 2602::1 - -
|
||||
|
||||
if ! confs=$(ls /etc/sysconfig/network/ifroute-*); then
|
||||
return
|
||||
fi
|
||||
|
||||
for conf in $confs; do
|
||||
# 判断 bug 是否已经修复
|
||||
if grep -v 'default' "$conf" | grep '-'; then
|
||||
return
|
||||
fi
|
||||
|
||||
# 获取网关
|
||||
gateways=$(awk '$1=="default" {print $2}' "$conf")
|
||||
if [ -z "$gateways" ]; then
|
||||
return
|
||||
fi
|
||||
|
||||
# 创建新条目
|
||||
for gateway in $gateways; do
|
||||
echo "$gateway - -"
|
||||
done | insert_into_file "$conf" head
|
||||
done
|
||||
|
||||
# 重新应用配置
|
||||
systemctl restart wicked
|
||||
}
|
||||
|
||||
# debian 10/11/12: netplan + networkd/resolved
|
||||
fix_netplan_conf
|
||||
|
||||
# arch: networkd/resolved
|
||||
# gentoo: networkd/resolved
|
||||
fix_networkd_conf
|
||||
|
||||
# opensuse 15.5: ifcfg + netconfig (dns) + wicked
|
||||
fix_wicked_conf
|
33
trans.sh
33
trans.sh
@ -1321,6 +1321,17 @@ modify_linux() {
|
||||
fi
|
||||
}
|
||||
|
||||
# 修复 onlink 网关
|
||||
add_onlink_script_if_need() {
|
||||
if is_staticv4 || is_staticv6; then
|
||||
fix_sh=cloud-init-fix-onlink.sh
|
||||
download $confhome/$fix_sh $os_dir/$fix_sh
|
||||
insert_into_file $ci_file after '^runcmd:' <<EOF
|
||||
- bash /$fix_sh && rm -f /$fix_sh
|
||||
EOF
|
||||
fi
|
||||
}
|
||||
|
||||
download_cloud_init_config $os_dir
|
||||
|
||||
truncate_machine_id $os_dir
|
||||
@ -1342,8 +1353,12 @@ modify_linux() {
|
||||
fi
|
||||
fi
|
||||
|
||||
# debian 10/11 网络问题
|
||||
if [ -f $os_dir/etc/debian_version ] && grep -E '^(10|11)' $os_dir/etc/debian_version; then
|
||||
# debian 网络问题
|
||||
if [ -f $os_dir/etc/debian_version ]; then
|
||||
# 修复 onlink 网关
|
||||
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
|
||||
@ -1371,6 +1386,13 @@ EOF
|
||||
mv $os_dir/etc/resolv.conf.orig $os_dir/etc/resolv.conf
|
||||
fi
|
||||
fi
|
||||
fi
|
||||
|
||||
# opensuse leap
|
||||
if grep opensuse-leap $os_dir/etc/os-release; then
|
||||
# 修复 onlink 网关
|
||||
add_onlink_script_if_need
|
||||
fi
|
||||
|
||||
# opensuse tumbleweed
|
||||
# TODO: cloud-init 更新后删除
|
||||
@ -1380,6 +1402,10 @@ EOF
|
||||
|
||||
# arch
|
||||
if [ -f $os_dir/etc/arch-release ]; then
|
||||
# 修复 onlink 网关
|
||||
add_onlink_script_if_need
|
||||
|
||||
# 同步证书
|
||||
rm $os_dir/etc/resolv.conf
|
||||
cp /etc/resolv.conf $os_dir/etc/resolv.conf
|
||||
mount_pseudo_fs $os_dir
|
||||
@ -1429,6 +1455,9 @@ EOF
|
||||
insert_into_file $ci_file after '^runcmd:' <<EOF
|
||||
- sed -i '/^Name=/d' /etc/systemd/network/10-cloud-init-eth*.network
|
||||
EOF
|
||||
|
||||
# 修复 onlink 网关
|
||||
add_onlink_script_if_need
|
||||
fi
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user