简述ARP交互的过程,并解释为什么路由器返回Echo的rply时,没有再次发起ARP请求

简述ARP交互的过程,并解释为什么路由器返回Echo的rply时,没有再次发起ARP请求,第1张

ARP(Address Resolution Protocol)是一种用于将IP地址映射到MAC地址的协议。在ARP交互的过程中,通常涉及到以下步骤:

1 当主机A需要向主机B发送数据时,首先会检查其ARP缓存中是否已经存在主机B的MAC地址。如果存在,则直接发送数据;如果不存在,则需要进行ARP查询。

2 主机A向本地网络广播ARP请求报文,请求目标主机B的MAC地址。ARP请求报文中包含了目标IP地址和主机A的MAC地址。

3 当主机B收到ARP请求报文时,会检查其中的目标IP地址是否为自己。如果是,则向主机A发送ARP响应报文,其中包含了自己的MAC地址;如果不是,则忽略该请求。

4 主机A收到ARP响应报文后,将目标IP地址和MAC地址添加到自己的ARP缓存中,并将数据发送给主机B。

在路由器返回Echo的reply时,通常情况下是因为路由器已经知道了目标主机的MAC地址,因此不需要再次发起ARP请求。在路由器转发数据包时,会先检查其ARP缓存中是否已经存在目标主机的MAC地址,如果存在,则直接将数据包转发给目标主机;如果不存在,则需要进行ARP查询,获取目标主机的MAC地址。

需要注意的是,ARP缓存中的条目通常有一定的生存时间,超过该时间后就会被删除。因此,在实际应用中,需要定期更新ARP缓存,以确保数据的及时传输。

1、ARP,地址解析协议。

ARP列表,是获取到的最近一段时间内使用过的IP地址与MAC地址的对应关系。

2、通过ARP映射表来观察网络中计算机的MAC地址和IP地址的映射关系,并可选定欲控制的计算机条目进行配置。

3、ARP绑定设置可以防止ARP攻击,因为ARP病毒可以伪IP为代理服务器(但MAC地址还是本机的),如果没有绑定的话,内部局域网的会不停的访问中了ARP病毒的电脑,自然你就上不了网了。

如果绑定了之后,MAC地址和IP地址就一一对应了,防ARP攻击的目的就达到了。

普通文件一样通过cat 和more命令查看其中的内容。

大多数的网络功能在其初始化时都会在/proc中注册一个或多个文件,不是在引导时就是在模块加载时,网络代码注册的文件位于/proc/net目录下

/proc中的目录尅是用proc_mkdir创建,如果在终端下,在proc目录下,使用mkdir命令创建目录,不会成功

root@zfz:/proc/net# mkdir bb

mkdir: cannot create directory `bb': No such file or directory

/proc/net中的文件可以使用定义的include/linux/proc_fsh中的proc_net_fops_create和proc_net_remove进行注册和卸载,在这两个函数里面含有更通用的函数create_proc_entry和remove_proc_entry,注意,proc_net_fops_create负责创建文档,然后,初始化器文件 *** 作函数。下面有一个例子:在Linux *** 作系统下的proc/net目录下有一个arp的文件

通过cat命令可以查看,记录着邻居表项的相关信息,该文件就是通过proc进行注册的。

点击(此处)折叠或打开

cat arp

IP address HW type Flags HW address Mask Device

1121 0x1 0x2 00:01:10:10:10:10 eth0

1123 0x1 0x2 bc:10:10:10:10:10 eth0

下面看一个的ARP协议中是如何在/proc/net中注册arp文件的。

点击(此处)折叠或打开

static struct file_operations arp_seq_fops = {

owner = THIS_MODULE,

open = arp_seq_open,

read = seq_read,

llseek = seq_lseek,

release = seq_release_private,

};

static int __init arp_proc_init(void)

{

if (!proc_net_fops_create("arp", S_IRUGO, &arp_seq_fops))

return -ENOMEM;

return 0;

}

有proc_net_fops_create函数的三个输入参数可以看出,文件名为arp,权限必须指定为只读。

#define S_IRUGO (S_IRUSR|S_IRGRP|S_IROTH)

定义了文件的权限,

文件权限值。定义在 src/include/stath中。

点击(此处)折叠或打开

这里的 S_IRUGO=(S_IRUSR|S_IRGRP|S_IROTH)

S_IRUSR:用户读 00400

S_IRGRP:用户组读 00040

S_IROTH: 其他读 00004

而且该组文件 *** 作处理例程是arp_seq_ops。当一个用户读取该文件时,使用file_operations数据结构,允许procfs返回数据给用户,当数据由一群形同类型的对象组成时会很有用,例如:ARP缓存在返回是一次只返回以项(entry),路由表在返回时一次只返回一条路径。

点击(此处)折叠或打开

#ifndef _LINUX_STAT_H

#define _LINUX_STAT_H

#ifdef __KERNEL__

#include <asm/stath>

#endif

#if defined(__KERNEL__) || !defined(__GLIBC__) || (__GLIBC__ < 2)

#define S_IFMT 00170000

#define S_IFSOCK 0140000

#define S_IFLNK 0120000

#define S_IFREG 0100000

#define S_IFBLK 0060000

#define S_IFDIR 0040000

#define S_IFCHR 0020000

#define S_IFIFO 0010000

#define S_ISUID 0004000

#define S_ISGID 0002000

#define S_ISVTX 0001000

#define S_ISLNK(m) (((m) & S_IFMT) == S_IFLNK)

#define S_ISREG(m) (((m) & S_IFMT) == S_IFREG)

#define S_ISDIR(m) (((m) & S_IFMT) == S_IFDIR)

#define S_ISCHR(m) (((m) & S_IFMT) == S_IFCHR)

#define S_ISBLK(m) (((m) & S_IFMT) == S_IFBLK)

#define S_ISFIFO(m) (((m) & S_IFMT) == S_IFIFO)

#define S_ISSOCK(m) (((m) & S_IFMT) == S_IFSOCK)

#define S_IRWXU 00700

#define S_IRUSR 00400

#define S_IWUSR 00200

#define S_IXUSR 00100

#define S_IRWXG 00070

#define S_IRGRP 00040

#define S_IWGRP 00020

#define S_IXGRP 00010

#define S_IRWXO 00007

#define S_IROTH 00004

#define S_IWOTH 00002

#define S_IXOTH 00001

#endif

#ifdef __KERNEL__

#define S_IRWXUGO (S_IRWXU|S_IRWXG|S_IRWXO)

#define S_IALLUGO (S_ISUID|S_ISGID|S_ISVTX|S_IRWXUGO)

#define S_IRUGO (S_IRUSR|S_IRGRP|S_IROTH)

#define S_IWUGO (S_IWUSR|S_IWGRP|S_IWOTH)

#define S_IXUGO (S_IXUSR|S_IXGRP|S_IXOTH)

#include <linux/typesh>

#include <linux/timeh>

struct kstat {

unsigned long ino;

dev_t dev;

umode_t mode;

unsigned int nlink;

uid_t uid;

gid_t gid;

dev_t rdev;

loff_t size;

struct timespec atime;

struct timespec mtime;

struct timespec ctime;

unsigned long blksize;

unsigned long blocks;

};

在进行open *** 作是,会做另一个重要的初始化,注册一个函数指针数组,包括procfs用于遍历要传回给用户数据的所有例程:一个例程启动卸载,另一个加载,

点击(此处)折叠或打开

static struct seq_operations arp_seq_ops = {

start = arp_seq_start,

next = neigh_seq_next,

stop = neigh_seq_stop,

show = arp_seq_show,

};

static int arp_seq_open(struct inode inode, struct file file)

{

struct seq_file seq;

int rc = -ENOMEM;

struct neigh_seq_state s = kmalloc(sizeof(s), GFP_KERNEL);

if (!s)

goto out;

memset(s, 0, sizeof(s));

rc = seq_open(file, &arp_seq_ops);

if (rc)

goto out_kfree;

seq = file->private_data;

seq->private = s;

out:

return rc;

out_kfree:

kfree(s);

goto out;

}

在ipv6中的邻居发现协议中已经不在采用这种方式,在proc/net目录下没有了类型的ipv6邻居发现的相关文件

以上就是关于简述ARP交互的过程,并解释为什么路由器返回Echo的rply时,没有再次发起ARP请求全部的内容,包括:简述ARP交互的过程,并解释为什么路由器返回Echo的rply时,没有再次发起ARP请求、路由器里的ARP表是什么意思、android 多长时间刷新一次/proc/net/arp等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/9284818.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-26
下一篇 2023-04-26

发表评论

登录后才能评论

评论列表(0条)

保存