编辑vars文件,设置国家、组织名等信息(如KEY_COUNTRY=CN)

从零开始配置VPN服务器指南

在当今高度互联的数字世界中,网络安全和隐私保护已成为每个用户不可忽视的重要议题,无论是远程办公、跨地域访问公司内网资源,还是避免公共Wi-Fi带来的数据泄露风险,虚拟私人网络(VPN)都是一种高效且可靠的解决方案,作为网络工程师,我将带你一步步从零开始搭建一个功能完整、安全稳定的自建VPN服务器,无需依赖第三方服务,真正掌握你的网络主权。

你需要一台具备公网IP的服务器,这可以是云服务商(如阿里云、腾讯云、AWS、DigitalOcean等)提供的Linux虚拟机(推荐Ubuntu 20.04或22.04 LTS版本),也可以是本地部署的树莓派或其他高性能设备,确保服务器已安装最新系统补丁并配置了基本防火墙(如UFW)。

我们选择OpenVPN作为协议方案,OpenVPN是一款开源、成熟、可定制性强的VPN实现,支持多种加密算法(如AES-256-CBC)、TLS认证和多用户管理,非常适合个人或小型团队使用。

第一步是安装OpenVPN及相关工具:

sudo apt update && sudo apt install openvpn easy-rsa -y

第二步,生成证书颁发机构(CA)和服务器证书,使用Easy-RSA脚本简化流程:

make-cadir /etc/openvpn/easy-rsa
cd /etc/openvpn/easy-rsa
sudo cp vars.example varssudo ./easyrsa init-pki
sudo ./easyrsa build-ca nopass  # 生成CA证书,不设置密码
sudo ./easyrsa gen-req server nopass
sudo ./easyrsa sign-req server server

第三步,生成客户端证书(每台设备一个):

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

第四步,配置服务器主文件 /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

第五步,启用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 ufw allow 1194/udp

启动服务并测试连接:

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

客户端方面,只需将CA证书、客户端证书、私钥和配置文件打包成.ovpn格式,导入到Windows、macOS或移动设备的OpenVPN客户端即可连接。

通过以上步骤,你不仅获得了一个稳定高效的自建VPN服务,还深入理解了网络隧道、加密通信与访问控制的核心机制,更重要的是,你的数据始终处于你自己的掌控之下——这才是真正的数字化自由。

编辑vars文件,设置国家、组织名等信息(如KEY_COUNTRY=CN)

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