CentOS Linux VPS安装IPSec+L2TP VPN
CentOS Linux VPS安装IPSec+L2TP VPN 时间 -- :: 天使羊波波闪耀光芒 相似文章 () 原文 http://www.live-in.org/archives/818.html 第二层隧道协议L2TP(Layer Tunneling Protocol)是一种工业标准的Internet隧道协议,它使用UDP的1701端口进行通信。L2TP本身并没有任何加密,但是我们可以使用IPSec对L2TP包进行加密。L2TP VPN比PPTP VPN搭建复杂一些。 一、安装IPsec,Openswan是Linux系统上IPsec的一个实现。 官网: http://www.openswan.org/ 、安装必备软件: yum -y install make gcc gmp-devel bison flex lsof xmlto; make,gcc我们都知道是干什么用的了。 gmp-devel: Development tools for the GNU MP arbitrary precision library. bison: A GNU general-purpose parser generator. flex: A tool for creating scanners (text pattern recognizers). 看上去好像都和编译器有关? 、安装Openswan: 由于更新源上的版本是2..el5_6.4较老,这里使用源码安装,目前最新版是2.6.35。 cd /tmp wget https://download.openswan.org/openswan//old/openswan-2.6/openswan-2.6.21.tar.gz tar -zxvf openswan-.tar.gz cd openswan- make programs install PS:进openswan-2.6.21目录看到已经有Makefile文件了,阅读目录内的INSTALL写着 Building userland: make programs install 、配置IPSec 编辑配置文件/etc/ipsec.conf: cp /etc/ipsec.conf /etc/ipsec.conf.bak vim /etc/ipsec.conf 查找protostack=auto,修改为: protostack=netkey 在最后加入: conn L2TP-PSK-NAT rightsubnet=vhost:%priv also=L2TP-PSK-noNAT conn L2TP-PSK-noNAT authby=secret pfs=no auto=add keyingtries= rekey=no ikelifetime=8h keylife=1h type=transport left=YOUR.SERVER.IP.ADDRESS leftprotoport=/ right=%any rightprotoport=/%any “YOUR.SERVER.IP.ADDRESS”换成VPS的外网IP。其中一些设置含义可以参考/etc/ipsec.d/examples/l2tp-psk.conf文件的内容。 、设置共享密钥PSK 编辑配置文件/etc/ipsec.secrets: vim /etc/ipsec.secrets 输入: YOUR.SERVER.IP.ADDRESS %any: PSK "YourSharedSecret" 、修改包转发设置 复制以下两段代码在终端里运行: for each in /proc/sys/net/ipv4/conf/* do echo 0 > $each/accept_redirects echo 0 > $each/send_redirects done echo 1 >/proc/sys/net/core/xfrm_larval_drop 修改内核设置,使其支持转发,编辑/etc/sysctl.conf文件: vim /etc/sysctl.conf 将“net.ipv4.ip_forward”的值改为1。 使修改生效: sysctl -p 6、重启IPSec: /etc/init.d/ipsec restart 查看系统IPSec安装和启动的正确性: ipsec verify 没有报[FAILED]就可以了。 我用的这个VPS结果显示如下: 二、安装L2TP(xl2tpd和rp-l2tp) xl2tpd是由Xelerance Corporation维护的l2tpd应用。但是xl2tpd没有l2tp-control,需要从rp-l2tp这个里面提取。所以要装这两个软件包。 1、安装必备软件: yum install libpcap-devel ppp policycoreutils 2、安装xl2tpd和rp-l2tp: cd /tmp wget http://sourceforge.net/projects/rp-l2tp/files/rp-l2tp/0.4/rp-l2tp-0.4.tar.gz tar -zxvf rp-l2tp-0.4.tar.gz cd rp-l2tp-0.4 ./configure make cp handlers/l2tp-control /usr/local/sbin/ mkdir /var/run/xl2tpd/ ln -s /usr/local/sbin/l2tp-control /var/run/xl2tpd/l2tp-control xl2tpd用的是目前最新的xl2tpd-1.3.0: cd /tmp wget http://www.xelerance.com/wp-content/uploads/software/xl2tpd/xl2tpd-1.3.0.tar.gz tar -zxvf xl2tpd-1.3.0.tar.gz cd xl2tpd-1.3.0 make make install 显示安装了如下一些内容: 3、建立xl2tpd配置文件: mkdir /etc/xl2tpd vim /etc/xl2tpd/xl2tpd.conf 加入: [global] ipsec saref = yes [lns default] ip range = 10.82.88.2-10.82.88.254 local ip = 10.82.88.1 refuse chap = yes refuse pap = yes require authentication = yes ppp debug = yes pppoptfile = /etc/ppp/options.xl2tpd length bit = yes 4、配置ppp 建立options.xl2tpd文件: vim /etc/ppp/options.xl2tpd 加入: require-mschap-v2 ms-dns 8.8.8.8 ms-dns 8.8.4.4 asyncmap 0 auth crtscts lock hide-password modem debug name l2tpd proxyarp lcp-echo-interval 30 lcp-echo-failure 4 5、设置拨号用户名和密码: vim /etc/ppp/chap-secrets 6、添加iptables转发规则: iptables --table nat --append POSTROUTING --jump MASQUERADE iptables -t nat -A POSTROUTING -s 10.1.2.0/24 -o eth1 -j MASQUERADE iptables -I FORWARD -s 10.1.2.0/24 -j ACCEPT iptables -I FORWARD -d 10.1.2.0/24 -j ACCEPT /etc/init.d/iptables save service iptables restart 保存iptables转发规则: /etc/init.d/iptables save 重启iptables: /etc/init.d/iptables restart 7、以debug方式启动l2tp,查看有无错误: xl2tpd -D 显示如下: xl2tpd[9647]: Enabling IPsec SAref processing for L2TP transport mode SAs xl2tpd[9647]: IPsec SAref does not work with L2TP kernel mode yet, enabling forceuserspace=yes xl2tpd[9647]: setsockopt recvref[22]: Protocol not available xl2tpd[9647]: This binary does not support kernel L2TP. xl2tpd[9647]: xl2tpd version xl2tpd-1.3.0 started on myserver.localdomain PID:9647 xl2tpd[9647]: Written by Mark Spencer, Copyright (C) 1998, Adtran, Inc. xl2tpd[9647]: Forked by Scott Balmos and David Stipp, (C) 2001 xl2tpd[9647]: Inherited by Jeff McAdams, (C) 2002 xl2tpd[9647]: Forked again by Xelerance (www.xelerance.com) (C) 2006 xl2tpd[9647]: Listening on IP address 0.0.0.0, port 1701 说明已经在监听端口了。现在可以在windows上建立L2TP拨号连接了。 三、设置开机启动 vim /etc/rc.local 加入: for each in /proc/sys/net/ipv4/conf/* do echo 0 > $each/accept_redirects echo 0 > $each/send_redirects done echo 1 >/proc/sys/net/core/xfrm_larval_drop /etc/init.d/ipsec restart /usr/local/sbin/xl2tpd 四、建立连接时遇到的问题 windows下新建一个VPN连接,属性-网络-VPN类型选择L2TP IPSec VPN,安全-IPSec设置-输入共享密钥。 提示“错误 768:因为加密数据失败连接尝试失败。” IPSEC services被关掉了。开始-运行-输入services.msc,然后在服务中启用“IPSEC services”即可。 参考资料: http://hi.baidu.com/wzypunk/blog/item/4566903cf418663b96ddd8b0.html http://www.wifay.com/blog/2010/08/21/centos-install-ipsec-l2tp-vpn/
CentOS Linux VPS安装IPSec+L2TP VPN的更多相关文章
- CENTOS/UBUNTU一键安装IPSEC/IKEV2 VPN服务器
1.在azure上创建ubuntu虚拟机 选择v15.04 server 版本 2.添加端口号 3.远程桌面到ubuntu 命令行 输入 sudo su 输入创建 ubuntu虚拟机 时候的 密码 ...
- setting up a IPSEC/L2TP vpn on CentOS 6 or Red Hat Enterprise Linux 6 or Scientific Linux
This is a guide on setting up a IPSEC/L2TP vpn on CentOS 6 or Red Hat Enterprise Linux 6 or Scientif ...
- CentOS linux下安装和配置Apache+SVN(用浏览器http方式访问SVN目录)
在CentOS linux下安装SVN,我们可以进行以下步骤: 第一步:安装CentOS Linux操作系统,并在CentOS安装进行的同时,自定义安装这一步,一定要勾选Subversion(在“开发 ...
- VMware ESXi CentOS Linux虚拟机安装VMware Tools教
转自VMware ESXi CentOS Linux虚拟机安装VMware Tools教程 | 一米居 http://www.yimiju.com/articles/548.html 最近一周在学习和 ...
- CentOS Linux 系统 安装oracle 11g
CentOS Linux 系统 安装oracle 11g 在Linux系统上安装oracle是比较麻烦,需要配置各种变量啥的,o(︶︿︶)o ,但是没办法,有些东西你总的去接触,而且接触理解的越早越深 ...
- CentOS Linux上安装Oracle11g笔记
CentOS Linux上安装Oracle11g 到 otn.oracle.com 网站上下载 Linux版的oracle 11g 编辑 /etc/sysctl.conf : kernel.shmal ...
- CentOS Linux 7 安装教程
建立新的虚拟机 将CentOS 7 ISO文件插入到CD-Rom 启动虚拟机,F12选择启动方式为CD/DVD 选择Install CentOS Linux 7 加载安装必要文件 选择安装过程所显示的 ...
- CentOS Linux 安装IPSec+L2TP
第二层隧道协议L2TP(Layer 2 Tunneling Protocol)是一种工业标准的Internet隧道协议,它使用UDP的1701端口进行通信.L2TP本身并没有任何加密,但是我们可以使用 ...
- linux vps安装kloxo配置全部过程
第一步如何登录Linux VPS进行远程(SSH)管理 很多人可能用过免费虚拟主机,但绝没有用过好用的免费服务器租用,仅有的少数免费服务器都只针对有较高访问量的大站(以交换广告为条件),而普通小站是无 ...
随机推荐
- Latex论文写作-Texsdudio 快捷键总结
Latex论文写作-Texsdudio 快捷键总结 The keyboard shortcuts can be modified at Options -> Shortcuts. The fo ...
- MySQL-curses/termcap缺失
环境:通前篇 1.错误:缺少 /curses/temrcap checking for termcap functions library... configure: error: No curses ...
- jsp日期插件My97DatePicker
jsp日期插件My97DatePicker 强大的日期控件 使用方便简单 (2010-10-30 18:59:12) 转载▼ 标签: js javascript 日期插件 jsp it 分类: jqu ...
- Yii2 执行流程
原文地址: http://www.cnblogs.com/cresuccess/p/4874330.html
- Yii2 – 如何写一个插件 , 如何做一个扩展
原文地址: http://www.fancyecommerce.com/2016/05/10/yii2-%E5%A6%82%E4%BD%95%E5%86%99%E4%B8%80%E4%B8%AA%E6 ...
- MVC学习笔记一
主要是为了复习昨天所学习到的MVC的基础内容,因为昨天还在申请博客,所以今天补上. 目前主要学习资料是<ASP.NET MVC4 Web 编程> 首先先来一个MVC请求的路径的流程说明. ...
- Mysql利用mysql_multi配置一台主机多个实例(转)
在Mysql官方帮助文档中,详细记录中Mysql的启动方式,有mysqld_safe.mysql.server.mysql_multi这三种.关于mysql_multi的介绍: Mysqld_mult ...
- ASP.NET MVC 自己实现登陆验证过滤器
1.首先添加一个过滤器类,并实现接口中对应的方法 public class YLFAuthorizeAttribute : FilterAttribute, IAuthorizationFilter ...
- VS2010webConfig配置
1.连接SqlServer数据库 <connectionStrings> <add name="ConnectionStringName" connectionS ...
- mapreduce 自定义数据类型的简单的应用
本文以手机流量统计为例: 日志中包含下面字段 现在需要统计手机的上行数据包,下行数据包,上行总流量,下行总流量. 分析:可以以手机号为key 以上4个字段为value传传递数据. 这样则需要自己定义一 ...