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

查看本地网络

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

相关推荐
两个人的幸福1 天前
Windows 桌面应用自研 PHP 队列(下):完整代码与六大工程化优化
php
zzzzzz3101 天前
9K Star 炸裂开源!这个 C 语言写的代码知识图谱,把 Linux 内核索引压缩到了 3 分钟
linux·服务器·sql
XIAOHEZIcode1 天前
Linux系统鼠标偏移常见原因以及修复方案
linux·运维·游戏
用户0328472220702 天前
如何搭建本地yum源(上)
运维
BingoGo3 天前
PHP 泛型之殇 泛型 RFC 提案被拒绝
后端·php
JaguarJack3 天前
PHP 泛型之殇 泛型 RFC 提案被拒绝
后端·php
用户3074596982074 天前
PHP 扩展——从入门到理解
php
鹏仔先生5 天前
拷贝漫画APP下载页PHP程序,后台带免费AI写作
php
大树885 天前
金刚石散热越强,管路越先见顶
大数据·运维·服务器·人工智能·ai
摇滚侠5 天前
Linux CentOS7 rpm 安装 MySQL 5.7
linux·运维·mysql