在CentOS 6.2上搭建OpenVPN Server
OpenVPN是不同于PPTP、L2TP的另一种VPN软件包,基于SSL的VPN。OpenVPN使用需要客户端支持。这里系统为CentOS6.2。
一、检查OpenVPN所需环境
OpenVPN需要TUN设备支持,还需要iptables的nat模块支持。
1、检查TUN模块:
|
|
2、在OpenVZ虚拟化的VPS上,需要管理员在母鸡上打开TUN/TAP设备。
|
|
如果返回:
cat: /dev/net/tun: File descriptor in bad state
VPS的TUN/TAP已经可以使用。
如果返回:
cat: /dev/net/tun: No such device
或者其它,说明TUN/TAP设备没有被正确配置,需要与客服沟通开通TUN/TAP。
3、检查OpenVZ的VPS上iptables是否支持:
|
|
如果返回:
iptables: Unknown error 4294967295
说明支持。
二、编译安装OpenVPN
1、安装LZO
LZO是一种数据压缩算法。
|
|
2、安装OpenVPN
|
|
此时提示:
configure: error: OpenSSL Crypto headers not found.
原来是openssl的开发包没有安装:
|
|
继续安装:
|
|
三、生成密钥和证书
1、初始化PIK
|
|
设置最后的证书字段值:
|
|
使vars设置生效:
|
|
报错:
No /etc/openvpn/easy-rsa/2.0/openssl.cnf file could be found
Further invocations will fail
将/etc/openvpn/easy-rsa/2.0目录下的openssl-1.0.0.cnf改名为openssl.cnf可解决:
|
|
继续运行脚本设置变量,并清理:
|
|
建立私钥:
|
|
build-ca脚本用于生成一个1024位的RSA私钥,由于前面已经设置过vars文件,直接按回车。
2、建立server key
|
|
前面几个按回车,中间有extra属性要填,最后按两个y。
3、建立client key
|
|
和建立server key基本相同,生成的每个客户端证书名字要不同。一份客户端证书对应一个客户端。
4、生成Diffie Hellman参数
|
|
5、将keys下的所有文件下载到本地
可以用winscp等工具。
6、创建服务端配置文件
将源代码解压后目录下的规范配置文件复制过来。
|
|
编辑配置文件:
|
|
找到:
ca ca.crt
cert server.crt
key server.key
dh dh1024.pem
修改为:
|
|
并将以下几句前的分号去掉:
|
|
7、设置IP包转发
|
|
将“net.ipv4.ip_forward”的值改为1。
使sysctl.conf配置生效:
|
|
这里忽略这些错误
|
|
8、添加iptables转发
|
|
PS:如果iptables save报错
iptables: Saving firewall rules to /etc/sysconfig/iptables: /etc/init.d/iptables: line 268: restorecon: command not found
要安装一个软件包:
|
|
9、设置OpenVPN开机自启动
|
|
10、启动OpenVPN
|
|
四、安装Windows客户端OpenVPN GUI For Windows
1、下载客户端软件并安装
http://openvpn.se/files/install_packages/openvpn-2.0.9-gui-1.0.3-install.exe
2、配置客户端
将下载下来的keys文件夹内的:
ca.crt
ca.key
client1.crt
client1.csr
client1.key
复制到客户端安装路径config文件夹下。
例如:
C:Program FilesOpenVPNconfig
将安装路径sample-config文件夹下的client.ovpn也复制到config文件夹内。
打开client.ovpn,找到:
remote my-server-1 1194
将my-server-1修改为OpenVPN服务端的ip地址。
找到:
cert client.crt
key client.key
修改为客户端证书的名字。
cert client1.crt
key client1.key
在最后加上:
redirect-gateway def1
使客户端把OpenVPN服务器IP设为默认网关。
双击client.ovpn即可启动openvpn,或者通过OpenVPN GUI的控制启动VPN。
随后到ip查询的网站上查看自己的ip是否为OpenVPN服务器ip。
备注:
客户端连接时报错:
There are no TAP-Win32 adapters on this system. You should be able to create a TAP-Win32 adapter by going to Start -> All Programs -> OpenVPN -> Add a new TAP-Win32 virtual ethernet adapter.
需要安装TAP-Win32 virtual ethernet adapter。
参考资料:
http://rashost.com/blog/centos-openvpn-install
http://www.cnblogs.com/fangbo/archive/2011/08/04/2127710.html
http://www.fallday.org/archives/230
http://openvpn.net/index.php/open-source/documentation/howto.html
转自:http://www.live-in.org/archives/1112.html