Linux-Manual

VPN(Virtual Private Network)介绍

VPN 介绍

VPN 分类有很多,这里主要讲 PPTPD 和 L2TPD、OpenVPN

PPTPD 安装

PPTPD 服务配置

L2TPD 安装

L2TPD 服务配置

ipsec saref = yes           
require chap = yes   
refuse pap = yes   
require authentication = yes  
ppp debug = yes  
length bit = yes
ip range = 192.168.1.10-192.168.1.200              #这是客户端连接本机的IP端限制
local ip = 172.31.201.255        #这是本机服务器端的内网 IP
pppoptfile = /etc/ppp/options.xl2tpd        #指定本机的 PPP 配置文件地址,如果你的 PPP 配置文件地址不是这里那就改下
refuse-mschap-v2           
refuse-mschap           
ms-dns 8.8.8.8           #配置DNS,如果是境外服务器最好改为google的,国内的看情况
ms-dns 8.8.4.4           #配置DNS,如果是境外服务器最好改为google的,国内的看情况
asyncmap 0           
auth           
lock           
hide-password           
local           
name l2tpd           
proxyarp           
lcp-echo-interval 30           
lcp-echo-failure 4           
refuse           
refuse           
refuse   

OpenVPN 安装

OpenVPN 服务配置

禁用 selinux

生成OpenVPN需要的服务器、客户端证书

设置OpenVPN服务端配置文件

port 1194 # 端口一般我们不改
proto udp # 默认使用udp,如果使用HTTP Proxy,改成tcp,必须使用tcp协议,还需要注意的是:需要与客户端配置保持一致,等下客户端配置会说道
dev tun
ca /usr/share/easy-rsa/2.0/keys/ca.crt # 这一行默认值为:ca ca.crt
cert /usr/share/easy-rsa/2.0/keys/server.crt # 这一行默认值为:cert server.crt
key /usr/share/easy-rsa/2.0/keys/server.key  # 这一行默认值为:key server.key
dh /usr/share/easy-rsa/2.0/keys/dh2048.pem  # 这一行默认值为:dh dh2048.pem
server 10.192.170.0 255.255.255.0  # 给客户的分配的局域网IP段,默认虚拟局域网网段,不要和实际的局域网冲突即可,这个10.192.170.0跟下面还有一个地方配置也有关联,需要注意
ifconfig-pool-persist ipp.txt # 启用了ipp.txt作为客户端和virtual IP的对应表,以方便客户端重新连接可以获得同样的IP;
keepalive 10 120
comp-lzo
persist-key
persist-tun
status openvpn-status.log  # OpenVPN的状态日志,默认为/etc/openvpn/openvpn-status.log
log openvpn.log # OpenVPN的运行日志,默认为/etc/openvpn/openvpn.log 
log-append openvpn.log
verb 3

push "redirect-gateway def1 bypass-dhcp"
push "dhcp-option DNS 8.8.8.8"
push "dhcp-option DOMAIN-SEARCH ap-northeast-1.compute.internal"
push "dhcp-option DOMAIN-SEARCH ec2.drawbrid.ge"

配置内核和防火墙,开启nat功能,启动服务

辨别你的 VPS 是属于那种虚拟方式,主流有:Xen KVM OpenVZ,方法:

启动openvpn并设置为开机启动

OpenVPN客户端配置

下载 Windows 客户端: https://openvpn.net/index.php/download/community-downloads.html

Mac 用户下载这个 tunnelblick(该地址需要开穿越): http://code.google.com/p/tunnelblick/

到你本地的电脑上(window电脑在安装好OpenVPN软件后可以把如上证书拷贝到如下文件夹里:C:\Program Files\OpenVPN\config )

从服务器找到这个文件:/usr/share/doc/openvpn-2.3.11/sample/sample-windows/sample.ovpn,下载到本地电脑这个目录下:C:\Program Files\OpenVPN\config 然后把这个文件改名字为:client1.ovpn 文件内如如下, 其他不用改只要把SERVER-IP 改成你服务器的 IP

client        #这个client不是自定义名称 不能更改
dev tun       #要与前面server.conf中的配置一致。
proto udp              #要与前面server.conf中的配置一致。
remote 45.32.90.22 1194    #将45.32.90.22替换为你VPS的IP,端口也与前面的server.conf中配置一致。
resolv-retry infinite
nobind
persist-key
persist-tun
ca ca.crt              #具体名称以刚下载的为准
cert client1.crt              #具体名称以刚下载的为准
key client1.key              #具体名称以刚下载的为准
comp-lzo
verb 3

VPN 资料