http://www.php.net/manual/en/intro.shmop.php
Shmop是一组易于使用的函数,允许PHP读取, 编写,创建和删除Unix共享内存段。
我不明白,这个扩展目的究竟是什么?它用于什么?
答案 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
设置信号处理程序),有限类型的消息传递。信号在脚本页面中不是特别有用,因为每个脚本应该运行很短的时间。posix_mkfifo
用于创建named pipes(又名FIFOs),标准file函数用于读取和写入数据。可以使用anonymous或popen
在父进程和子进程之间创建未命名(aka proc_open
)管道。注意无法在任意进程之间创建未命名的管道。请注意,某些系统上的管道是单向的:管道句柄可用于读取或写入,但不能同时用于两者。shm_attach
)。还提供了各种消息传递协议的许多其他扩展,包括SAM,STOMP和AMQP。请参阅PHP手册中的“Other Services”,以及其他人。虽然套接字(以及基于它们的任何东西,例如流包装器)和管道可用于在进程之间传递数据,但它们对两个以上进程的能力是有限的。套接字只能连接两个进程;要处理两个以上,需要打开多个套接字(这是客户端 - 服务器架构通常进入的地方)。使用管道,只有一个流程read given data;一旦它有,那么这些数据将无法供其他读者使用,尽管他们可以读取其他数据(除了读者之外,所有数据都将无法读取)。任意数量的进程都可以打开相同的共享内存区域。
答案 1 :(得分:9)
当正在运行的进程请求内存时,系统会提供一块内存,只能由分配的进程访问。有时您运行多个线程并希望在它们之间共享数据。
“共享数据”可以通过以下方式完成:
由于在某些情况下传递数据不是很方便,因此可能需要使用Shared memory。
有问题的函数提供了处理PHP中共享内存段的功能。