如何设置LINUX的共享内存

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何设置LINUX的共享内存相关的知识,希望对你有一定的参考价值。

我们可以修改shmmax内核参数,使SGA存在于一个共享内存段中。
  通过修改/proc/sys/kernel/shmmax参数可以达到此目的。
  [root@neirong root]# echo 1073741824 > /proc/sys/kernel/shmmax
  [root@neirong root]# more /proc/sys/kernel/shmmax
  1073741824这里设为1G。
  对于shmmax文件的修改,系统重新启动后会复位。可以通过修改 /etc/sysctl.conf 使更改永久化。
  在该文件内添加以下一行 kernel.shmmax = 1073741824 这个更改在系统重新启动后生效.
  1、设置 SHMMAX
  SHMMAX
  参数定义共享内存段的最大尺寸(以字节为单位)。在设置 SHMMAX 时,切记 SGA 的大小应该适合于一个共享内存段。 SHMMAX 设置不足可能会导致以下问题:
  ORA-27123:unable to attach to shared memory segment
  您可以通过执行以下命令来确定 SHMMAX 的值:
  # cat /proc/sys/kernel/shmmax
  33554432
  SHMMAX 的默认值是 32MB 。我一般使用下列方法之一种将 SHMMAX 参数设为 2GB :
  通过直接更改 /proc 文件系统,你不需重新启动机器就可以改变 SHMMAX 的默认设置。我使用的方法是将以下命令放入 /etc/rc.local 启动文件中:
  # >echo "2147483648" > /proc/sys/kernel/shmmax
  您还可以使用 sysctl 命令来更改 SHMMAX 的值:
  # sysctl -w kernel.shmmax=2147483648
  最后,通过将该内核参数插入到 /etc/sysctl.conf 启动文件中,您可以使这种更改永久有效:
  # echo "kernel.shmmax=2147483648" >> /etc/sysctl.conf
  2、设置 SHMMNI
  我们现在来看 SHMMNI 参数。这个内核参数用于设置系统范围内共享内存段的最大数量。该参数的默认值是 4096 。这一数值已经足够,通常不需要更改。
  您可以通过执行以下命令来确定 SHMMNI 的值:
  # cat /proc/sys/kernel/shmmni
  4096
  3、设置 SHMALL
  最后,我们来看 SHMALL 共享内存内核参数。该参数控制着系统一次可以使用的共享内存总量(以页为单位)。简言之,该参数的值始终应该至少为:
  ceil(SHMMAX/PAGE_SIZE)
  SHMALL 的默认大小为 2097152 ,可以使用以下命令进行查询:
  # cat /proc/sys/kernel/shmall
  2097152
  SHMALL 的默认设置对于我们的 Oracle9 i RAC 安装来说应该足够使用。
  注意: 在 i386 平台上 Red Hat Linux 的 页面大小 为 4096 字节。但是,您可以使用 bigpages ,它支持配置更大的内存页面尺寸。
参考技术A 这个 key 对应的是 IPC_PRIVATE,即创建 shared memory 时,可以用 IPC_PRIVATE 来创建,而不用指定具体的 key 值, 你看到的就是这类 shared memory。 具体细节,你可以 man shmget。

linux共享内存的控制释放

调用 shmctl(Shared Memory Control,控制共享内存)函数会返回一个共享内存块的相关信息。同时 shmctl 允许程序修改这些信息。该函数的第一个参数是一个共享内存块标识。
要获取一个共享内存块的相关信息,则为该函数传递 IPC_STAT 作为第二个参数,同时传递一个指向一个 struct shmid_ds 对象的指针作为第三个参数。
要删除一个共享内存块,则应将 IPC_RMID 作为第二个参数,而将 NULL 作为第三个参数。当最后一个绑定该共享内存块的进程与其脱离时,该共享内存块将被删除。
您应当在结束使用每个共享内存块的时候都使用 shmctl 进行释放,以防止超过系统所允许的共享内存块的总数限制。调用 exit 和 exec 会使进程脱离共享内存块,但不会删除这个内存块。 要查看其它有关共享内存块的操作的描述,请参考shmctl函数的手册页。

参考技术A 要让一个进程获取对一块共享内存的访问,这个进程必须先调用 shmat(SHared Memory Attach,绑定到共享内存)。
将 shmget 返回的共享内存标识符 SHMID 传递给这个函数作为第一个参数。
该函数的第二个参数是一个指针,指向希望用于映射该共享内存块的进程内存地址;
如果指定NULL则Linux会自动选择一个合适的地址用于映射。
第三个参数是一个标志位,包含了以下选项:
SHM_RND表示第二个参数指定的地址应被向下靠拢到内存页面大小的整数倍。
如果不指定这个标志,将不得不在调用shmat的时候手工将共享内存块的大小按页面大小对齐。
SHM_RDONLY表示这个内存块将仅允许读取操作而禁止写入。
如果这个函数调用成功则会返回绑定的共享内存块对应的地址。
通过 fork 函数创建的子进程同时继承这些共享内存块;
如果需要,它们可以主动脱离这些共享内存块。
当一个进程不再使用一个共享内存块的时候应通过调用 shmdt(Shared Memory Detach,脱离共享内存块)函数与该共享内存块脱离。
将由 shmat 函数返回的地址传递给这个函数。
如果当释放这个内存块的进程是最后一个使用该内存块的进程,则这个内存块将被删除。
对 exit 或任何exec族函数的调用都会自动使进程脱离共享内存块。

以上是关于如何设置LINUX的共享内存的主要内容,如果未能解决你的问题,请参考以下文章

如何设置LINUX的共享内存

如何在unix环境下实现共享内存

linux 共享内存 可不可以不加锁呢? 系统有两个进程,一个负责写入,一个负责读取

linux共享内存的控制释放

linux共享内存和mmap的区别

集成显卡如何设置共享内存