热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Linux设置GRE隧道

通用路由封装(GRE)是由思科系统开发的隧道协议,可以在虚拟点对点链路或互联网协议网络上的点对多点链路中

介绍

通用路由封装(GRE)是由思科系统开发的隧道协议,可以在虚拟点对点链路或互联网协议网络上的点对多点链路中封装各种网络层协议。


GRE隧道在某些情况下很有用,例如使用另一个具有保护的服务器来保护没有DDoS保护的服务器,或者启用仅允许IPv4的应用程序也接受IPv6。

先决条件

首先,您必须有两台具有根访问权限的服务器。在本教程中,它们将被称为服务器A和服务器B,并将具有以下特征:


  • 服务器A - 所有客户端都将连接到的服务器

  • IP:198.51.100.1

  • GRE隧道内部IP:10.0.0.1

  • 服务器B - 实际运行所有应用程序的服务器

  • IP:203.1.113.1

  • GRE隧道内部IP:10.0.0.2


第1步-模块加载

要在Linux上设置GRE隧道,您必须在内核中加载ip_gre模块。要确保它已加载,只需执行以下操作:

    sudo modprobe ip_gre
    lsmod | grep gre

    你应该看看:

      ip_gre                 #####  0
      gre                    #####  1 ip_gre

      如果您看到其他内容,您的内核可能不支持GRE。


      为了转发进出GRE隧道的所有流量,我们将使用iptables和iproute2,它们应该已经安装在所有主要的linux发行版中。如果它们没有安装,请使用以下命令


      对于基于Debian的发行版:

        sudo apt install iptables iproute2

        对于基于红帽的发行版:

          sudo yum install iptables iproute2

          第2步-隧道设置

          首先,我们必须建立我们的隧道。


          在服务器A上执行此代码以启用ip转发:

            sudo echo 'net.ipv4.ip_forward=1' >> /etc/sysctl.conf
            sudo sysctl -p

            现在创建一个新的网络界面,该界面将使用GRE隧道:

              sudo ip tunnel add gre1 mode gre local 198.51.100.1 remote 203.0.113.1 ttl 255
              sudo ip addr add 10.0.0.1/30 dev gre1
              sudo ip link set gre1 up

              然后,在服务器B上更改IP时也这样做:

                sudo ip tunnel add gre1 mode gre local 203.0.113.1 remote 198.51.100.1 ttl 255
                sudo ip addr add 10.0.0.2/30 dev gre1
                sudo ip link set gre1 up

                第2.1步-Ping测试

                在服务器A上做:

                  ping 10.0.0.2

                  在服务器B上做:

                    ping 10.0.0.1

                    如果ping工作正常,那么GRE隧道设置正确。

                    第3步-新路线实施

                    需要一条路线来确保通过GRE隧道输入的数据得到正确处理。


                    在服务器B上执行:

                      sudo echo '100 GRE' >> /etc/iproute2/rt_tables
                      sudo ip rule add from 10.0.0.0/30 table GRE
                      sudo ip route add default via 10.0.0.1 table GRE

                      第4步-NAT配置

                      NAT用于将数据传递到我们的GRE和另一端。


                      在服务器A上运行:

                        iptables -t nat -A POSTROUTING -s 10.0.0.0/30 ! -o gre+ -j SNAT --to-source 198.51.100.1

                        要测试在服务器B上执行的出站连接,请执行以下命令:


                        对于基于Debian的发行版:

                          sudo apt install curl

                          对于基于红帽的发行版:

                            sudo yum install curl

                            然后:

                              curl http://www.cpanel.net/showip.cgi --interface 10.0.0.2

                              最后,您应该会看到服务器 A 的 IP。


                              第5步-端口转发

                              在服务器A上运行此命令,以允许进出服务器B的所有数据:

                                sudo iptables -A FORWARD -d 10.0.0.2 -m state --state NEW,ESTABLISHED,RELATED -j ACCEPT
                                sudo iptables -A FORWARD -s 10.0.0.2 -m state --state NEW,ESTABLISHED,RELATED -j ACCEPT

                                然后,我们希望将所有数据从服务器A转发到服务器B。


                                在服务器A上执行:

                                  sudo iptables -t nat -A PREROUTING -d 198.51.100.1 -p PROTO -m PROTO --dport PORT -j DNAT --to-destination 10.0.0.2

                                  用实际的PROTO和PORT替换。


                                  例如,要将所有数据转发到Web服务器(端口TCP 80),我们必须运行:

                                    sudo iptables -t nat -A PREROUTING -d 198.51.100.1 -p TCP -m TCP --dport 80 -j DNAT --to-destination 10.0.0.2

                                    我们必须为我们使用的每个端口这样做。

                                    第6步-持久性

                                    在服务器上重新启动,我们所做的所有事情都将被消灭。为了确保GRE隧道和其他所有内容在重新启动后都能正常工作,我们必须编辑文件/etc/rc.local,并添加我们所做的所有命令(回声命令除外!)在exit 0之前。

                                    结论

                                    现在,如果我们使用我们配置的端口(例如端口TCP 80)连接到服务器A,我们将在不知不觉中连接到服务器B。


                                    注意:如果您使用CSF管理iptables,您可能必须将所有iptables命令放在您的/etc/csf/csfpost.sh中,并将两台服务器的IP(也是GRE命令)插入/etc/csf/csf.allow中。

                                    国庆节快乐


                                    26

                                    27

                                    28

                                    29

                                    30

                                    1

                                    2

                                    3

                                    4

                                    5

                                    6

                                    7

                                    8

                                    9


                                    关注微信公众号:SFS运维工具箱每天定时更新各类教程文章与线报福利!



                                    推荐阅读
                                    • 成功安装Sabayon Linux在thinkpad X60上的经验分享
                                      本文分享了作者在国庆期间在thinkpad X60上成功安装Sabayon Linux的经验。通过修改CHOST和执行emerge命令,作者顺利完成了安装过程。Sabayon Linux是一个基于Gentoo Linux的发行版,可以将电脑快速转变为一个功能强大的系统。除了作为一个live DVD使用外,Sabayon Linux还可以被安装在硬盘上,方便用户使用。 ... [详细]
                                    • Spring源码解密之默认标签的解析方式分析
                                      本文分析了Spring源码解密中默认标签的解析方式。通过对命名空间的判断,区分默认命名空间和自定义命名空间,并采用不同的解析方式。其中,bean标签的解析最为复杂和重要。 ... [详细]
                                    • 搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的详细步骤
                                      本文详细介绍了搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的步骤,包括环境说明、相关软件下载的地址以及所需的插件下载地址。 ... [详细]
                                    • 本文介绍了数据库的存储结构及其重要性,强调了关系数据库范例中将逻辑存储与物理存储分开的必要性。通过逻辑结构和物理结构的分离,可以实现对物理存储的重新组织和数据库的迁移,而应用程序不会察觉到任何更改。文章还展示了Oracle数据库的逻辑结构和物理结构,并介绍了表空间的概念和作用。 ... [详细]
                                    • Metasploit攻击渗透实践
                                      本文介绍了Metasploit攻击渗透实践的内容和要求,包括主动攻击、针对浏览器和客户端的攻击,以及成功应用辅助模块的实践过程。其中涉及使用Hydra在不知道密码的情况下攻击metsploit2靶机获取密码,以及攻击浏览器中的tomcat服务的具体步骤。同时还讲解了爆破密码的方法和设置攻击目标主机的相关参数。 ... [详细]
                                    • 本文介绍了在Mac上搭建php环境后无法使用localhost连接mysql的问题,并通过将localhost替换为127.0.0.1或本机IP解决了该问题。文章解释了localhost和127.0.0.1的区别,指出了使用socket方式连接导致连接失败的原因。此外,还提供了相关链接供读者深入了解。 ... [详细]
                                    • HDFS2.x新特性
                                      一、集群间数据拷贝scp实现两个远程主机之间的文件复制scp-rhello.txtroothadoop103:useratguiguhello.txt推pushscp-rr ... [详细]
                                    • Android系统移植与调试之如何修改Android设备状态条上音量加减键在横竖屏切换的时候的显示于隐藏
                                      本文介绍了如何修改Android设备状态条上音量加减键在横竖屏切换时的显示与隐藏。通过修改系统文件system_bar.xml实现了该功能,并分享了解决思路和经验。 ... [详细]
                                    • 本文介绍了在mac环境下使用nginx配置nodejs代理服务器的步骤,包括安装nginx、创建目录和文件、配置代理的域名和日志记录等。 ... [详细]
                                    • 本文介绍了如何使用C#制作Java+Mysql+Tomcat环境安装程序,实现一键式安装。通过将JDK、Mysql、Tomcat三者制作成一个安装包,解决了客户在安装软件时的复杂配置和繁琐问题,便于管理软件版本和系统集成。具体步骤包括配置JDK环境变量和安装Mysql服务,其中使用了MySQL Server 5.5社区版和my.ini文件。安装方法为通过命令行将目录转到mysql的bin目录下,执行mysqld --install MySQL5命令。 ... [详细]
                                    • CentOS 6.5安装VMware Tools及共享文件夹显示问题解决方法
                                      本文介绍了在CentOS 6.5上安装VMware Tools及解决共享文件夹显示问题的方法。包括清空CD/DVD使用的ISO镜像文件、创建挂载目录、改变光驱设备的读写权限等步骤。最后给出了拷贝解压VMware Tools的操作。 ... [详细]
                                    • 本文介绍了在CentOS上安装Python2.7.2的详细步骤,包括下载、解压、编译和安装等操作。同时提供了一些注意事项,以及测试安装是否成功的方法。 ... [详细]
                                    • RouterOS 5.16软路由安装图解教程
                                      本文介绍了如何安装RouterOS 5.16软路由系统,包括系统要求、安装步骤和登录方式。同时提供了详细的图解教程,方便读者进行操作。 ... [详细]
                                    • Vagrant虚拟化工具的安装和使用教程
                                      本文介绍了Vagrant虚拟化工具的安装和使用教程。首先介绍了安装virtualBox和Vagrant的步骤。然后详细说明了Vagrant的安装和使用方法,包括如何检查安装是否成功。最后介绍了下载虚拟机镜像的步骤,以及Vagrant镜像网站的相关信息。 ... [详细]
                                    • 本文介绍了禅道作为一款国产开源免费的测试管理工具的特点和功能,并提供了禅道的搭建和调试方法。禅道是一款B/S结构的项目管理工具,可以实现组织管理、后台管理、产品管理、项目管理和测试管理等功能。同时,本文还介绍了其他软件测试相关工具,如功能自动化工具和性能自动化工具,以及白盒测试工具的使用。通过本文的阅读,读者可以了解禅道的基本使用方法和优势,从而更好地进行测试管理工作。 ... [详细]
                                    author-avatar
                                    小市民828_719
                                    这个家伙很懒,什么也没留下!
                                    PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
                                    Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有