首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

详解Linux共享内存管理

在进程通信应用中会用到共享内存,这就涉及到了IPC,与IPC相关命令包括:ipcs、ipcrm(释放IPC)。IPCS命令是Linux下显示进程间通信设施状态工具。...使用IPCS可以查看共享内存、信号量、消息队列状态。...key; 第二列是共享内存编号shmid; 第三列就是创建用户owner; 第四列就是权限perms; 第五列为创建大小bytes; 第六列为连接到共享内存进程数...nattach; 第七列是共享内存状态status。...当用户调用shmctlIPC_RMID时,内存先查看多少个进程与这个内存关联着,如果关联数为0,就会销 毁这段共享内存,否者设置这段内存modmode位为SHM_DEST,如果所有进程都不用则删除这段共享内存

3.7K50

Linux】system V 共享内存

先描述,在组织 并不是在内存中开辟空间即可,系统为了管理共享内存,构建对应描述共享内存结构体对象 共享内存=共享内存内核数据结构(伪代码:struct shm)+真正开辟内存空间 2....,输入 man shmget 查看 申请一个 系统V共享内存块 如果创建成功,则会返回共享内存标识符,失败返回-1 ---- size代表申请内存大小 shmflg代表 选项 有两个最常用选项...通过寻找key值来找到A所创建共享内存 ---- pathname 代表 用户自己设定路径字符串 proj_id 代表 项目id key值意义为 让创建共享内存进程可以给新共享内存设置key值 让获取共享内存进程...将自己和共享内存关联起来 输入 man shmat 指令 at代表 关联 将共享内存和目标值关联起来 返回值为 共享内存虚拟地址起始地址 我们不知道应该把共享内存放在虚拟空间什么地址处...删除共享内存 创建共享内存进程已经早就退出了,但是共享内存还存在 确认共享内存存在: ipcs ipc作为进程间通信简写 ipc表示资源 s表示有多个资源 显出来为ipc通信系统所支持三种

24520
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Linux进程通信——共享内存

    (也就是说如果创建成功,他一定是一个新共享内存——shm) 第二个参数是创建shm大小。 返回值: 如果成功就返回一个共享内存合法标识符,失败就返回-1。...之前C语言,malloc开辟n大小空间时候,释放时并不需要告诉他释放多大,自己就知道释放掉n个大小内存,其实这一块内存中OS也要对这块中间做管理,申请了n个大小,并不代表就是n个,因为里面还有对这块内存属性和数据左储存...//ftok第一个参数,是一个合法路径 #define PROJ_IO 0X666//ftok第二个参数 #define MAX_SIZE 4096//共享内存大小 key_t getkey()...其中key是在第一个数据结构第一个成员数据结构当中,这相当于又做了一层封装。 这里还有一个重点,如果我们将共享内存大小改成4097会怎么样?...那么显示这块内存数据结构是4097大小,但是实际物理内存以你为是按照每次最少开辟4KB大小内存划分内存基本单位),所以一般都是开辟4KB整数倍,这里显示是4097只是因为他是数据结构,实际上多出了

    5.8K30

    Linux进程通信--共享内存

    概述 共享内存区是最快IPC形式。一旦这样内存映射到共享进程地址空间,这些进程间数据传递不再涉及到内核,换句话说是进程不再通过执行进入内核系统调用来传递彼此数据。...首先由操作系统在物理内存中开辟一段内存空间,共享内存虽然是操作系统创建,但是这些进程中某一个需要来创建这个共享内存,这个共享内存属于操作系统。...由此,操作系统就要对共享内存进程管理(先描述,再组织),共享内存不是简单一段内存空间,也要有描述并管理共享内存数据结构和匹配算法。简单来说,对共享内存管理,就变成了对链表增删查改。.../shm.h> int shmget(key_t key, size_t size, int shmflg); 参数: key:这个共享内存段名字,具有唯一性,使用户设置 size:共享内存大小 shmflg...进程如何知道该共享内存存不存在? 共享内存有自己对应属性,这个属性有一个标识共享内存唯一性字段,因此对应共享内存存不存在,可以看对应唯一性标识符。

    10410

    nginx共享内存共享内存实现

    而ngx_shared_memory_add不会马上创建一个共享内存,它是先登记一下共享内存使用信息,比如名称、大小等,然后在进程初始化时候再进行共享内存创建与初始化。...两个相同名字共享内存大小要一样。 2. 两个相同名字共享内存tag要一样。 3. 如果当前共享内存已经存在,则不需要再次添加。会返回同一个共享内存 4....= 0) { continue; } // 如果新共享内存大小与原有的共享内存大小相同,就不需要重新添加了...// 注意,如果新配置共享内存大小与老共享内存大小不一样,那老共享内存大小就被释放掉了,所以这点我们要特别注意 ngx_shm_free(&oshm_zone...另外,共享内存实际创建是通过ngx_shm_alloc来实现,nginx里面包含了共享内存实现多种方式,linux中默认使用mmap来实现,实现代码比较简单,看看: ngx_int_t ngx_shm_alloc

    4.6K30

    Linux内核编程--内存映射和共享内存

    offset); start:用户进程中要映射某段内存区域起始地址,通常为NULL(由内核来指定) length:要映射内存区域大小 prot:期望内存保护标志 flags:指定映射对象类型...若失败,返回-1 2.销毁共享内存 int shm_unlink(const char *name); 3.修改共享内存大小(还可以修改文件大小) int ftruncate(int fd, off_t...length) 处理mmap时候,普通文件或共享内存区对象大小都可以通过调用ftruncate修改。...--key:进程间事先约定key,或者调用key_t ftok( char * fname, int id )获取 --size:共享内存大小,当创建一个新共享内存区时,size必须大于0,如果是访问一个已经存在内存共享区...若失败,返回-1 两个版本微小差异:Posix共享内存区对象大小可在任意时刻由ftruncate函数修改,System V共享内存区对象大小是在调用shmget创建时固定下来

    6.1K10

    Linux进程通信之共享内存

    Linux进程通信之共享存储 概念: 共享内存指 (shared memory)在多处理器计算机系统中,可以被不同中央处理器(CPU)访问大容量内存。...任何一个缓存数据被更新后,由于其他处理器也可能要存取,共享内存就需要立即更新,否则不同处理器可能用到不同数据。...共享内存是 Unix下多进程之间通信方法 ,这种方法通常用于一个程序多进程间通信,实际上多个程序间也可以通过共享内存来传递信息。...PHP中封装: php中封装了shm开头函数和shmop开头函数,实际效果是一样,具体使用方式请查看官方手册 ,下面我们以shm开头为例演示 特点: 共享内存是将内存映射到其他进程地址空间中...,所以说共享内存也是最快IPC进程通信方式 前提: 在使用IPC进程通信时,也就是信号量、消息队列、共享存储时,首先要先确定自己PHP扩展是否已经开启,使用php -m 查看 编写代码 父子进程

    4.8K31

    Linux 进程间如何共享内存

    导读 共享内存是在内存中单独开辟一段内存空间,这段内存空间有自己特有的数据结构,包括访问权限、大小和最近访问时间等。...共享内存 IPC 原理 共享内存进程间通信机制主要用于实现进程间大量数据传输,下图所示为进程间使用共享内存实现大量数据传输示意图: ?...共享内存是在内存中单独开辟一段内存空间,这段内存空间有自己特有的数据结构,包括访问权限、大小和最近访问时间等。...共享内存管理 1.创建共享内存 #include #include /* * 第一个参数为 key 值,一般由 ftok() 函数产生 * 第二个参数为欲创建共享内存大小...); 共享内存在父子进程间遵循约定 1.使用 fork() 函数创建一个子进程后,该进程继承父亲进程挂载共享内存

    8.4K21

    速通 Linux 共享内存原理

    共享内存是一个非常有意思的话题,一方面共享内存避免了通讯过程中内存复制问题,是 Linux IPC 通讯中效率最高一种。...从使用方式上讲,Linux 提供了三种共享内存方式,包括 Unix 味 POSIX 和 SysV 接口,还提供了直接文件映射内存 mmap。...本文尝试分别介绍 Linux 共享内存基本原理,并做一个 “违背祖宗决定”,如何在 Golang 中使用共享内存。...Golang 是通过通讯代替共享内存优雅代表,下文仅做试验,不建议日常使用 mmap mmap 是 POSIX 规范中文件映射内存方法,Linux 并提供了同名系统调用。...总结 从原理上讲 Linux 共享内存主要方式只有两种,一是基于文件 mmap,另一种就是 tmpfs,用一张图描述 Linux 几种实现共享内存方式:

    4.1K20

    Linux进程间通信【共享内存

    shmid,失败返回 -1 参数1 key_t key 创建共享内存唯一 key 值,通过函数计算获取 参数2 size_t size 创建共享内存大小,一般为 4096 参数3 int shmflg...位图,可以设置共享内存创建方式及创建权限 因为共享内存拥有自己数据结构,所以 返回值 int 实际就是 shmid,类似于文件系统中 fd,用来对不同共享内存块进行操作 参数2为创建共享内存大小...关于共享内存,还需要知道以下几个特点 4.1、共享内存大小 在上面的代码中,我们将共享内存大小设为 4096 字节,即一个 PAGE 页大小(4kb);如果申请 4097 字节大小共享内存,操作系统实际上会分配...因为操作系统为了避免因非法操作导致出现越界访问问题,所以会开辟 PAGE 页整数倍大小空间,多开辟空间不会给共享内存时,主要是用来检测是否出现了越界访问 4.2、共享内存 “快” 原因 共享内存...:《共享内存博客仓库》 ---- 总结 以上就是本次关于 Linux 进程间通信之 共享内存 全部内容了,共享内存 是所有 IPC 中最快一种,因为它省去了很多不必要 IO 操作,进程直接对话进程

    34900

    Linux内存共享映射(mmap和munmap)

    Linux进程间通信也可以使用mmap内存共享映射来实现,mmap作用就是把磁盘文件一部分直接映射到进程内存中,那么进程就可以直接对该内存文件进行操作,mmap也设置了两种机制...:共享和私有,如果是共享映射,那么在内存中对文件进行修改,磁盘中对应文件也会被修改,相反,磁盘中文件有了修改,内存文件也被修改。...如果是私有映射,那么内存文件是独立,二者进行修改都不会对对方造成影响。...通过这样内存共享映射就相当于是进程直接对磁盘中文件进行读写操作一样,那么如果有两个进程来mmap同一个文件,就实现了进程间通信。...int cnt = 1; if(fd == -1) sys_err("open"); if(lseek(fd, 0x1000 - 1, SEEK_SET) == -1) // 将文件大小变为

    8.2K30

    php共享内存,php共享内存使用

    (1).基本写入(a.php)//(1.1).创建一个IPC通信专用KEY$shm_key = ftok(__FILE__, 't');//(1.2).创建或者打开共享内存块,创建1KB$shmop...$shmop) {    throw new Exception('创建共享内存失败');}//(1.3).向内存写入数据$text = 'A:大家好,我是A进程,我创建内存空间啊,欢迎大家一起来耍啊...)shmop_close($shmop);//(1.5).输出共享内存系统ID,我是1948581891,php打印是int值,底层用16进制echo dechex($shm_key) . ...PHP_EOL;//(2.3).删除共享内存.不需要close.直接删除shmop_delete($shmop);(3).注意事项通过ipcs -m 命令可以查看已经创建共享内存通过ipcrm -M...key 命令可以删除通过shm_key创建共享内存共享内存不会因为进程退出而丢失,会一直存在系统中,除非删除它

    95130

    Linux 进程间通信 : 共享内存(上)

    前言 本文主要说明在Linux环境上如何使用共享内存。阅读本文可以帮你解决以下问题: 什么是共享内存和为什么要有共享内存? 如何使用mmap进行共享内存? 如何使用XSI共享内存?...Linux系统在编程上为我们准备了多种手段共享内存方案。包括: mmap内存共享映射。 XSI共享内存。 POSIX共享内存。 下面我们就来分别介绍一下这三种内存共享方式。...XSI共享内存 为了满足多个无关进程共享内存需求,Linux提供了更具通用性共享内存手段,XSI共享内存就是这样一种实现。...,这主要是因为在相同内存大小情况下,使用大页内存(2M一页)将比使用一般内存页(4k一页)内存页管理数量大大减少,从而减少了内存页表项缓存压力和CPU cache缓存内存地质映射压力,提高了寻址能力和内存管理效率...于是,遵循一切皆文件理念POSIX标准进程间通信机制应运而生。 接Linux进程间通信:共享内存 (下)

    11.2K33

    Linux进程间通信:共享内存 (下)

    Linux进程间通信:共享内存 (上) POSIX共享内存 POSIX共享内存实际上毫无新意,它本质上就是mmap对文件共享方式映射,只不过映射是tmpfs文件系统上文件。 什么是tmpfs?...现在绝大多数Linux系统都有一个叫做/dev/shmtmpfs目录,就是这样一种存在。具体使用方法,大家可以参考我另一篇文章《Linux内存Cache真的能被回收么?》。...Linux提供POSIX共享内存,实际上就是在/dev/shm下创建一个文件,并将其mmap之后映射其内存地址即可。...使用ftruncate方法来设置“共享内存大小。其实就是更改文件长度。 要以共享方式做mmap映射,并且指定文件描述符为shmfd。 shm_unlink实际上就是unlink系统调用封装。...使用ftruncate设置共享内存大小,实际上就是对tmpfs文件进行指定长度截断。使用fchmod、fchown、fstat等系统调用修改和查看相关共享内存属性。

    8.2K12

    宋宝华:世上最好共享内存(Linux共享内存最透彻一篇)

    只要内存拷贝(memcpy)仍然是一个占据内存带宽、CPU利用率消耗大户存在,共享内存作为Linux进程间通信、计算机系统里各个不同硬件组件通信最高效方法,都将持续繁荣。...我早就想系统地写一篇综述Linux里面各种共享内存方式文章了,但是一直被带娃这个事业牵绊,今日我决定顶着娃娃们山呼海啸,也要写一篇文章不吐不快。...SYS V共享内存 历史悠久、年代久远、API怪异,对应内核代码linux/ipc/shm.c,当你编译内核时候不选择CONFIG_SYSVIPC,则不再具备此能力。...你在Linux敲ipcs命令看到share memory就是这种共享内存: ? 下面写一个最简单程序来看共享内存写端sw.c: ? 以及共享内存读端sr.c: ? 编译和准备运行: ?...我们都知道cached这一列统计是file-backed文件page cache大小

    45.7K1313

    Linux进程间通信(四) - 共享内存

    共享内存优势 采用共享内存通信一个显而易见好处是效率高,因为进程可以直接读写内存,而不需要任何数据拷贝。...Linux2.6.x内核支持多种共享内存方式,如mmap()系统调用,Posix共享内存,以及System V共享内存。本文对3种共享内存形式都将进行介绍。...linux采用是页式管理机制。...进程能够访问有效地址大小取决于文件被映射部分大小。简单说,能够容纳文件被映射部分大小最少页面个数决定了进程从mmap()返回地址开始,能够有效访问地址空间大小。...在Linux 2.6.x中,对于POSIX信号量和共享内存名字会在/dev/shm下建立对应路径名 [root@rocket shm]# ll /dev/shm/|grep mem -rwxr-xr-x

    7.2K61
    领券