当前位置:  技术问答>linux和unix

linux 怎么实现数据包转发

    来源: 互联网  发布时间:2016-06-26

    本文导语:  机器有6个网卡,red hat系统。现在要求从eth0 收到的数据包,从eth2转发出去, eth0:192.168.20.110 eth2:10.3.10.159 隐约知道应该开启linux路由功能,可具体怎么设置就不知道了,急用,能有详细步骤最好,不胜感激 ...

机器有6个网卡,red hat系统。现在要求从eth0 收到的数据包,从eth2转发出去,
eth0:192.168.20.110
eth2:10.3.10.159
隐约知道应该开启linux路由功能,可具体怎么设置就不知道了,急用,能有详细步骤最好,不胜感激

|
Linux环境下双网卡主机路由配置

一、环境:
三台直接相连的计算机主机如图
PC1PC2PC3
其中PC2上有两块网卡eth0、eth1,分别与PC3、PC1相连
------代表网线

二、需求:
将PC2配置为路由器模式,用来在PC1、PC3之间转发报文

三、方法:
将三台主机按照环境所要求用交叉线直接连网后,为三台主机分配网段并配置IP地址。
网段及IP地址分配如下:
主 机名      所在网段        分配IP                     网关
PC1:    192.168.2.0/24   192.168.2.2/24     192.168.2.1

PC2:    192.168.2.0/24   192.168.2.1/24     '与PC1相连的网卡的配置' eth1
              192.168.1.0/24   192.168.1.1/24     '与PC3相连的网卡的配置' eth0

PC3:    192.168.1.0/24   192.168.1.2/24     192.168.1.1

按照上表所示分别将主机IP地址配置好,其中要注意的是,要想使PC2具有报文转发功能,在PC2

上检查/proc/sys/net/ipv4/ip_forward中的值是否为1
命令:
#more /proc/sys/net/ipv4/ip_forward
如果显示其值不为1而是0 输入以下命令:
#echo '1' > /proc/sys/net/ipv4/ip_forward
打开IP转发功能
PC2中的其它配置:
为PC2添加路由,命令:
#route add -net 192.168.1.0 netmask 255.255.255.0 dev eth0
#route add -net 192.168.2.0 netmask 255.255.255.0 dev eth1

四、验证:
PC1:
ping网关
#ping 192.168.2.1
#ping 192.168.1.1
ping PC3:
#ping 192.168.1.2
PC3:
ping网关
#ping 192.168.1.1
#ping 192.168.2.1
pint PC1
#ping 192.168.2.2

五、Bug调试:
出错的原因主要集中在PC2两个地方
1.检查PC2是否允许IP报文转发(/proc/sys/net/ipv4/ip_forward的值是否为1)
2.路由设置是否正确(#route 回车查看)

|
实现:Linux主机做路由,为子网实现共享上网。2个IP,一个公网IP(22.33.44.55),一个内外网关(192.168.0.254)。
     
    首先打开路由转发,并且为了保证开机重启后生效。如下操作:

    1:修改/etc/sycctl.conf,打开路由转发。

    [root@kook ~]# vi /etc/sysctl.conf

    net.ipv4.ip_forward = 1

    2:立即生效

    [root@kook ~]# sysctl -p

    net.ipv4.ip_forward = 1

    net.ipv4.conf.default.rp_filter = 1

    net.ipv4.conf.default.accept_source_route = 0

    kernel.sysrq = 0

    kernel.core_uses_pid = 1

    net.ipv4.tcp_syncookies = 1

    kernel.msgmnb = 65536

    kernel.msgmax = 65536

    kernel.shmmax = 4294967295

    kernel.shmall = 268435456

    添加iptables的NAT,同样保证开机路由生效。

    1:添加iptable的NAT

    [root@kook ~]# iptables -t nat -A POSTROUTING -s 192.168.10.0/24 -o eth0 -j MASQUERADE

    2:修改默认iptables,保障重启开机后仍然生效。

    [root@kook ~]# iptables-save > /etc/sysconfig/iptables

    3:让iptables开机启动

    [root@kook ~]# chkconfig iptables on

    [root@kook ~]# chkconfig ——list iptables

    iptables 0:off 1:off 2:on 3:on 4:on 5:on 6:off

    在子网下测试,是否可以上网。完成。

|
http://www.ithov.com/Linux/Apply/Network/84405.shtml

网上有双网卡路由配置的文章

    
 
 

您可能感兴趣的文章:

  • 请推荐一个linux下数据包转发工具
  • linux9.0下可否实现多个域名邮箱的转发代理设置
  • linux下如何实现串口的转发?
  • 求助linux转发组播包的方法
  • IT科技资讯 iis7站长之家
  • 向高手求助Linux下网络包转发的问题!!!!!!!
  • linux下udp的转发
  • 关于linux下用Ipchains 做地址转发
  • 关于LINUX下数据包转发和保存
  • linux下udp的转发问题
  • 我,一Linux文盲咨询端口转发问题,忘高手解答
  • linux转发数据,局域网A(eth1)的数据是如何发送到另一个网卡eth0所在的网络上的,只需要设置FORWARD的ACCEPT吗?
  • 高分求助linux数据包转发编程问题
  • linux下如何自定义IPV4包?并把它转发到指定网卡上
  • 想找一个从终端设备以串口接收数据然后在ARM(linux内核)板上做一个透明转发以UDP型式发送到一台PC机上程序的人员。有意详读下文!
  • HELP:linux隧道数据路由不能转发
  • 转发:::::安全性最差的OS是Linux::::
  • 关于linux下面的SMTP邮件服务器转发程序开发
  • linux内核 uml转发 高分求助,紧急求救
  • linux下通过crond实现自动执行程序
  • Linux和Unix相对WIN、NETWARE有什么好处?他们之间有什么区别?WIN、NETWARE能实现的功能LINUX和UNIX能实现吗?
  • Linux下c函数dlopen实现加载动态库so文件代码举例
  • linux下如实现与window下的驱动器实现文件共享??
  • Linux内存文件系统(ramdisk)的三种实现方式
  • windows 下的PortTunnel 在linux下怎么实现?或者相应的已经实现的软件?端口映射
  • linux内存文件系统ramfs实现原理
  • 在linux下如何编程实现nslookup命令实现的IP地址和域名互相转换的功能?
  • Linux 共享内存介绍及实现代码
  • 我需要一个模型,在 LINUX C 下。实现线程间的控制,执行,阻塞,再执行。。。。。不知道如何实现。
  • linux下grep命令实现查找多个关键字(与关系和或关系)
  • 我想做linux下的还原备份,实现与还原精灵虚拟还原等一样的功能,应该怎么做?另外现在有实现这种功能的成熟产品是哪一种?
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • Linux c++库boost unordered_set数据插入及查找代码举例
  • 请问在红旗Linux多功能服务器版上(不是数据库服务器版)能否正常安装使用Oracle?红旗Linux数据库服务器版要比红旗Linux多功能服务器版贵
  • Linux c++库boost unordered_map数据插入及查找代码举例
  • linux串口程序可以发送数据,但是不能接受数据?谁知道原因?
  • Linux和windows下用mysql c++ library操作Mysql数据库
  • 请问Linux数据库编程是否也可以支持通用的SQL语言进行数据库编写.
  • 急,请问数据流是经过zip压缩的,Linux下如何编程,解开压缩的数据流?
  • Linux下Oracle数据库,dbstart持续不动,数据库无法启动解决
  • linux下能调用*.sql备份的数据库数据么?
  • linux下用什么办法连接oracle数据库并且读取数据呢?(用c++代码实现时)
  • 强人,linux下驱动相关数据结构和usb设备数据结构之间的功能分析
  • 请教在linux系统开发环境下,有没有db和dbf数据库引擎,如何使用这个数据库?
  • 在安装Linux时,如果未给/usr挂载磁盘分区,那往/usr里写数据时,数据保存在哪儿啊?
  • linux下已经从摄像头采集到的数据,如何将这些数据播放成视频呢?????
  • linux下不知有什么小型的数据库?要求速度比较快,开销最小。并且支持单文件数据库及多表的
  • linux上安装oracle 数据库后,是否能写shell程序实现数据库的自动启动。
  • linux下用libpcap库函数抓包,如何判断捕获的数据包是IP数据包还是非IP数据包,顺便说一下、捕获的数据包除了IP数据包之外,还有那些种类,非常感谢!!!
  • linux中的串口通信判断一帧数据是否传输完整时,用定时器检查前后两帧数据的间隔时间,该用什么定时函数,有详细代码最好,谢谢!
  • {高分200分}jsp访问linux上的mysql数据库,取到和插入的数据全是乱码,我是这样设置的???
  • Linux下访问MYSQL数据库中数据时出现乱码问题
  • 【急……】求助linux数据库相关问题
  • linux c/c++ IP字符串转换成可比较大小的数字
  • 在win分区上安装linux和独立分区安装linux有什么区别?可以同时安装吗?(两个linux系统)
  • linux哪个版本好?linux操作系统版本详细介绍及选择方案推荐
  • 在虚拟机上安装的linux上,能像真的linux系统一样开发linux程序么?
  • secureCRT下Linux终端汉字乱码解决方法
  • 我重装window后,把linux的引导区覆盖了,进不了linux怎么办?急啊,望热心的人帮助 (现在有linux的盘)
  • Linux c字符串中不可打印字符转换成16进制
  • 安装vmware软件,不用再安装linux系统,就可以模拟linux系统了,然后可以在其上学习一下LINUX下的基本操作 了?
  • Linux常用命令介绍:更改所属用户群组或档案属性
  • 红旗Linux主机可以通过127.0.0.1访问,但如何是连网的Win2000机器通过Linux的IP去访问Linux


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3