虚拟局域网中配置某台服务器作为网关的方案

查看本地网络

命令 ip a 查看本地网络接口信息

将需要转发流量的网卡名称,如 tun0 转发至 ens18记录到脚本的对应位置,并执行脚本

shell 复制代码
#!/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,输入以下命令:

shell 复制代码
route add 10.108.16.0 mask 255.255.255.0 10.3.0.48

还有一种方式是直接在openvpn access server后台中最后一行加入该配置(这种方式需要将历史生成的VPN配置重新生成一次,具体怎么实时生效我还不清楚,有需要可自行查阅相关资料,当然也希望能有结论后分享给我)

最终的效果图如下,未配置时无法ping通,配置后正常ping通并能够访问网络

相关推荐
小嵌同学7 分钟前
Meson:开源的自动化构建系统
linux·运维·开源·自动化·meson
果子⌂32 分钟前
Zabbix 企业级高级应用
linux·运维·nginx·zabbix
钱彬 (Qian Bin)39 分钟前
解决docker load加载tar镜像报json no such file or directory的错误
运维·docker·容器·错误·tar·docker load
初九之潜龙勿用2 小时前
技术与情感交织的一生 (十一)
服务器·笔记·microsoft·印象笔记
明月心9522 小时前
NFS CENTOS系统 安装配置
linux·运维·centos
Raymond运维3 小时前
MySQL 8.0源码编译安装(二)
linux·运维·mysql
xw53 小时前
免费的个人网站托管-InfinityFree
服务器·前端
延凡科技3 小时前
延凡科技光伏清洗预测系统
大数据·运维·人工智能·科技·无人机·智慧城市
wuzuyu3653 小时前
Laravel The requested URL /hellowzy was not found on this server. 404 问题的解决
php·laravel
!win !3 小时前
免费的个人网站托管-InfinityFree
服务器·前端工具