技术积累--共享内存使用常见陷阱和分析.docVIP

  • 5
  • 0
  • 约7.49千字
  • 约 8页
  • 2018-08-23 发布于江苏
  • 举报

技术积累--共享内存使用常见陷阱和分析.doc

技术积累--共享内存使用常见陷阱和分析

LINUX共享内存使用常见陷阱与分析 所谓共享内存就是使得多个进程可以访问同一块内存空间,是最快的可用IPC形式。是针对其他通信机制运行效率较低而设计的。往往与其它通信机制,如信号量结合使用,来达到进程间的同步及互斥。其他进程能把同一段共享内存段“连接到”他们自己的地址空间里去。所有进程都能访问共享内存中的地址。如果一个进程向这段共享内存写了数据,所做的改动会即时被有访问同一段共享内存的其他进程看到。共享内存的使用大大降低了在大规模数据处理过程中内存的消耗,但是共享内存的使用中有很多的陷阱,一不注意就很容易导致程序崩溃。 超过共享内存的大小限制? 在一个linux服务器上,共享内存的总体大小是有限制的,这个大小通过SHMMAX参数来定义(以字节为单位),您可以通过执行以下命令来确定 SHMMAX 的值: # cat /proc/sys/kernel/shmmax 如果机器上创建的共享内存的总共大小超出了这个限制,在程序中使用标准错误perror可能会出现以下的信息: unable to attach to shared memory 解决方法: 1、设置 SHMMAX SHMMAX 的默认值是 32MB 。一般使用下列方法之一种将 SHMMAX 参数设为 2GB : 通过直接更改 /proc 文件系统,你不需重新启动机器就可以改变 SHMMAX 的默

文档评论(0)

1亿VIP精品文档

相关文档