Ubuntu系统下搭建与配置VPN服务的完整指南,从基础到进阶

在当今远程办公和跨地域协作日益普遍的背景下,虚拟私人网络(VPN)已成为保障网络安全、实现远程访问的重要工具,对于使用Ubuntu操作系统的用户而言,无论是个人用户还是企业IT管理员,掌握在Ubuntu上搭建和配置VPN服务的能力都至关重要,本文将详细介绍如何在Ubuntu系统中部署OpenVPN服务,涵盖环境准备、安装配置、防火墙设置以及客户端连接等关键步骤,帮助你快速构建一个稳定、安全的私有网络通道。

确保你的Ubuntu服务器已更新至最新版本,打开终端并执行以下命令:

sudo apt update && sudo apt upgrade -y

安装OpenVPN及其依赖包,OpenVPN是一个开源的VPN解决方案,支持多种加密协议,兼容性强且安全性高,运行以下命令完成安装:

sudo apt install openvpn easy-rsa -y

easy-rsa 是用于生成SSL/TLS证书的工具,是OpenVPN认证体系的核心组件。

安装完成后,进入证书生成目录并初始化PKI(公钥基础设施):

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

这里会提示输入CA(证书颁发机构)的名称,默认即可,下一步生成服务器证书和密钥:

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

然后生成Diffie-Hellman参数和TLS密钥交换文件(这一步耗时较长,建议耐心等待):

sudo ./easyrsa gen-dh
sudo openvpn --genkey --secret ta.key

将所有生成的证书和密钥复制到OpenVPN配置目录:

sudo cp pki/ca.crt pki/issued/server.crt pki/private/server.key dh.pem ta.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

此配置启用UDP协议,分配子网10.8.0.0/24给客户端,并推送DNS和路由规则,确保流量通过VPN隧道转发。

配置完成后,启动OpenVPN服务并设置开机自启:

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

若需允许IPv4转发(即让服务器充当网关),编辑 /etc/sysctl.conf 文件,取消注释以下行:

net.ipv4.ip_forward=1

然后执行 sudo sysctl -p 生效配置。

配置防火墙(如UFW)以开放端口1194 UDP:

sudo ufw allow 1194/udp
sudo ufw reload

至此,Ubuntu上的OpenVPN服务器已成功部署,用户可通过生成客户端证书(使用easy-rsa)并配置.ovpn文件,连接到该服务器,推荐使用OpenVPN Connect客户端或Linux原生OpenVPN客户端进行连接测试。

通过以上步骤,你可以快速搭建一个功能完整的OpenVPN服务,满足远程办公、内网穿透或站点间互联的需求,后续可根据实际需求进一步优化性能(如启用压缩、调整MTU)或集成身份认证(如LDAP/Radius),掌握这些技能,让你在Ubuntu环境下游刃有余地管理网络服务。

Ubuntu系统下搭建与配置VPN服务的完整指南,从基础到进阶

半仙加速器-海外加速器 | VPN加速器 | VPN翻墙加速器 | VPN梯子 | VPN外网加速