共享内存是Linux下最快速、最有效的进程间通信方式。是多个进程可以把同一段内存映射到自己的进程空间,以此实现数据的共享与传输。即:对于不同的进程A、B,将同一块物理内存映射到进程A、B各自进程的地址空间,进程A能够及时地看到进程B对共享内存中数据的更新,反之B进程同样能够及时地看到进程A对共享内存中数据的更新。
共享内存存在于内核级别的一种资源,因此是所有进程间通信(IPC)方式中最快的一种。在shell中通过命令ipcs可以查看当前系统IPC中的状态:
<span style="font-size:14px;">[xcbeyond@bogon /]$ ipcs
------ Shared Memory Segments --------
key shmid owner perms bytes nattch status
0x000000001 32768 xcbeyond 600 655360 2
0xfffffffff 589825 xcbeyond 0 4096 0
------ Semaphore Arrays --------
key semid owner perms nsems
------ Message Queues --------
key msqid owner perms used-bytes messages </span>
在系统内核为一个进程分配内存地址时,通过分页机制可以让一个进程的物理地址不连续,同时也可以让同一段内存分配给不同的进程。共享内存机制就是通过该原理来实现的,共享内存只是提供数据的传送,而如何确保进行服务器端和客户端读写操作的互斥性,就需要一些其他的方式来控制了,例如信号量。
Linux共享内存
最新推荐文章于 2023-07-20 13:36:48 发布