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

查看本地网络

命令 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通并能够访问网络

相关推荐
海外空间恒创科技12 分钟前
香港站群服务器与普通香港服务器对比
服务器·git·github
自由游戏开发者1 小时前
用U盘启动制作centos系统最常见报错,系统卡住无法继续问题(手把手)
linux·运维·centos
Ronin3051 小时前
【Linux系统】vim编辑器 | 编译器gcc/g++ | make/Makefile
linux·运维·服务器·ubuntu·编辑器·vim
Bruce_Liuxiaowei2 小时前
Netstat高级分析工具:Windows与Linux双系统兼容的精准筛查利器
linux·运维·网络·windows·安全
linux修理工2 小时前
n1 armbian 安装桌面环境并启用xrdp远程登录
linux·服务器·数据库
Brookty2 小时前
【操作系统】进程(二)内存管理、通信
java·linux·服务器·网络·学习·java-ee·操作系统
易德研发3 小时前
ubuntu24.04安装NFS网络文件系统/ARM开发板NFS挂载
运维·服务器·网络
开开心心就好4 小时前
高效报价软件,简化商铺定价流程
服务器·数据库·安全·面试·职场和发展·电脑·symfony
生活爱好者!4 小时前
NAS 部署白板工具,实现思维导图/画板/流程图自由
运维·docker·容器
段帅龙呀9 小时前
Redis构建缓存服务器
服务器·redis·缓存