PHP进程通信基础——shmop 、sem系列函数使用

PHP进程通信基础——shmop 、sem系列函数使用

进程通信的原理就是在系统中开辟出一个共享区域,不管是管道也好,还是共享内存,都是这个原理。如果心中有了这个概念,就会很方便去理解代码。由于官网上shmop函数的英语解释稍显复杂,所以一边练习,一边简单翻译了下。信号量的内存扩展函数,比较简单,也非常好理解。所以就没有翻译。这篇博客是通信基础,所以直接就放实例代码了,按照上代码上敲一遍,就能够明白个七七八八了。如果实在不明白,可以复制进去,直接打断点调试,也是一种不错的学习思路。

这篇文章参考:

http://php.net/manual/en/ref.sem.php

http://php.net/manual/en/ref.shmop.php

http://www.cnblogs.com/nickbai/articles/6133354.html

1、shmop 系列函数使用

<?php//使用shmop 系列函数set_time_limit(0);$shm_key = ftok(__FILE__, ‘t‘);$shm_id = shmop_open($shm_key, "c", 0655, 1024);$size = shmop_write($shm_id, "Hello world".PHP_EOL, 0);shmop_write($shm_id, ‘I love you‘.PHP_EOL, $size+1);echo $size.PHP_EOL;$data = shmop_read($shm_id, 0, 100);var_dump($data);shmop_delete($shm_id);shmop_close($shm_id);

//Shared Memory Functions

/** * shmop_open(int $key , string $flags , int $mode , int $size) * $key 共享内存的key * $flags 的值有以下几种 * a :  创建一个只读的共享内存区。 * c :  如果共享内存区已存在,则打开该共享内存区,并尝试读写。否则新建共享内存区 * w : 创建一个读写共享内存区 * n :  创建一个共享内存区,如果已存在,则返回失败 * * $mode 读写权限。如0755 0644 等 * $size 申请共享内存区的大小 */

/** * shmop_read( resource $shmid , int $start , int $count) * 将从共享内存块中读取数据 * $shmid 共享内存id,资源类型 * $start 从共享内存的那个字节开始读起 * $count 一次读取多少个字节。 * 如果count值小于发送的信息长度,则信息会被截断。 */

/** * shmop_write(resource $shmid , string $data , int $offset) * 将数据写入共享内存块 * $data 将要写入的数据 * $offset 从共享内存块的那个位置开始写入。 * 该函数的返回值是写入数据的长度。 */

/** * shmop_size(resource $shmid); * 返回当前共享内存块,已经使用的大小 */

/** * shmop_delete ( resource $shmid ) * 删除一个共享内存块的,删除引用关系 */

/** * shmop_close ( resource $shmid ) * 关闭共享内存块 * 要先使用shmop_delete 之后才能继续使用shmop_close */

2、shm 系列函数使用

<?php//使用信号量扩展共享内存$key = ftok(__FILE__, ‘a‘);$share_key = 1;

//创建一个共享内存,大小为1024字节,权限为755$shm_id = shm_attach($key, 1024, 0755);

//将一个key=>value放进共享内存$message1 = "I love Roverliang";shm_put_var($shm_id, $share_key, $message1);

//重复使用key ,前一个设置的值会被后一个设置的值覆盖掉。$message2 = "I love Rover";shm_put_var($shm_id, $share_key, $message2);

//读取一个共享内存值$read_message = shm_get_var($shm_id, $share_key);echo $read_message.PHP_EOL;

//并不是取走了,而是读取$read_message2 = shm_get_var($shm_id, $share_key);echo $read_message2.PHP_EOL;

//判断共享内存中,某个值是否存在$isexists = shm_has_var($shm_id, $share_key);var_dump($isexists);

//删除一个值shm_remove_var($shm_id, $share_key);

//判断共享内存中,某个值是否存在$isexists = shm_has_var($shm_id, $share_key);var_dump($isexists);

//删除一个共享内存shm_remove($shm_id);

//关闭共享内存的连接shm_detach($shm_id);
时间: 2024-10-13 22:36:27

PHP进程通信基础——shmop 、sem系列函数使用的相关文章

替换进程映像 - exec系列函数

exec系列函数由一组相关的函数组成,它们在进程的启动方式和程序参数的表达方式上各有不同.exec函数可以把当前进程替换为一个新进程,新进程由patch或file参数指定.你可以使用exec函数将程序的执行从一个程序切换到另一个程序.例如,你可以在启动另一个有着受限使用策略的程序前,检查用户的凭证.exec函数比system函数更有效,因为在新的程序启动后,原来的程序就不再运行了. 替换进程映像 - exec系列函数

【转载】linux进程控制-exec系列 exec系统调用

inux进程控制-exec系列 说是exec系统调用,实际上在Linux中,并不存在一个exec()的函数形式,exec指的是一组函数,一共有6个,分别是: #include <unistd.h>int execl(const char *path, const char *arg, ...);int execlp(const char *file, const char *arg, ...);int execle(const char *path, const char *arg, ...,

exec系列函数(execl,execlp,execle,execv,execvp)使用

本节目标: exec替换进程映像 exec关联函数组(execl.execlp.execle.execv.execvp) 一,exec替换进程映像 在进程的创建上Unix采用了一个独特的方法,它将进程创建与加载一个新进程映象分离.这样的好处是有更多的余地对两种操作进行管理. 当我们创建了一个进程之后,通常将子进程替换成新的进程映象,这可以用exec系列的函数来进行.当然,exec系列的函数也可以将当前进程替换掉. 例如:在shell命令行执行ps命令,实际上是shell进程调用fork复制一个新

一起talk C栗子吧(第一百三十五回:C语言实例--exec系列函数一)

各位看官们,大家好,上一回中咱们说的是"创建线程时的内存细节"的例子,这一回咱们说的例子是:exec系列函数.闲话休提,言归正转.让我们一起talk C栗子吧! 看官们,我们在前面介绍创建进程内存细节的章回中提到过exec系列函数,当时并没有做详细的介绍.今天我们将和大家一起看看exec系列函数. exec系列函数可以把某个进程导入到调用exec系列函数的进程中,并且把当前进程替换成一个新的进程,在前面的章回中我们也介绍了,执行exec系列函数会触发写时复制,因此新进程拥有自己的代码区

posix 线程(一):线程模型、pthread 系列函数 和 简单多线程服务器端程序

posix 线程(一):线程模型.pthread 系列函数 和 简单多线程服务器端程序 一.线程有3种模型,分别是N:1用户线程模型,1:1核心线程模型和N:M混合线程模型,posix thread属于1:1模型. (一).N:1用户线程模型 “线程实现”建立在“进程控制”机制之上,由用户空间的程序库来管理.OS内核完全不知道线程信息.这些线程称为用户空间线程.这些线程都工作在“进 程竞争范围”(process contention scope):各个线程在同一进程竞争“被调度的CPU时间”(但

Linux中exec()执行文件系列函数的使用说明

函数原型: 描述:    exec()系列函数使用新的进程映像替换当前进程映像.    工作方式没有什么差别, 只是参数传递的方式不同罢了. 说明:    1. 这6个函数可分为两大类: execl()系列 和 execv()系列.    2. `l' 是指把所有传递给程序的参数依次列(list)出来.        `v' 是指把所有参数放到容器(数组, vector)中再一次性传入.         不论是list出来还是vector them all, 参数的最后一个都必须为空指针((ch

关于getpw系列函数返回的静态区域

首先说一下什么是getpw系列函数,它主要是指这些函数: 这些函数根据一个用户名(getpwnam和getpwnam_r两个函数)或者一个用户ID(getpwuid和getpwuid_r)来获取这个用户在/etc/passwd中相应的条目信息,并把这些信息存放在一个struct passwd的结构体里面,然后再把这个结构体的指针返回.问题就出在这个存储用户信息的结构体上面,它是由getpw函数在程序中自定义的一块静态存储区,而且每调用一次getpw函数,这个静态存储区就会被重写一次.比如下面这段

execve 系列函数

exec系列函数(execl.execlp.execle.execv.execvp) 1带 p 的exec函数:execlp,execvp,表示第一个参数path不用输入完整路径,只有给出命令名即可,它会在环境变量PATH当中查找命令 2 execl* 和execv*的区别是,前者一一列出参数,后者用指针数组这出. 3 最后有e的表示自己制定环境变量,不带e的表示使用进程环境原有的环境变量.

contiki-main.c 中的process系列函数学习笔记 &lt;contiki学习笔记之六&gt;

说明:本文依然依赖于 contiki/platform/native/contiki-main.c 文件. ------------------------------------------------------------------------------------------------------------------------------------- 根据上一个笔记里面添加的printf()语句的打印信息提示,hello world 打印是在执行了 1 autostart_