Linux网桥知识总结.doc

  1. 1、本文档共71页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
Linux网桥知识总结(beta 1) ——by moonflow qq:171932120 (总结自互联网) 目录 TOC \o 1-4 \h \z \u Figure (b) shows what is called a store-and-forward bridge , which is the scheme used by Linux: Ethernet frames are copied out of the right ports only after they have been received in their entirety.(转自ULNI) 网桥的工作原理其实很简单,就是:某个主机的消息从哪个端口进来,那么这个主机必定位与这个端口这一侧,从这个端口一定能找到这个主机,给这个主机的消息也就应该从这个端口转发。 比如,一个网桥连接主机A和主机B。当主机A连接到网桥时,会告诉网桥,它在端口A。网桥会维持一个映射表,让端口A与主机A的mac地址对应。当有其他主机试图通过网桥转发目的mac地址为主机A的mac地址的消息时,网桥会通过查表来指导应该由端口A转发。 同理,当网桥连接两个或两个以上主机或主机构成的网络时,也按照这个原则,维持一个记录端口和mac地址的映射表,需要转发消息的时候通过查找这个表来找到应该去的地址。当然,如果收到的消息是发给网桥本身的,就要交给上层协议来处理。这就是网桥的工作原理。 重要数据结构 2.1 net_bridge 在/net/bridge/br_private.h ,这个结构体描述一个网桥。dev是这个桥对应的设备。port_list是net_bridge_port的链表头。hash[BR_HASH_SIZE]是net_bridge_fdb_entry的散列表,也是网桥MAC地址和端口的映射表CAM。 struct net_bridge { //自旋锁 spinlock_t lock; //桥组中的端口列表 struct list_head port_list; //网桥会建立一个虚拟设备来进行管理,这个设备的MAC地址是动态指定的,通常就是桥组中一个物理端口的MAC地址 struct net_device *dev; //网桥中虚拟网卡的统计数据 struct net_device_stats statistics; //hash列表自旋锁 spinlock_t hash_lock; //存放的是net_bridge_fdb_entry的哈希表,实际上就是mac和port的对应表 struct hlist_head hash[BR_HASH_SIZE]; struct list_head age_list; unsigned long feature_mask; //以下定义了STP协议所使用的信息 bridge_id designated_root; //DR bridge_id bridge_id; //这个成员一下是stp相关的信息 u32 root_path_cost; unsigned long max_age; unsigned long hello_time; unsigned long forward_delay; unsigned long bridge_max_age; unsigned long ageing_time; unsigned long bridge_hello_time; unsigned long bridge_forward_delay; u8 group_addr[ETH_ALEN]; u16 root_port; enum { BR_NO_STP,

文档评论(0)

yurixiang1314 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档