在现代企业网络和远程办公环境中,虚拟私人网络(VPN)已成为保障数据安全传输的重要手段,CentOS作为一款稳定、开源且广泛应用于服务器环境的操作系统,是部署OpenVPN服务的理想选择,本文将详细介绍如何在CentOS 7或CentOS 8/9上安装、配置并测试OpenVPN服务,最终实现安全的远程访问。

确保你已登录到一台运行CentOS的服务器,并具备root权限或sudo权限,我们以CentOS 7为例进行演示(CentOS 8/9操作类似,但需注意软件包管理命令差异,如dnf代替yum)。

第一步:更新系统并安装依赖
执行以下命令更新系统软件包列表并升级现有程序:

sudo yum update -y

接着安装OpenVPN所需的依赖项:

sudo yum install epel-release -y
sudo yum install openvpn easy-rsa -y

easy-rsa 是用于生成SSL/TLS证书和密钥的工具,是OpenVPN身份认证的核心组件。

第二步:配置证书颁发机构(CA)
进入EasyRSA目录并初始化PKI(公钥基础设施):

make-cadir /etc/openvpn/easy-rsa
cd /etc/openvpn/easy-rsa

编辑 vars 文件,设置你的国家、组织等信息(如CN=China, O=MyCompany),避免使用默认值,提高安全性,然后执行:

./clean-all
./build-ca

这将生成一个名为 ca.crt 的根证书文件,它是后续所有证书的信任基础。

第三步:生成服务器证书和密钥
执行以下命令创建服务器证书:

./build-key-server server

按提示输入信息(如Common Name设为server),确认后生成 server.crtserver.key

第四步:生成客户端证书(可选多个)
每个客户端都需要单独的证书,例如为用户“client1”生成:

./build-key client1

同时生成Diffie-Hellman参数(用于密钥交换):

./build-dh

第五步:配置OpenVPN服务端
复制模板配置文件:

cp /usr/share/doc/openvpn-*/sample/sample-config-files/server.conf /etc/openvpn/

编辑 /etc/openvpn/server.conf,关键修改如下:

  • port 1194:指定监听端口(建议改为非标准端口如5000以规避扫描)
  • proto udp:使用UDP协议,性能更优
  • dev tun:使用隧道模式
  • ca ca.crtcert server.crtkey server.key:引用刚刚生成的证书文件
  • dh dh.pem:引用Diffie-Hellman参数
  • server 10.8.0.0 255.255.255.0:定义内部IP池
  • push "redirect-gateway def1 bypass-dhcp":强制客户端流量通过VPN
  • push "dhcp-option DNS 8.8.8.8":设置DNS服务器

第六步:启用IP转发与防火墙规则
编辑 /etc/sysctl.conf,取消注释:

net.ipv4.ip_forward = 1

应用更改:

sysctl -p

配置防火墙(firewalld)允许OpenVPN端口:

sudo firewall-cmd --add-port=1194/udp --permanent
sudo firewall-cmd --add-masquerade --permanent
sudo firewall-cmd --reload

第七步:启动服务并测试
启动OpenVPN服务:

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

检查状态:

systemctl status openvpn@server

将客户端配置文件(.ovpn)分发给用户,包含ca.crt、client1.crt、client1.key及服务器IP地址,即可完成客户端连接。

至此,你在CentOS上成功搭建了一个安全、可扩展的OpenVPN服务,此方案适用于中小型团队远程办公、跨地域访问内网资源等场景,是值得掌握的网络工程技能。

CentOS系统中配置OpenVPN服务的完整指南,从安装到客户端连接  第1张

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