2024-03-05 21:46:32 +08:00
|
|
|
#!/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
|
|
|
|
|
2024-03-31 00:47:13 +08:00
|
|
|
if ! confs=$(ls /etc/systemd/network/10-cloud-init-*.network 2>/dev/null); then
|
2024-03-05 21:46:32 +08:00
|
|
|
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 - -
|
|
|
|
|
2024-03-31 00:47:13 +08:00
|
|
|
if ! confs=$(ls /etc/sysconfig/network/ifroute-* 2>/dev/null); then
|
2024-03-05 21:46:32 +08:00
|
|
|
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
|