查看本地网络
命令 ip a 查看本地网络接口信息
将需要转发流量的网卡名称,如 tun0 转发至 ens18记录到脚本的对应位置,并执行脚本
#!/bin/bash
# 检查是否以 root 权限运行
if [ "$EUID" -ne 0 ]; then
echo "请使用 root 权限运行此脚本"
exit 1
fi
# 设置网络转发
SYSCTL_CONF="/etc/sysctl.conf"
IP_FORWARD_LINE="net.ipv4.ip_forward = 1"
# 检查是否已存在该行,如果不存在则添加
if ! grep -q "$IP_FORWARD_LINE" "$SYSCTL_CONF"; then
echo "$IP_FORWARD_LINE" >> "$SYSCTL_CONF"
echo "已将 '$IP_FORWARD_LINE' 添加到 $SYSCTL_CONF"
else
echo "$IP_FORWARD_LINE 已存在于 $SYSCTL_CONF"
fi
# 重新加载 sysctl 配置
sysctl -p
# 允许流量转发(需指定 tun0 和 ens18)
TUN_INTERFACE="tun0" # 请根据需要修改
ENS_INTERFACE="ens18" # 请根据需要修改
iptables -A FORWARD -i "$TUN_INTERFACE" -o "$ENS_INTERFACE" -j ACCEPT
iptables -A FORWARD -i "$ENS_INTERFACE" -o "$TUN_INTERFACE" -m state --state ESTABLISHED,RELATED -j ACCEPT
# 设置 NAT
iptables -t nat -A POSTROUTING -o "$ENS_INTERFACE" -j MASQUERADE
echo "网关设置完成!"
配置路由
配置完成后请在其他客户端上通过路由配置完成流量转发,如客户端A的ip为10.3.0.5,网关ip为10.3.0.48,想让客户端A中能够访问网关10.108.16.0网段的网络(必须是ens18网卡对应的网段),则以管理员方式打开cmd,输入以下命令:
route add 10.108.16.0 mask 255.255.255.0 10.3.0.48
还有一种方式是直接在openvpn access server后台中最后一行加入该配置(这种方式需要将历史生成的VPN配置重新生成一次,具体怎么实时生效我还不清楚,有需要可自行查阅相关资料,当然也希望能有结论后分享给我)
最终的效果图如下,未配置时无法ping通,配置后正常ping通并能够访问网络