您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

PHP信号量的用法及实例

2024/4/7 15:08:27发布9次查看
本篇文章主要介绍php信号量的用法及实例,感兴趣的朋友参考下,希望对大家有所帮助。
理论基础:
信号量:又称为信号灯、旗语 用来解决进程(线程同步的问题),类似于一把锁,访问前获取锁(获取不到则等待),访问后释放锁。
临界资源:每次仅允许一个进程访问的资源。
临界区:每个进程中访问临界资源的那段代码叫临界区
进程互斥:两个或以上的进程不能同时进入关于同一组共享变量的临界区域,即一个进程正在访问临界资源,另一个进程要想访问必须等待。
进程同步主要研究如何确定数个进程之间的执行顺序和避免数据竞争的问题 即,如何让多个进程能一块很好的协作运行
实例如下:
$key=ftok(__file__,'t');/** * 获取一个信号量资源 int $key [, int $max_acquire = 1 [, int $perm = 0666 [, int $auto_release = 1 ]]] $max_acquire:最多可以多少个进程同时获取信号 $perm:权限 默认 0666 $auto_release:是否自动释放信号量 */$sem_id=sem_get($key);#获取信号sem_acquire($seg_id);//do something 这里是一个原子性操作//释放信号量sem_release($seg_id);//把次信号从系统中移除sem_remove($sem_id);//可能出现的问题$fp = sem_get(fileinode(__dir__), 100);sem_acquire($fp);$fp2 = sem_get(fileinode(__dir__), 1));sem_acquire($fp2);
implementation of a read-write semaphore in php:
class rw_semaphore { const read_access = 0; const write_access = 1; /** * @access private * @var resource - mutex semaphore */ private $mutex; /** * @access private * @var resource - read/write semaphore */ private $resource; /** * @access private * @var int */ private $writers = 0; /** * @access private * @var int */ private $readers = 0; /** * default constructor * * initialize the read/write semaphore */ public function __construct() { $mutex_key = ftok('/home/cyrus/development/php/sysvipc/rw_semaphore.php', 'm'); $resource_key = ftok('/home/cyrus/development/php/sysvipc/rw_semaphore.php', 'r'); $this->mutex = sem_get($mutex_key, 1); $this->resource = sem_get($resource_key, 1); } /** * destructor * * remove the read/write semaphore */ public function __destruct() { sem_remove($this->mutex); sem_remove($this->resource); } /** * request acess to the resource * * @param int $mode * @return void */ private function request_access($access_type = self::read_access) { if ($access_type == self::write_access) { sem_acquire($this->mutex); /* update the writers counter */ $this->writers++; sem_release($this->mutex); sem_acquire($this->resource); } else { sem_acquire($this->mutex); if ($this->writers > 0 || $this->readers == 0) { sem_release($this->mutex); sem_acquire($this->resource); sem_acquire($this->mutex); } /* update the readers counter */ $this->readers++; sem_release($this->mutex); } } private function request_release($access_type = self::read_access) { if ($access_type == self::write_access) { sem_acquire($this->mutex); /* update the writers counter */ $this->writers--; sem_release($this->mutex); sem_release($this->resource); } else { sem_acquire($this->mutex); /* update the readers counter */ $this->readers--; if ($this->readers == 0) sem_release($this->resource); sem_release($this->mutex); } } /** * request read access to the resource * * @return void */ public function read_access() { $this->request_access(self::read_access); } /** * release read access to the resource * * @return void */ public function read_release() { $this->request_release(self::read_access); } /** * request write access to the resource * * @return void */ public function write_access() { $this->request_access(self::write_access); } /** * release write access to the resource * * @return void */ public function write_release() { $this->request_release(self::write_access); }}
共享内存+信号 实现原子性操作
$shm_key = ftok("/home/joeldg/homeymail/shmtest.php", 'r');$shmid = sem_get($shm_key, 1024, 0644 | ipc_creat);$data = shm_attach($shmid, 1024);// we now have our shm segment// lets place a variable in thereshm_put_var ($data, $inmem, "test");// now lets get it back. we could be in a forked process and still have// access to this variable.printf("shared contents: %s\n", shm_get_var($data, $inmem));shm_detach($data);
总结:以上就是本篇文的全部内容,希望能对大家的学习有所帮助。
相关推荐:
php实现数据分页显示功能的方法
php封装的mssql操作类以及完整实例分析
php连接oracle数据库的方法及简单分析
以上就是php信号量的用法及实例的详细内容。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product