timer。

这是邻居的定时器,用于解析ARP,其超时函数是neigh_timer_handler。

arp_queue

这是一个struct sk_buff的队列,协议栈在发送一个IP数据包时,如果还未进行arp解析,则先把该IP数据包放入arp_queue,然后进行ARP解析。

下面重点看一下struct neighbour的成员nud_state,它是邻居的当前状态,邻居在创建,解析的过程中,其状态经历了一系例的变迁过程。

当一个邻居刚刚被创建,其状态是NUD_NONE,此时,邻居被创建出来,并根据其IP地址被加入到arp_tbl的哈希表hash_buckets中,但它还没有被解析,其成员ha(邻居的硬件地址)为空。直到向这个邻居发送IP数据报,并且发送流程到达网络层的最后一个发送函数ip_finish_output2时,调用邻居的output成员函数,一般这个函数是neigh_resolve_output(根据type的不同会略有不同)。它会先进行ARP解析,然后把IP数据报发往正确的邻居。

因为当前状态是NUD_NONE,neigh_resolve_output首先判断parms的成员mcast_probes加上app_probes的值,这两个参数表示ARP解析时尝试的次数,mcast_probes缺省值置为3,app_probes是0,如果它们的和为零,则不作ARP解析尝试,直接将状态置为NUD_FAILED。当前不为零,所以进行解析,首先置邻居的成员probes为parms的ucast_probes,缺省为3,这样,该邻居等于是已经尝试了3次了,另外还只能多3次(mcast_probes),即该邻居的解析最多尝试3次,如果3次不成功,则失败,结束。然后将状态置为NUD_INCOMPLETE,表示正在解析中,并把待解析的socket缓冲skb放入arp_queue队列中,然后启动邻居的定时器开始ARP解析。

定时器处理函数neigh_timer_handler首先确定下次的超时时间(如果这次解析没有成功)为当前时间加上parms的成员retrans_time的值(缺省设置为1秒)。所以,ARP解析的发包超时时间是1秒,连续尝试3次。ARP解析是通过ops的成员函数solicit去做的,该成员函数指针指向的arp_solicit函数,arp_solicit会实际发送ARP请求包。

如果arp_solicit发送ARP请求包,连续三次没有得到正确的回应,则把nud_state置为NUD_FAILED,调用ops的成员函数error_report报告错误。并把skb从arp_queue队列中取出。error_report错误报告置dst的超时时间为当前时间,并删除skb,关于dst,跟FIB相关,涉及到FIB时再详细分析。

置为NUD_FAILED的邻居在下次进行常规垃圾回收时,被删除回收掉。

协议栈在发送一个IP数据报之前,需要发送ARP请求是为了解析IP数据报的目的IP地址对应的硬件地址。ARP协议可以承载多种硬件类型和多种协议,这里我们只关注以太网上的IP协议,那ARP请求的目的就是为了解析邻居的以太网MAC地址。

ARP请求/应答数据报总共有28字节,其具体格式如下所示(在以太网,IP协议的情况下):

字段含义:硬件类型 协议类型 硬件地址长度 协议地址长度 op

字段长度:2              2             1                    1                    2

字段含义:发送端以太网地址 发送端IP地址 目的以太网地址 目的IP地址

字段长度:6                           4                      6                      4

硬件类型,对于10Mbps以太网,其取值是ARPHRD_ETHER(值为1),协议类型,对于IP协议来说,就是ETH_P_IP(0x0800),在上述条件限定下,硬件地址长度为6,协议地址长度为4,op的值为ARPOP_REQUEST(值为1,表示是ARP请求,或者ARPOP_REPLY(值为2,表示是ARP应答)。

发送端以太网地址填发送接口的MAC地址,发送端IP地址填源IP地址(关于源IP地址的选取下文会有详细分析),目的以太网地址,因为当前是ARP请求,所以填入以太网广播地址0xFF:0xFF:0xFF:0xFF:0xFF:0xFF,目的IP地址填入IP数据报的目的地址。

这里,发送端IP地址的选取是一个可配置的选项,文件/proc/sys/net/ipv4/conf/设备名/arp_announce记录的是它的配置值,这是一个整型数值,取值范围为0-2,0表示只要待发送IP数据报的源地址为本地地址,就取该地址为发送端IP地址,这也是缺省配置;1表示若待发送IP数据报的源地址为本地地址,并且该IP地址与目的IP地址在同一子网内,则取该地址为发送端IP地址,否则从所有的本地地址中取一个与目的IP地址在同一子网内的地址;2表示完全忽略IP数据报中的地址,直接从所有本地输出网络接口中选取一个最为合适的发送端IP地址。配置级别越高,我们能够获得ARP回应的机率也就越大。

构建好的ARP请求数据报通过函数dev_queue_xmit发送出去。

在分析接收和处理ARP的回应数据之前,先复习一下协议栈接收网络数据的一个基本流程,网卡驱动程序会创建一个skb,并填入接收到的数据,并把这个skb传给协议栈的第一个接收函数netif_rx。softnet_data是一组全局变量,每个CPU拥有一个,它是一个结构体struct softnet_data,其定义如下:

struct softnet_data

{

struct net_device   *output_queue;

struct sk_buff_head input_pkt_queue;

struct list_head    poll_list;

struct sk_buff      *completion_queue;

struct net_device   backlog_dev;

};

input_pkt_queue是一个接收队列,从网卡接收上来的skb一般会放在这里队列中待处理,这个队列的长度是有限制的,netdev_max_backlog就是该队列长度的上限,值为1000,如果队列中的skb数量已经达到1000,对于新收到的skb会直接丢弃。当新接收到一个skb,首先检查input_pkt_queue队列,如果队列长度未太到上限,且队列中已经存在skb,则直接把新收到的skb放在队列尾,返回成功。如果队列为空,则先调用函数netif_rx_schedule把接收工作启动起来,再把skb放入队列。

netif_rx_schedule把softnet_data的成员backlog_dev连入poll_list,产生一个软中断NET_RX_SOFTIRQ。随后该中断处理函数net_rx_action被执行,net_rx_action检查softnet_data的poll_list队列,如果不空,则开始进行处理接收数据。

获取linux内核arp表,Linux内核ARP缓存表格式相关推荐

  1. 1、交换机ARP缓存表分析

    1.交换机ARP缓存表分析 一.用模拟器不是一个简单的拓扑:   拓扑简单描述:交换机不做任何配置,两台电脑使用arp -a命令查看混存表,均为空. 操作1:PC A 去ping  PC B: 10. ...

  2. ARP帧、ARP过程、免费ARP、ACD的原理

    ARP协议(地址解析协议)用于局域网中网络设备按IP地址查询对方的MAC地址,提供一种从网络地址(仅ipv4,ipv6用ND协议替代)到硬件地址(各种链路层协议使用的地址)的映射. 1.ARP过程 简 ...

  3. linux内核协议栈 邻居协议之 arp 数据包收发处理流程

    目录 前言 1 arp数据包文接收 arp_rcv() 1.1 处理arp请求 arp_process()[核心] 2 arp数据包发送 arp_send() 2.1 arp 数据包构造 arp_cr ...

  4. Linux内核分析 - 网络[十]:ARP杂谈

    内核版本:2.6.34 杂谈一:重复地址检测 Linux协议栈中处理重复地址检测报文的是arp_process()中的一段代码,RFC2131是DHCP的草案,相应的sip==0是DHCP服务器用来检 ...

  5. linux内核网络协议栈--linux bridge(十九)

    1 . 前言 本文是参考附录上的资料整理而成,以帮助读者更好的理解kernel中brdige 模块代码. 2. 网桥的原理 2.1 桥接的概念 简单来说,桥接就是把一台机器上的若干个网络接口" ...

  6. linux内核网络协议栈--linux网络设备理解(十三)

    网络层次 linux网络设备驱动与字符设备和块设备有很大的不同. 字符设备和块设备对应/dev下的一个设备文件.而网络设备不存在这样的设备文件.网络设备使用套接字socket访问,虽然也使用read, ...

  7. ARP***绑定 linux/windows 下解决方案

    请教: 使用IPTABLES作为网关,实现客户端的IP地址跟MAC地址绑定? 这个你在iptables里的nat里对每个地址作SNAT时指上就OK了, 也可在你的机子上arp -s 网关IP 正确的网 ...

  8. linux arp 老化时间,Linux实现的ARP缓存老化时间原理解析

    一.问题众所周知,ARP是一个链路层的地址解析协议,它以IP地址为键值,查询保有该IP地址主机的MAC地址.协议的详情就不详述了,你可以看RFC,也可以看教科书.这里写这么一篇文章,主要是为了做一点记 ...

  9. [转]Linux 2.6.19.x 内核编译配置选项简介

    Linux 2.6.19.x 内核编译配置选项简介 作者:金步国,转载地址:http://lamp.linux.gov.cn/Linux/kernel_options.html 版权声明 本文作者是一 ...

  10. Linux 2.6.19.x 内核编译配置选项简介(内核裁剪)

    Linux 2.6.19.x 内核编译配置选项简介 Code maturity level options 代码成熟度选项 Prompt for development and/or incomple ...

最新文章

  1. ATS cache中的几个数据结构图收集
  2. java.sql在哪_我的Java访问MS SQL的程序错在哪了?谢谢!
  3. 为机柜鸣冤:数据中心被忽视的重要设备
  4. C#中的==、Equal、ReferenceEqual(转载)
  5. python方差特征选择_使用scikitlearn进行方差分析的特征选择和交叉验证
  6. 用GDI+转BMP为WMF、EXIF、EMF格式
  7. c语言里字符串和字符串字面量,string literals(字符串字面量)
  8. Angular开发准备
  9. 【Java】编写Java应用程序,完成从键盘输入圆的半径,求圆的周长和面积并输出结果的功能...
  10. spring_restful_json_jdbc
  11. mysql数据库任务驱动式教程课后答案_MySQL数据库任务驱动式教程
  12. php try 错误_PHP异常和错误(2)异常的基本处理:try
  13. 问题:子进程父进程哪个先执行:【转】关于 fork 和父子进程的理解
  14. Python成员运算符
  15. 5.7.2.4 random() 方法
  16. 【渝粤题库】陕西师范大学800006 世界地理
  17. 浅谈javascript和java中的字符串
  18. CURL+preg_match()
  19. 中兴新支点服务器安装,U盘安装中兴新支点操作系统(NewStart)的方法
  20. 报错undefined symbol: _ZN3c104impl23ExcludeDispatchKeyGuardC1ENS_11DispatchKeyE

热门文章

  1. PLC笔记(一)PLC入门姿势
  2. Mongodb工具Studio 3T 破解教程
  3. C/C++通过WMI和系统API函数获取获取系统硬件(cpu,内存,显卡,网卡)配置信息
  4. matlab实现差分进化算法DE
  5. JDBC---jar包下载与导入
  6. PhotonServer介绍
  7. 数据结构——链表面试题
  8. matlab GS算法
  9. Win10 /Win8系统遇到驱动需要数字签名无法安装问题怎么办
  10. idea导入gradle项目时遇到的坑