Ubuntu下配置VPN与NAT实现内网访问外网的完整指南

dfbn6 2026-05-05 梯子VPN 2 0

在现代网络环境中,许多企业或家庭用户需要通过Ubuntu系统搭建一个既安全又高效的网络环境,尤其是在需要将内部设备通过单一公网IP访问互联网时,配置VPN(虚拟私人网络)与NAT(网络地址转换)成为常见需求,本文将详细介绍如何在Ubuntu服务器上部署OpenVPN服务,并结合iptables实现NAT转发,从而让局域网内的设备通过该服务器安全地访问外部网络。

确保你有一台运行Ubuntu 20.04或更高版本的服务器,并具备静态公网IP地址,安装OpenVPN服务前,建议先更新系统软件包:

sudo apt update && sudo apt upgrade -y

接着安装OpenVPN和Easy-RSA(用于生成证书):

sudo apt install openvpn easy-rsa -y

使用Easy-RSA生成证书和密钥对,创建CA(证书颁发机构):

make-cadir /etc/openvpn/easy-rsa
cd /etc/openvpn/easy-rsa
sudo ./easyrsa init-pki
sudo ./easyrsa build-ca nopass

生成服务器证书和密钥:

sudo ./easyrsa gen-req server nopass
sudo ./easyrsa sign-req server server

生成客户端证书(每个客户端都需要单独生成):

sudo ./easyrsa gen-req client1 nopass
sudo ./easyrsa sign-req client client1

复制相关文件到OpenVPN配置目录:

sudo cp pki/ca.crt pki/issued/server.crt pki/private/server.key /etc/openvpn/

创建OpenVPN服务器配置文件 /etc/openvpn/server.conf如下(可根据实际网络调整):

port 1194
proto udp
dev tun
ca ca.crt
cert server.crt
key server.key
dh dh.pem
server 10.8.0.0 255.255.255.0
push "redirect-gateway def1 bypass-dhcp"
push "dhcp-option DNS 8.8.8.8"
push "dhcp-option DNS 8.8.4.4"
keepalive 10 120
comp-lzo
user nobody
group nogroup
persist-key
persist-tun
status openvpn-status.log
verb 3

启用IP转发并配置NAT规则:

echo 'net.ipv4.ip_forward=1' | sudo tee -a /etc/sysctl.conf
sudo sysctl -p

设置iptables规则,允许流量转发并进行SNAT(源地址转换):

sudo iptables -t nat -A POSTROUTING -s 10.8.0.0/24 -o eth0 -j MASQUERADE
sudo iptables -A FORWARD -m state --state RELATED,ESTABLISHED -i tun0 -o eth0 -j ACCEPT
sudo iptables -A FORWARD -i eth0 -o tun0 -j ACCEPT

为确保重启后规则依然生效,可将iptables命令写入脚本并加入开机启动项,例如使用iptables-persistent包:

sudo apt install iptables-persistent -y
sudo netfilter-persistent save

启动OpenVPN服务:

sudo systemctl enable openvpn@server
sudo systemctl start openvpn@server

至此,Ubuntu服务器已成功配置为OpenVPN服务器并启用了NAT功能,局域网内的客户端只需导入证书并连接至该服务器,即可通过该服务器访问外网,同时保持数据加密与隐私保护。

此方案适用于小型办公、远程访问或家庭网络扩展,具有成本低、安全性高、易维护的优点,是网络工程师在Ubuntu环境下部署基础网络服务的理想选择。

Ubuntu下配置VPN与NAT实现内网访问外网的完整指南

VPN加速器|半仙VPN加速器-免费VPN梯子首选半仙VPN