Centos7_DDNS_Check

#! /bin/bash

export PATH=$PATH:/usr/sbin

wg_ip=$(wg|awk -F ":" 'NR==7 {print $2}')
ns_ip=$(nslookup connectwg.topgen.com.cn |awk 'NR==6 {print $2}')

if [ ${wg_ip} == ${ns_ip} ];then
echo "$(date "+%Y%m%d-%H%M%S") : 未检测到IP发生改变"
else
bash /etc/wireguard/downup.sh && echo "$(date "+%Y%m%d-%H%M%S") : 检测到IP发生改变,已重启Wireguard"
fi
exit 0

【Crontab】
# */5 * * * * /bin/bash /etc/wireguard/DDNS_check.sh >> /etc/wireguard/ddns_check.log 2>&1 &

【cat /etc/wireguard/downup.sh】
# /usr/bin/wg-quick down wg0
# /usr/bin/wg-quick up wg0

【日志结果】
# 20230413-123001 : 未检测到IP发生改变
# 20230413-123501 : 未检测到IP发生改变
# [#] ip link delete dev wg0
# [#] ip link add wg0 type wireguard
# [#] wg setconf wg0 /dev/fd/63
# [#] ip -4 address add 10.5.0.6/24 dev wg0
# [#] ip link set mtu 1420 up dev wg0
# [#] ip -4 route add 172.16.80.0/23 dev wg0
# [#] ip -4 route add 172.16.50.0/23 dev wg0
# [#] ip -4 route add 172.16.40.0/23 dev wg0
# [#] ip -4 route add 172.16.30.0/23 dev wg0
# [#] ip -4 route add 172.16.20.0/23 dev wg0
# [#] ip -4 route add 172.16.10.0/23 dev wg0
# [#] iptables -A FORWARD -i wg0 -j ACCEPT; iptables -A FORWARD -o wg0 -j ACCEPT; iptables -t nat -A POSTROUTING -o em1 -j MASQUERADE
# 20230413-124001 : 检测到IP发生改变,已重启Wireguard
# 20230413-124501 : 未检测到IP发生改变
# 20230413-125002 : 未检测到IP发生改变

【报错处理】
# 1、/usr/bin/wg-quick: line 31: ip: command not found
# crontab无法找到/usr/sbin/ip 的环境变量,需手动添加:export PATH=$PATH:/usr/sbin
# 2、Warning: /etc/wireguard/wg0.conf' is world accessible
# 配置文件权限问题,需改为:chmod 600 /etc/wireguard/wg0.conf

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值