在现代网络环境中,虚拟私人网络(VPN)已成为远程办公、跨地域访问内网资源和保护数据隐私的重要工具,对于使用Ubuntu操作系统的用户而言,搭建一个稳定且安全的OpenVPN服务不仅能够提升网络灵活性,还能为家庭或企业用户提供可靠的数据加密通道,本文将详细介绍如何在Ubuntu 20.04及以上版本上部署并配置OpenVPN服务器,涵盖环境准备、证书生成、服务配置、防火墙设置及客户端连接等关键步骤。
确保你拥有一个运行Ubuntu的物理机或云服务器,并具备root权限或sudo权限,通过终端执行以下命令更新系统包列表:
sudo apt update && sudo apt upgrade -y
接着安装OpenVPN及其依赖项,包括Easy-RSA(用于证书管理):
sudo apt install openvpn easy-rsa -y
下一步是创建证书颁发机构(CA)和服务器证书,复制Easy-RSA模板目录到/etc/openvpn/并初始化:
make-cadir /etc/openvpn/easy-rsa cd /etc/openvpn/easy-rsa sudo ./easyrsa init-pki sudo ./easyrsa build-ca nopass
这里我们使用nopass参数跳过CA密码,便于自动化脚本调用,接下来生成服务器证书和密钥:
sudo ./easyrsa gen-req server nopass sudo ./easyrsa sign-req server server
然后生成Diffie-Hellman密钥交换参数(此过程耗时较长):
sudo ./easyrsa gen-dh
我们开始配置OpenVPN服务器主文件,创建 /etc/openvpn/server.conf 文件,内容如下:
port 1194
proto udp
dev tun
ca /etc/openvpn/easy-rsa/pki/ca.crt
cert /etc/openvpn/easy-rsa/pki/issued/server.crt
key /etc/openvpn/easy-rsa/pki/private/server.key
dh /etc/openvpn/easy-rsa/pki/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
tls-auth /etc/openvpn/easy-rsa/pki/ta.key 0
cipher AES-256-CBC
auth SHA256
user nobody
group nogroup
persist-key
persist-tun
status /var/log/openvpn-status.log
verb 3
注意:tls-auth需预先生成,可通过 openvpn --genkey --secret ta.key 命令实现,并将其放置于指定路径。
配置完成后,启用IP转发以允许流量穿越服务器:
echo 'net.ipv4.ip_forward=1' | sudo tee -a /etc/sysctl.conf sudo sysctl -p
配置UFW防火墙规则,放行OpenVPN端口(UDP 1194):
sudo ufw allow 1194/udp sudo ufw enable
启动OpenVPN服务并设置开机自启:
sudo systemctl start openvpn@server sudo systemctl enable openvpn@server
为客户端生成证书和配置文件,在客户端机器上使用Easy-RSA生成个人证书,并打包客户端配置文件(包含ca.crt、client.crt、client.key、ta.key),即可在Windows、macOS或移动设备上使用OpenVPN客户端连接。
通过以上步骤,你已在Ubuntu上成功部署了一个功能完备的OpenVPN服务器,后续建议定期更新证书、监控日志、限制访问源IP范围,并考虑结合Fail2Ban增强安全性,掌握这一技能,无论是个人隐私保护还是企业级远程接入,都将为你提供强大而灵活的网络解决方案。

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

