CentOS系统中配置OpenVPN服务的完整指南:从安装到客户端连接
在现代企业网络和远程办公环境中,虚拟私人网络(VPN)已成为保障数据安全传输的重要手段,CentOS作为一款稳定、开源且广泛应用于服务器环境的操作系统,是部署OpenVPN服务的理想选择,本文将详细介绍如何在CentOS 7或CentOS 8/9上安装、配置并启动OpenVPN服务,最终实现安全的远程访问。
第一步:准备工作
确保你的CentOS服务器具备公网IP地址,并已更新系统软件包:
sudo yum update -y
关闭防火墙或开放必要的端口(默认为UDP 1194):
sudo systemctl disable firewalldsudo firewall-cmd --permanent --add-port=1194/udp sudo firewall-cmd --reload
第二步:安装OpenVPN及相关工具
使用EPEL源安装OpenVPN及easy-rsa(用于证书管理):
sudo yum install epel-release -y sudo yum install openvpn easy-rsa -y
第三步:生成SSL/TLS密钥对
进入easy-rsa目录并初始化PKI环境:
make-cadir /etc/openvpn/easy-rsa cd /etc/openvpn/easy-rsa
编辑vars文件,设置国家、组织等信息(如CN=China, O=MyCompany),然后执行:
./clean-all ./build-ca ./build-key-server server ./build-key client1 ./build-dh
步骤会生成服务器证书、客户端证书、Diffie-Hellman参数等关键文件。
第四步:配置OpenVPN服务器
复制示例配置文件并修改:
cp /usr/share/doc/openvpn-*/sample-config-files/server.conf /etc/openvpn/ nano /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 nobody
persist-key
persist-tun
status /var/log/openvpn-status.log
verb 3
第五步:启用IP转发与NAT规则
在/etc/sysctl.conf中启用IP转发:
net.ipv4.ip_forward = 1
应用更改:
sysctl -p
配置iptables NAT:
sudo iptables -t nat -A POSTROUTING -s 10.8.0.0/24 -o eth0 -j MASQUERADE sudo service iptables save
第六步:启动OpenVPN服务
sudo systemctl enable openvpn@server sudo systemctl start openvpn@server
第七步:客户端配置与连接
将ca.crt、client1.crt、client1.key和ta.key(若使用TLS-auth)打包发送给客户端,客户端配置文件(如client.ovpn)应包含:
client
dev tun
proto udp
remote your_server_ip 1194
resolv-retry infinite
nobind
persist-key
persist-tun
ca ca.crt
cert client1.crt
key client1.key
tls-auth ta.key 1
comp-lzo
verb 3
完成上述步骤后,客户端即可通过OpenVPN GUI或命令行工具连接至服务器,实现安全的远程访问。
此方案不仅适用于企业内部员工远程办公,也可用于跨地域站点互联,是构建私有网络基础设施的可靠选择。

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

