shmop PHP扩展有什么作用?

时间:2011-12-25 22:23:22

标签: php shared-memory

http://www.php.net/manual/en/intro.shmop.php

  

Shmop是一组易于使用的函数,允许PHP读取,   编写,创建和删除Unix共享内存段。

我不明白,这个扩展目的究竟是什么?它用于什么?

2 个答案:

答案 0 :(得分:34)

共享内存允许多个进程访问内存中的相同数据。您可以使用它在运行的PHP脚本之间共享数据。

 $shm = shmop_open(0xF00, "c", 0644, 4);

 $count = unpack('L', shmop_read($shm, 0, 4));
 $count = reset($count);
 var_dump($count);
 echo "count: ", $count++, "<br/>\n";
 shmop_write($shm, pack('L', $count), 0);

当计算机重新启动时,共享内存中的任何内容都将丢失。

不同的进程可以同时访问同一个共享内存,这可能会导致race conditions。在上面的示例中,如果两个进程在写回共享内存之前读取共享内存,则计数将比它应该少1。使用mutex可以防止竞争条件,但这超出了本Q&amp; A的范围。

共享内存用于一种inter-process communication,即数据传递。 PHP中提供的其他一些(取决于平台和PHP构建)是:

  • 信号(posix_kill发送信号,pcntl_signal设置信号处理程序),有限类型的消息传递。信号在脚本页面中不是特别有用,因为每个脚本应该运行很短的时间。
  • Sockets获取数据。套接字可以使用网络,也可以是本地的。
  • 数据管道。 posix_mkfifo用于创建named pipes(又名FIFOs),标准file函数用于读取和写入数据。可以使用anonymouspopen在父进程和子进程之间创建未命名(aka proc_open)管道。注意无法在任意进程之间创建未命名的管道。请注意,某些系统上的管道是单向的:管道句柄可用于读取或写入,但不能同时用于两者。
  • Semaphores代表synchronization
  • messaging的消息队列。在PHP中,Semaphore扩展提供了消息队列和另一组共享内存函数(例如shm_attach)。还提供了各种消息传递协议的许多其他扩展,包括SAMSTOMPAMQP。请参阅PHP手册中的“Other Services”,以及其他人。
  • 网络stream wrappers获取数据。在较低级别,这些只是套接字,但它们提供不同的接口。它们也适用于特定的应用程序级协议,而套接字则更为通用。
  • Network protocol extensions,例如cURL,用于发送消息&amp;数据。与流包装器一样,这些是伪装的(限制的)套接字。
  • 对于Web service extensions(RPC),
  • SOAP,例如XML-RPCremote procedure calls。请注意,虽然这些是基于套接字的,但它们是针对不同类型的IPC(RPC而不是数据)。

虽然套接字(以及基于它们的任何东西,例如流包装器)和管道可用于在进程之间传递数据,但它们对两个以上进程的能力是有限的。套接字只能连接两个进程;要处理两个以上,需要打开多个套接字(这是客户端 - 服务器架构通常进入的地方)。使用管道,只有一个流程read given data;一旦它有,那么这些数据将无法供其他读者使用,尽管他们可以读取其他数据(除了读者之外,所有数据都将无法读取)。任意数量的进程都可以打开相同的共享内存区域。

答案 1 :(得分:9)

当正在运行的进程请求内存时,系统会提供一块内存,只能由分配的进程访问。有时您运行多个线程并希望在它们之间共享数据。

“共享数据”可以通过以下方式完成:

  • 通过套接字/管道传递数据
  • 共享内存(线程,进程)

由于在某些情况下传递数据不是很方便,因此可能需要使用Shared memory

有问题的函数提供了处理PHP中共享内存段的功能。