作为一名网络工程师,我经常被问到:“如何自己搭建一个VPN服务器?”无论是为了家庭网络远程访问NAS、企业员工远程办公,还是保护隐私和绕过地理限制,配置一个稳定可靠的VPN服务器都是一项非常实用的技能,本文将带你一步步完成在Linux系统(以Ubuntu为例)上设置OpenVPN服务器的全过程,即使你没有太多技术背景,只要按步骤操作也能成功。

第一步:准备环境
你需要一台具备公网IP的服务器(可以是云服务商如阿里云、腾讯云或AWS),并确保服务器防火墙允许UDP端口1194(OpenVPN默认端口),如果你使用的是国内云服务,可能还需要在控制台开放对应端口,并检查是否被运营商屏蔽(部分地区对UDP协议有限制)。

第二步:安装OpenVPN及相关工具
登录服务器后,执行以下命令更新系统并安装OpenVPN:

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

easy-rsa 是用于生成数字证书和密钥的工具包,这是OpenVPN实现加密通信的核心组件。

第三步:生成证书与密钥
进入EasyRSA目录并初始化PKI(公钥基础设施):

cd /usr/share/easy-rsa/
sudo cp -r /usr/share/easy-rsa/* /etc/openvpn/easy-rsa/
sudo nano /etc/openvpn/easy-rsa/vars

修改 KEY_COUNTRY, KEY_PROVINCE, KEY_CITY 等字段为你的信息(比如中国、北京),然后运行:

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服务器
创建配置文件 /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"
keepalive 10 120
comp-lzo
user nobody
group nogroup
persist-key
persist-tun
status /var/log/openvpn-status.log
verb 3

第五步:启用IP转发并配置iptables
编辑 /etc/sysctl.conf,取消注释 net.ipv4.ip_forward=1,然后执行:

sudo sysctl -p
sudo iptables -t nat -A POSTROUTING -s 10.8.0.0/24 -o eth0 -j MASQUERADE

第六步:启动服务并测试

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

现在你可以下载客户端配置文件(包含证书、密钥等),在Windows、Mac、Android或iOS设备上使用OpenVPN客户端连接。

虽然设置过程涉及多个步骤,但每一步都有明确目的,掌握后不仅能提升网络安全意识,还能让你在远程办公、家庭NAS访问等场景中游刃有余,安全第一——定期更新证书、设置强密码、限制访问IP,才能真正用好自己的VPN服务器。

手把手教你设置VPN服务器,从零开始搭建安全远程访问通道  第1张

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