CentOS Linux VPS架设VPN教程[图解]

林继 VPS 知识 2,812 共写了1331个字 (2012-06-27 23:15:06) 没有评论 打印 扫描二维码 百度已收录

有很多朋友需要VPN来使用,但是购买别人VPN服务来使用却又限速又限流量,而且不稳定,价格还奇高。为什么不动手架设自己的VPN服务器来使用呢?自己架设VPN的成本非常低,比如购买buyvm VPS,最便宜的15$/年,换成RMB才一百元不到,心动了吧?心动不如行动,下面是架设VPN的教程:

一、首先检查你VPS的PPP和TUN有没有启用:

  1. cat /dev/ppp
  2. cat /dev/net/tun

显示结果为:cat: /dev/ppp: No such device or addresscat: /dev/net/tun: File descriptor in bad state,表明通过,上述两条只要有一个没通过都不行。如果没有启用,你可以给VPS提供商Submit 一个 Ticket请求开通:

  1. Hello
  2.  
  3. Could you enabled TUN-TAP for me? I want run pptp-vpn on my VPS.
  4. Thank you.

确认PPP和TUN启用后,开始安装ppp和iptables:

  1. yum install -y ppp iptables

1.png

二、安装pptp:

  1. rpm -ivh http://acelnmp.googlecode.com/files/pptpd-1.3.4-1.rhel5.1.i386.rpm(32位系统)
  2.  
  3. rpm -ivh http://acelnmp.googlecode.com/files/pptpd-1.3.4-1.rhel5.1.x86_64.rpm(64位系统)

2.png

三、配置pptp,编辑/etc/pptpd.conf文件:

  1. vim /etc/pptpd.conf

3.png

把下面字段前面的#去掉:

  1. localip 192.168.0.1
  2. remoteip 192.168.0.234-238,192.168.0.245

4.png

四、编辑/etc/ppp/options.pptpd 文件:

  1. vim /etc/ppp/options.pptpd

5.png

去掉ms-dns前面的#,并使用Google的DNS服务器,修改成如下字段:

  1. ms-dns 8.8.8.8
  2. ms-dns 8.8.4.4

6.png

五、设置VPN账号密码,编辑/etc/ppp/chap-secrets这个文件:

  1. vim /etc/ppp/chap-secrets

7.png

六、修改内核设置,使其支持转发,编辑 /etc/sysctl.conf 文件:

  1. vim /etc/sysctl.conf

将“net.ipv4.ip_forward”的值改为1,同时在“net.ipv4.tcp_syncookies = 1”前面加#

8.png

七、使sysctl.conf配置文件生效并添加iptables转发规则:

  1. sysctl -p
  2. iptables -t nat -A POSTROUTING -s 192.168.0.0/24 -j SNAT --to-source ***.***.***.*** 
  3. (***.***.***.***为你VPS的公网IP地址)

保存iptables转发规则:

  1. /etc/init.d/iptables save

重启iptables:

  1. /etc/init.d/iptables restart

重启pptp服务:

  1. /etc/init.d/pptpd restart

设置开机自动运行pptp服务:

  1. chkconfig pptpd on

设置开机自动运行iptables服务:

  1. chkconfig iptables on

9.png

至此,Linux VPS架设VPN完成,如果连接出现错误619则输入如下命令解决:

  1. rm /dev/ppp
  2. mknod /dev/ppp c 108 0

如果出现错误734则修改/etc/ppp/options.pptpd文件,在require-mppe-128字段前面加#然后windows客户端连接按下图设置即可。

link.png

如果觉得我的文章对您有用,请随意赞赏。您的支持将鼓励我继续创作!

发表评论

电子邮件地址不会被公开。 必填项已用*标注

< >