【Linux】system V 共享内存(上)

简介: 【Linux】system V 共享内存

system V

system V 是一套标准,独立于文件系统之外的,专门为了通信设计出来的模块

让两个毫不相关的进程看到同一份资源

1. 共享内存原理

第一阶段原理

b71b0658f8c64047999c4faf628da2d2.png

进程A和进程B都通过自己的页表映射到物理内存中的特定区域,进而找到该进程匹配的代码和数据

为了让进程A和进程B通信,前提是两者要看到同一份资源

假设在物理内存上开辟一块空间

进程A和进程B在自己的地址空间中都有自己的共享区

想办法把物理内存中新开辟空间 通过页表 映射到 进程A和进程B的共享区中

把地址空间的起始地址返回给用户

进程A和进程B就可以通过起始的虚拟地址,对应页表访问到内存

就完成了让进程A和进程B看到同一份资源,这份资源就被称为共享内存


第二阶段原理


5502b17ebf7f465882ed4f7bbb1c0c5d.png

系统中可以用ssh进行通信 ,是不是只能有一对进程使用共享内存呢?

可以,其他进程也可以通信

所以在任何时刻,可能有多个共享内存在被使用

系统中一定会存在很多共享内存同时存在

操作系统要不要整体管理所有的共享内存呢?要

操作性系统如何管理多个共享内存呢?

先描述,在组织

并不是在内存中开辟空间即可,系统为了管理共享内存,构建对应的描述共享内存的结构体对象

共享内存=共享内存的内核数据结构(伪代码:struct shm)+真正开辟的内存空间


2. 直接写代码–编写代码进行原理介绍


打开vscode,创建文件client.cc和server.cc(后缀为cc说明是c++)的文件

创建公共路径 comm.hpp

shmget函数

创建共享路径接口 ,输入 man shmget 查看


d22bc459d6d744fa8bf95e5a8ff4fead.png

申请一个 系统V的共享内存块

如果创建成功,则会返回共享内存标识符,失败返回-1

size代表申请内存块的大小

shmflg代表 选项

有两个最常用的选项,IPC_CREAT IPC_EXCL

转到定义就可以发现其实这两个都是宏

158e33b4777a48c8a9f3d512ab338b8e.png

若单独使用 IPC_CREAT :创建一个共享内存,如果共享内存不存在,就创建之,如果已经存在,就获取已经存在的共享内存并返回

IPC_EXCL不能单独使用 ,一般都要配合 IPC_CREAT

若要将两个选项同时传进去 IPC_CREAT | IPC_EXCL

两个选项同时用: 创建一个共享内存,如果共享内存不存在,就创建之,如果已经存在,则立马出错返回

如果创建成功,对应的共享内存一定是最新的


获取共享内存时,需要有一个key值


ftok函数

输入 man ftok

0d325f7de31443818c9699252ce210d8.png

根据路径和项目id进行算法结合,形成一个冲突概率低的key值

失败就返回-1,成功返回key值

key值用法

假设进程A创建了一个共享内存,但是进程B怎么知道那个共享内存是创建的吗?

就需要借助上述提到的 ftok 函数

49abb96e28f24d0e9b95ed095c5f4f87.png


c3a1ccf6913149fcac0bbad49fd67325.png

刚开始约定好 A和B用同样的路径字符串和项目id

借助A形成一个key值,将key值放入A创建的共享内存描述结构体中

此时B也形成一个相同的key值,通过寻找key值来找到A所创建的共享内存


pathname 代表 用户自己设定的路径字符串

proj_id 代表 项目id

key值意义为

让创建共享内存的进程可以给新共享内存设置key值

让获取共享内存的进程 通过key值 去找特定匹配的共享内存


相关文章
|
4天前
|
缓存 Linux
linux 手动释放内存
在 Linux 系统中,内存管理通常自动处理,但业务繁忙时缓存占用过多可能导致内存不足,影响性能。此时可在业务闲时手动释放内存。
45 17
|
2月前
|
监控 Linux
如何检查 Linux 内存使用量是否耗尽?这 5 个命令堪称绝了!
本文介绍了在Linux系统中检查内存使用情况的5个常用命令:`free`、`top`、`vmstat`、`pidstat` 和 `/proc/meminfo` 文件,帮助用户准确监控内存状态,确保系统稳定运行。
739 6
|
7天前
|
消息中间件 Linux
Linux:进程间通信(共享内存详细讲解以及小项目使用和相关指令、消息队列、信号量)
通过上述讲解和代码示例,您可以理解和实现Linux系统中的进程间通信机制,包括共享内存、消息队列和信号量。这些机制在实际开发中非常重要,能够提高系统的并发处理能力和数据通信效率。希望本文能为您的学习和开发提供实用的指导和帮助。
55 20
|
17天前
|
Linux
【Linux】System V信号量详解以及semget()、semctl()和semop()函数讲解
System V信号量的概念及其在Linux中的使用,包括 `semget()`、`semctl()`和 `semop()`函数的具体使用方法。通过实际代码示例,演示了如何创建、初始化和使用信号量进行进程间同步。掌握这些知识,可以有效解决多进程编程中的同步问题,提高程序的可靠性和稳定性。
65 19
|
2月前
|
缓存 Java Linux
如何解决 Linux 系统中内存使用量耗尽的问题?
如何解决 Linux 系统中内存使用量耗尽的问题?
200 48
|
1月前
|
算法 Linux
深入探索Linux内核的内存管理机制
本文旨在为读者提供对Linux操作系统内核中内存管理机制的深入理解。通过探讨Linux内核如何高效地分配、回收和优化内存资源,我们揭示了这一复杂系统背后的原理及其对系统性能的影响。不同于常规的摘要,本文将直接进入主题,不包含背景信息或研究目的等标准部分,而是专注于技术细节和实际操作。
|
2月前
|
缓存 Ubuntu Linux
Linux环境下测试服务器的DDR5内存性能
通过使用 `memtester`和 `sysbench`等工具,可以有效地测试Linux环境下服务器的DDR5内存性能。这些工具不仅可以评估内存的读写速度,还可以检测内存中的潜在问题,帮助确保系统的稳定性和性能。通过合理配置和使用这些工具,系统管理员可以深入了解服务器内存的性能状况,为系统优化提供数据支持。
60 4
|
2月前
|
Linux
如何在 Linux 系统中查看进程占用的内存?
如何在 Linux 系统中查看进程占用的内存?
|
2月前
|
缓存 Linux
如何检查 Linux 内存使用量是否耗尽?
何检查 Linux 内存使用量是否耗尽?
|
2月前
|
存储 算法 安全
深入理解Linux内核的内存管理机制
本文旨在深入探讨Linux操作系统内核的内存管理机制,包括其设计理念、实现方式以及优化策略。通过详细分析Linux内核如何处理物理内存和虚拟内存,揭示了其在高效利用系统资源方面的卓越性能。文章还讨论了内存管理中的关键概念如分页、交换空间和内存映射等,并解释了这些机制如何协同工作以提供稳定可靠的内存服务。此外,本文也探讨了最新的Linux版本中引入的一些内存管理改进,以及它们对系统性能的影响。