面试知识点整理

计算机的物理内存是有限的,所以操作系统在遇到内存不足时,会通过换页机制暂时把

某个进程未使用的内存中的数据搬移到硬盘上(比如 Linux 的 swap 分区 ),并在系统页表中

删除相应的表项。当该进程访问数据已经被搬移到硬盘中的内存时,会触发缺页中断,随后

操作系统会把硬盘中的数据重新移回内存中新分配的内存页,并在页表中添加表项,以保证

内存页的虚拟地址不变。对于进程而言,此时数据所在的内存的虚拟地址没有变化,但物理

地址很可能已经和原来不一样了。所以,这一过程很可能导致虚拟地址和物理地址的映射关
系发生改变

由于 RDMA 网卡经常会绕过 CPU 对用户提供的虚拟地址所指向的内存区域进行访问,

如果虚拟地址和物理地址的映射关系发生改变,因此前文提到的 MR 地址转换表的原有内容

会失去意义,RDMA 网卡将无法找到正确的物理地址。

为了防止换页所导致的地址映射关系发生改变,在应用程序为缓存注册 MR 的过程中,

运行在内核态的 RDMA 网卡驱动程序会调用 Linux 内核提供的 pin_user_pages_fast 函数, Pin

这块缓存(亦称锁页),即锁定缓存的虚拟地址和物理地址的映射关系。也就是说,MR 这

块内存区域会长期存在于物理内存中,其数据不会被 swap 到硬盘,直到完成 RDMA 通信之

后,应用程序主动调用 Verbs API ibv_dereg_mr 注销此 MR。

要实现可靠服务,必须有以下几个关键机制。

• 能够检测到受损数据的保护机制,比如循环冗余校验(CRC)。

• 使发送者能够确定消息已成功传递的确认机制(ACK)。

用于检测丢失的数据包并允许发送者将对端响应与发送请求关联的数据包序列号

(packet sequence number,PSN)机制。

• 计时器,用于检测被丢弃(dropped)或丢失(missed)的确认消息

相关推荐
网硕互联的小客服8 小时前
服务器防火墙是如何区分正常流量和攻击流量?
运维·服务器·网络
勇敢牛牛_10 小时前
【conreg-client】在Rust中使用向Feign一样的远程调用
网络·rust·feign
double2li10 小时前
linux/unix 段错误捕获【续】
linux·运维·服务器·网络·unix
qq_2602412310 小时前
将盾 CDN:网络网站安全防护体系与实践
网络·安全
dashizhi201510 小时前
禁止复制电脑文件、电脑机密数据禁止拷贝、禁止电脑文件复制到U盘和移动硬盘的方法
运维·网络·stm32·安全·电脑
Ralph_Y10 小时前
C++网络:一
开发语言·网络·c++
猪猪侠|ZZXia10 小时前
# Openssl关键知识
linux·网络
程序猿编码11 小时前
探秘 SSL/TLS 服务密码套件检测:原理、实现与核心设计(C/C++代码实现)
c语言·网络·c++·ssl·密码套件
江南西肥肥11 小时前
养虾日记[特殊字符]:多Agent在飞书群辩论--踩坑篇
网络·飞书·openclaw
网云工程师手记11 小时前
企业多出口负载与故障切换实战:4 种调度模式 + 主备线路高可用
运维·服务器·网络·安全·网络安全