首页 php教程 PHP源码 PHP进程通信基础之信号量与共享内存通信_php技巧

PHP进程通信基础之信号量与共享内存通信_php技巧

May 26, 2016 am 08:18 AM
共享内存 进程通信 进程间通信

这篇文章主要介绍了PHP进程通信基础知识中的信号量与共享内存通信的相关资料,有需要的小伙伴可以查看下

由于进程之间谁先执行并不确定,这取决于内核的进程调度算法,其中比较复杂。由此有可能多进程在相同的时间内同时访问共享内存,从而造成不可预料的错误。信号量这个名字起的令人莫名其妙,但是看其英文原意,就十分容易理解。

semaphore 英[ˈseməfɔ:(r)] vt. 发出信号,打旗语;

类似于指挥官的作用。

下面我们看下一个伪代码信号量的使用。

1、创建信号量唯一标识符

$ftok = ftok(__FILE__, 'a');

2、创建信号量资源ID

$sem_resouce_id = sem_get($ftok);

3、接受信号量

sem_acqure($sem_resource_id);

4、释放信号量

sem_release($sem_resource_id);

5、销毁信号量

sem_remove($sem_resource_id);

举个不文雅的例子,使我们容易理解这个信号量在生活中的用法。理解之后可以套用到我们编程领域。
一家公司只有一个卫生间。那么当有人上厕所的时候,都要获取一把锁(信号量),表示卫生间正在使用。代码如下:

sem_acqure($sem_resource_id);

那么员工上完厕所之后,就需要将锁打开,释放锁(信号量),表示现在可以允许别人使用。代码如下:

sem_release($sem_resource_id);

通过一个简单的锁,我们就能够知道当前的厕所(共享内存)是否可以使用。这个例子不雅观,但说明了问题。这篇博客也是有味道的博客,真是不容易。。。。以下是示例代码:

<?php
//创建共享内存区域
$shm_key = ftok(__FILE__, &#39;a&#39;);
$shm_id = shm_attach($shm_key, 1024, 0755);
//var_dump($shm_id);die(); resource(4) of type (sysvshm)
const SHARE_KEY = 1;
$child_list = [];
//加入信号量
$sem_id = ftok(__FILE__, &#39;b&#39;);
$signal = sem_get($sem_id);
//$signal resource(5) of type (sysvsem)
for ($i = 0; $i < 3; $i++) {
  $pid = pcntl_fork();
  if ($pid == -1) {
    exit("Fork fail!".PHP_EOL);
  } elseif ($pid == 0) {
   //获取信号量
   sem_acquire($signal);
    if (shm_has_var($shm_id,SHARE_KEY)) {
      $count = shm_get_var($shm_id, SHARE_KEY);
      $count++;
      //模拟业务处理
      $sec = rand(1, 3);
      sleep($sec);
     shm_put_var($shm_id, SHARE_KEY, $count);
    } else {
      $count = 0;
      $sec = rand(1, 3);
      sleep($sec);
      shm_put_var($shm_id, SHARE_KEY, $count);
    }
    echo "child process: ".getmypid()." is writing! now count is: $count ".PHP_EOL;
    //释放信号量
    sem_release($signal);
    exit("child process".getmypid()."end".PHP_EOL);
  } else {
    $child_list[] = $pid;
  }
}

while (count($child_list) > 0) {
  foreach ($child_list as $key => $pid) {
    $status = pcntl_waitpid($pid, $status);
    if ($status > 0 || $status == -1) {
      unset($child_list[$key]);
    }
  }
  sleep(1);
}

$count = shm_get_var($shm_id, SHARE_KEY);
echo " $count  ".PHP_EOL;

//销毁信号量
sem_remove($signal);

shm_remove($shm_id);
shm_detach($shm_id);
登录后复制
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
2 周前 By 尊渡假赌尊渡假赌尊渡假赌
仓库:如何复兴队友
1 个月前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
1 个月前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

win10gpu共享内存关闭方法 win10gpu共享内存关闭方法 Jan 12, 2024 am 09:45 AM

对电脑有了解的小伙伴肯定都知道gpu有着共享内存,而许多小伙伴都担心共享内存会导致内存数变小影响电脑而想着关闭它,下面就给大家带来了关闭它的方法,一起看看吧。win10gpu共享内存关闭:注:GPU的共享内存是无法关闭的,但是可以将它的数值设置为最小值。1、开机时按DEL进入BIOS,部分主板需要按F2/F9/F12进入,在BIOS界面的最上方有很多Tab,包含“Main、Advanced”等等设定,找到“Chipset”选项。在下面的界面中找到SouthBridge设定选项,点击Enter进入

Golang函数的多进程之间共享内存的应用方法 Golang函数的多进程之间共享内存的应用方法 May 17, 2023 pm 12:52 PM

Golang作为一门高并发编程语言,其内置的协程机制和多线程操作实现了轻量级的多任务处理。然而,在多进程处理的场景下,不同进程之间的通信和共享内存成为了程序开发的关键问题。本文将介绍在Golang中实现多进程之间共享内存的应用方法。一、Golang中多进程的实现方式在Golang中,可以通过多种方式实现多进程并发处理,其中包括fork、os.Process、

PHP共享内存函数用法及应用 PHP共享内存函数用法及应用 Jun 16, 2023 pm 12:27 PM

PHP共享内存函数用法及应用共享内存是指多个进程同时存取同一段内存空间的技术。在并发编程中,共享内存可用于进程间通信,从而实现不同进程之间的数据共享。PHP也提供了相关的共享内存函数,这篇文章将介绍PHP共享内存函数的用法,并且探讨一些实际应用场景。共享内存函数的使用PHP提供了shmop这个扩展模块,使得PHP可以对系统共享内存进行操作。该扩展模块提供的函

PHP中的多进程 PHP中的多进程 May 23, 2023 am 08:39 AM

随着互联网的发展,越来越多的网站需要承载大量用户的访问请求。单进程的服务器在面对高并发的情况下,会很快达到瓶颈,导致用户无法正常访问网站。因此,多进程成为解决高并发问题的有效方案之一。本文将介绍PHP中的多进程技术,在保证程序质量的前提下提高程序处理并发请求的能力。一、多进程简介在计算机科学中,进程是指正在执行的程序实例。每个进程有自己的内存空间和系统资源。

Golang 进程通信:构建高效沟通桥梁 Golang 进程通信:构建高效沟通桥梁 Apr 03, 2024 pm 10:09 PM

Go中的进程间通信(IPC)通过管道、通道和共享内存实现。管道允许协程通过管道端点写入和读取数据,而通道则保证了发送和接收操作的原子性。共享内存通过让进程访问同一块内存实现快速数据交换,但需要同步以防止并发访问。

在C++中使用共享内存和消息队列 在C++中使用共享内存和消息队列 Aug 22, 2023 pm 04:21 PM

在C++中,共享内存和消息队列是两个常用的进程间通信方式。它们可以帮助我们在不同的进程之间共享数据和信息,从而实现更加高效的程序设计。共享内存是一种特殊的内存区域,可以被多个进程共享。使用共享内存可以避免复制数据的开销,也能够减少数据在进程间传输的延迟。C++中使用共享内存需要包含&lt;sys/shm.h&gt;头文件,并使用shmget、shmat、sh

Python 3.x 中如何使用multiprocessing模块进行进程间通信 Python 3.x 中如何使用multiprocessing模块进行进程间通信 Aug 01, 2023 pm 12:39 PM

Python3.x中如何使用multiprocessing模块进行进程间通信随着计算机技术的发展,我们在编程中经常需要同时执行多个任务。为了更好地利用多核处理器,Python的multiprocessing模块提供了一套简单而强大的工具来创建并发程序。multiprocessing模块允许我们在Python中使用多个进程,这些进程可以同时执行并在需要时进

Golang开发:使用RPC实现跨进程通信 Golang开发:使用RPC实现跨进程通信 Sep 21, 2023 pm 03:26 PM

Golang开发:使用RPC实现跨进程通信,需要具体代码示例一、介绍RPCRPC(RemoteProcedureCall)是一种远程过程调用协议,它使得客户端可以调用位于远程计算机上的服务端程序的函数或方法,就像调用本地函数一样。RPC可以使用不同的网络协议实现,如TCP、HTTP等。在分布式系统中,RPC是一种重要的通信机制,常用于跨进程或跨网络节点的

See all articles