在当今远程办公和分布式团队日益普及的背景下,构建一个稳定、安全的虚拟私人网络(VPN)服务器成为企业与个人用户的重要需求,Linux凭借其开源特性、高度可定制性以及强大的网络功能,成为搭建VPN服务器的理想平台,本文将详细介绍如何在Linux系统上搭建一个基于OpenVPN的加密VPN服务,涵盖环境准备、配置文件编写、防火墙设置及客户端连接等关键步骤。
确保你的Linux服务器满足基本要求:一台运行Ubuntu 20.04/22.04或CentOS Stream 9等主流发行版的服务器,具备公网IP地址(静态IP更佳),并已安装SSH访问权限,建议使用云服务商如阿里云、腾讯云或AWS部署,便于管理与扩展。
第一步是安装OpenVPN及其依赖组件,以Ubuntu为例,执行以下命令:
sudo apt update sudo apt install openvpn easy-rsa -y
对于CentOS用户,使用:
sudo dnf install openvpn easy-rsa -y
初始化PKI(公钥基础设施),进入EasyRSA目录:
sudo 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参数(增强加密强度):
sudo ./easyrsa gen-dh
复制证书到OpenVPN配置目录:
sudo cp pki/ca.crt pki/private/server.key pki/dh.pem /etc/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"
keepalive 10 120
tls-auth ta.key 0
cipher AES-256-CBC
auth SHA256
user nobody
group nogroup
persist-key
persist-tun
status openvpn-status.log
verb 3
注意:tls-auth ta.key 需提前生成(openvpn --genkey --secret ta.key),用于防DDoS攻击。
启用IP转发并配置iptables规则:
echo 'net.ipv4.ip_forward=1' | sudo tee -a /etc/sysctl.conf sudo sysctl -p 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 -j ACCEPT sudo iptables -A FORWARD -s 10.8.0.0/24 -d 10.8.0.0/24 -j ACCEPT
若使用firewalld(CentOS),则用firewall-cmd替代iptables命令。
启动服务并设为开机自启:
sudo systemctl enable openvpn@server sudo systemctl start openvpn@server
为客户端生成证书和配置文件,在EasyRSA目录中执行:
sudo ./easyrsa gen-req client1 nopass sudo ./easyrsa sign-req client client1
然后将ca.crt、client1.crt、client1.key和ta.key打包发送给客户端,并创建.ovpn配置文件供OpenVPN桌面客户端使用。
通过以上步骤,你已成功搭建了一个支持多用户接入、端到端加密的Linux VPN服务器,此方案兼顾安全性与易用性,适合中小型企业或技术爱好者使用,后续可根据需要添加双因素认证、日志审计等功能,进一步提升运维效率。

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






