天天看点

PHP中进程间共享变量 shmop

类似于 asp中的 application 实现多用户 的缓存共享

进程间共享变量

用户在一个Web 应用 程序 中导航 时,如果能在Web服务器 上存储用户或会话的特定数据,从而每次请求网页 时能很容易地访问这些数据,将非常有用。存储的可以 是有关用户、用户首选项的信息,或者是与应用程序相关的数据,如购物车中的数据。用户每次请求包含session_start()函数调用的网页时,服务 器会开始一个新进程(或重用一个空闲进程),PHP 引擎将在查询字符串或cookie数据中查找一 个会话ID。这会获取 到已保存的会话数据,并建立$_SESSION数 组。

在技巧 10-5已经提到,$_SESSION是一个超全局 变量,可以从任何代码 段直接访问。如果会话是活动的,可以 从$_SESSION数组获取、增加、更新和删除值。这与处理任何其他变量是类似的。引擎会在脚本结束时自动保存数组的值,除非因为错误异常中止。会话数 据文件 会锁定,以避免多个进程同时访问(写)相同的数据。 如果脚本执行的时间 很长,或者要从同一个服务器加载多个帧,可以优化应 用程序,使用session_write_close()或session_commit()关闭会话数据文件。不论使用其中哪一个命令,之后都不能再 向$_SESSION数组增加新的值。

共享内存是在进程中共享数据的另一种办法。两个进程同时运行时(可能由不同的客户启动),就可以使用共享内存。在 大多数情况下,共享内存比共享文件或数据库 表的速度更快。在PHP中使用共享内存时,必须使 用–enable–shmop参数编译。

说明    使用共享内存时,要求进程是持久的,如Apache模块、IIS ISAPI或PHP-GTK应用程序。

shmop扩 展实现了6个简单函数,如表10-8所示。

表10-8  shmop函数

函  数  名 描    述
shmop_open() 打开或创建一个内存块来共享
shmop_close() 关闭一个共享内存块
shmop_delete() 删除一个共享内存块
shmop_read() 从一个共享内存块读取数据
shmop_write() 将数据写到一个共享内存块
shmop_size() 得到一个共享内存块的大小

使用一个共享 内存块之前必须先创建它。可以使用shmop_open()函数创建共享内存块,这个函数取4个参数。第一个参数是一个唯一ID(一个整数),用于标识这 个内存块。第二个参数是一个标志,指定了要如何访问这个块(a = 只读,c = 创建或读/写,w = 读写, n = 创建新块或失败)。第三个参数指定了内存块的入口,像文件系统 权限一样作为一个八进制数传入(如0644)。第四 个参数(也是最后一个)设置 了块的大小。如果打开一个现有的块,第三个和第四个 参数应当设置为0。

说明    共享内存块的大小在创建时就已经固定,而且不能再改变。

下面的例子显 示了如何创建并写入一个内存块。这个块将在脚本结束时删除并关闭,所以为了说明共享内存的工作原理,脚本会在终止前等待60秒。这段时间应该足够运行下一 个例子并查看共享内存。

代码

PHP中进程间共享变量 shmop

如果另一个进程还要使用这个内存块,就不能将其删除,另一个进程可以访问这 个数据,如下所示:

PHP中进程间共享变量 shmop
PHP中进程间共享变量 shmop

工作原理

在两个脚本间共享内存时,要求这两个脚本同时运行。第一个脚本 用一个字符串定义了一个共享内存块,并从这个块中读取6个字节。第二个脚本通过同一个句柄(0×123)连接到同一个块,再读取整个字符串并发送给客户。

命令行查看

        ipcs -h for help.

[[email protected] html]# ipcs -m

------ Shared Memory Segments --------

key        shmid      owner      perms      bytes      nattch     status     

0x00000001 262144     root      644        4          0                      

[[email protected] html]#

可以看到,共享内存的key, shmid,所有者,权限,大小,attach数,和状态。

删除共享内存可以用ipcrm -m shmid或ipcrm -M shmkey命令来完成。

[[email protected] html]# ipcrm -M 0x00000001

[[email protected] html]# ipcs -m

------ Shared Memory Segments --------

key        shmid      owner      perms      bytes      nattch     status     

[[email protected] html]#