PHP使用多线程-程序员宅基地

技术标签: 多线程  PHP  pthreads  

PHP 5.3 以上版本,使用pthreads PHP扩展,可以使PHP真正地支持多线程。多线程在处理重复性的循环任务,能够大大缩短程序执行时间。

  我之前的文章中说过,大多数网站的性能瓶颈不在PHP服务器上,因为它可以简单地通过横向增加服务器或CPU核数来轻松应对(对于各种云主机,增加VPS或CPU核数就更方便了,直接以备份镜像增加VPS,连操作系统、环境都不用安装配置),而是在于MySQL数据库。如果用 MySQL 数据库,一条联合查询的SQL,也许就可以处理完业务逻辑,但是,遇到大量并发请求,就歇菜了。如果用 NoSQL 数据库,也许需要十次查询,才能处理完同样地业务逻辑,但每次查询都比 MySQL 要快,十次循环NoSQL查询也许比一次MySQL联合查询更快,应对几万次/秒的查询完全没问题。如果加上PHP多线程,通过十个线程同时查询NoSQL,返回结果汇总输出,速度就要更快了。我们实际的APP产品中,调用一个通过用户喜好实时推荐商品的PHP接口,PHP需要对BigSea NoSQL数据库发起500~1000次查询,来实时算出用户的个性喜好商品数据,PHP多线程的作用非常明显。

  PHP扩展下载:https://github.com/krakjoe/pthreads
  PHP手册文档:http://php.net/manual/zh/book.pthreads.php

  1、扩展的编译安装(Linux),编辑参数 --enable-maintainer-zts 是必选项:

cd /Data/tgz/php-5.5.1
./configure --prefix=/Data/apps/php --with-config-file-path=/Data/apps/php/etc --with-mysql=/Data/apps/mysql --with-mysqli=/Data/apps/mysql/bin/mysql_config --with-iconv-dir --with-freetype-dir=/Data/apps/libs --with-jpeg-dir=/Data/apps/libs --with-png-dir=/Data/apps/libs --with-zlib --with-libxml-dir=/usr --enable-xml --disable-rpath --enable-bcmath --enable-shmop --enable-sysvsem --enable-inline-optimization --with-curl --enable-mbregex --enable-fpm --enable-mbstring --with-mcrypt=/Data/apps/libs --with-gd --enable-gd-native-ttf --with-openssl --with-mhash --enable-pcntl --enable-sockets --with-xmlrpc --enable-zip --enable-soap --enable-opcache --with-pdo-mysql --enable-maintainer-zts
make clean
make
make install        

unzip pthreads-master.zip
cd pthreads-master
/Data/apps/php/bin/phpize
./configure --with-php-config=/Data/apps/php/bin/php-config
make
make install


 

vi /Data/apps/php/etc/php.ini


添加:

extension = "pthreads.so"

 

<?php
  class test_thread_run extends Thread 
  {
      public $url;
      public $data;

      public function __construct($url)
      {
          $this->url = $url;
      }

      public function run()
      {
          if(($url = $this->url))
          {
              $this->data = model_http_curl_get($url);
          }
      }
  }

  function model_thread_result_get($urls_array) 
  {
      foreach ($urls_array as $key => $value) 
      {
          $thread_array[$key] = new test_thread_run($value["url"]);
          $thread_array[$key]->start();
      }

      foreach ($thread_array as $thread_array_key => $thread_array_value) 
      {
          while($thread_array[$thread_array_key]->isRunning())
          {
              usleep(10);
          }
          if($thread_array[$thread_array_key]->join())
          {
              $variable_data[$thread_array_key] = $thread_array[$thread_array_key]->data;
          }
      }
      return $variable_data;
  }

  function model_http_curl_get($url,$userAgent="") 
  {
      $userAgent = $userAgent ? $userAgent : 'Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 5.2)'; 
      $curl = curl_init();
      curl_setopt($curl, CURLOPT_URL, $url);
      curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
      curl_setopt($curl, CURLOPT_TIMEOUT, 5);
      curl_setopt($curl, CURLOPT_USERAGENT, $userAgent);
      $result = curl_exec($curl);
      curl_close($curl);
      return $result;
  }

  for ($i=0; $i < 100; $i++) 
  { 
      $urls_array[] = array("name" => "baidu", "url" => "http://www.baidu.com/s?wd=".mt_rand(10000,20000));
  }

  $t = microtime(true);
  $result = model_thread_result_get($urls_array);
  $e = microtime(true);
  echo "多线程:".($e-$t)."\n";

  $t = microtime(true);
  foreach ($urls_array as $key => $value) 
  {
      $result_new[$key] = model_http_curl_get($value["url"]);
  }
  $e = microtime(true);
  echo "For循环:".($e-$t)."\n";
?>

转自:https://www.cnblogs.com/kluan/p/5934228.html

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/why444216978/article/details/85049416

智能推荐

六级考研单词之路-三十三_implement compencate-程序员宅基地

文章浏览阅读185次。title: 六级考研单词之路-三十三date: 2020-12-23 12:29:58tags: 六级考研单词之路Day331.bin[n.大口箱,垃圾箱,仓;v.扔掉]eg:It’ s the time to bin that old thing. 是时候把那些旧东西给扔了。考研:bin 垃圾桶,箱子dustbin 纸篓2.compatibleadj.兼容的,可和谐共存的]eg:Their._implement compencate

如何将ubuntu LTS升级为Pro_ubuntu pro-程序员宅基地

文章浏览阅读2.7w次。去年年末,Canonical 宣布,Ubuntu Pro,即我们的扩展安全维护和合规性订阅现可作为公测版用于数据中心和桌面。Ubuntu Pro 订阅涵盖 Landscape,这是 Canonical 针对所有 Ubuntu 版本的监控和管理工具,为实体和虚拟机群提供软件更新、配置管理、政策合规性和权限控制。这些功能让 Ubuntu 的 Active Directory 管理经验尽可能地与 Windows 保持一致,让系统管理员安全管理大规模的 Ubuntu 桌面所需的学习曲线变得平缓。_ubuntu pro

[VulnHub靶机渗透] CTF7-程序员宅基地

文章浏览阅读117次。本篇博客根据大佬红队笔记的视频进行打靶,详述了打靶的每一步思路,并非复现writeup,读者耐心看完,定会有所收获。打靶过程涉及到关于SQL注入、不安全的文件上传、awk字符串处理、md5哈希批量破解、密码喷射等

期货_期货量化交易:提高效率的数学模型_期货 数学模型-程序员宅基地

文章浏览阅读793次,点赞21次,收藏15次。如果您看一下最后一个不完整的交易轮回,我特别在起点下方收官,您会发现在某些情况下会很幸运,您应等待轮回的成功收官,而在某些情况下,您可能还未等到最后,就面临巨大的损失,或者令您的资金彻底爆仓。事情在于,该图像可能会给人一种错误的印象,即资金的回撤金额在其绝对价值上是有限的,因此,在这种回撤中花费的时间也应该受到限制。在许多情况下,如果我们有适当的数学表达式,我们可以得到完成积分或级数之和的精确方程,但在真实交易的情况下,我们就无法应用微积分,一般来说这对我们没有多大帮助,但重要的是理解。_期货 数学模型

布局数字隔离器件领域,世强硬创获中科格励微授权代理-程序员宅基地

文章浏览阅读358次,点赞9次,收藏9次。中科格励微具有隔离功能的系列产品包括标准数字隔离器、隔离电源、隔离型总线和隔离栅极驱动器等。

Nvivo简介、学习经验分享及教程_nvivo学习心得-程序员宅基地

文章浏览阅读8.3k次,点赞5次,收藏70次。NVivo 是一款功能强大的质性分析 (Qualitative Analysis)软件,能够有效分析多种不同类型数据,诸如文字,图片,录音,录像等数据,是实现质性研究的最佳工具。使用NVivo ,可以将你从以往的资料分析过程诸如分类、排序、整理等繁杂手工作业的劳累中解脱出来,让你有更充分的时间去探究发展趋势,建立理论模型,并最终获得研究问题的结论。如果你还没有软件请参考文章:定性分析Nvivo软件 12/11plus 永久许可windows版本-宗盛教育安装即可。本教程为Nviv.._nvivo学习心得

随便推点

SpringBoot+Vue在线商城系统(源码+论文+任务书)_基于spring boot和vue的网上商城-程序员宅基地

文章浏览阅读554次。近10年中国的互联网市场发生巨变,线上消费得到快速发展,越来越多的人通过网络购物。商品信息管理页面,此页面提供给管理员的功能有:根据商品信息进行条件查询,还可以对商品信息进行新增、修改、查询操作等等。用户信息管理页面,此页面提供给管理员的功能有:用户信息的查询管理,可以删除用户信息、修改用户信息、新增用户信息。商品分类管理页面,此页面提供给管理员的功能有:查看已发布的商品分类数据,修改商品分类,商品分类作废,即可删除。轮播图管理页面,此页面提供给管理员的功能有:根据轮播图进行新增、修改、查询操作等等。_基于spring boot和vue的网上商城

史上最厉害的“1+2”!这个270年前出现的大难题,已经60多年没有出现好消息了..........-程序员宅基地

文章浏览阅读1.8k次。全世界只有3.14 %的人关注了爆炸吧知识费马费马欧拉欧拉数学是科学的皇后数论是数学中的皇冠这顶皇冠每一次被举起它的光芒都在照亮数学的前方从1+1=2到“1+2”人类一次次逼近“哥德巴..._黎曼猜想下的1+2

手把手教你使用zabbix5.0设置企业微信告警_zabbix5.0企业微信告警脚本-程序员宅基地

文章浏览阅读228次。一、环境要求需要准备2台虚拟机,镜像是centos7,保证2台虚拟机之间可以正常通信,并且可以正常连接外网。EOF二、zabbix-server安装步骤1:下载Zabbix安装包2:下载安装Centos_scl软件合集并修改yum源启用basearchbaseurlhttp//repozabbixcomzabbix/5.0/rhel/7/enabled=1。_zabbix5.0企业微信告警脚本

Python批量修改、删除、替换xml文件内容(labelimg标注)_labelimg删除标签会把classes里的内容删除-程序员宅基地

文章浏览阅读1w次,点赞25次,收藏114次。使用模型训练自定义数据集之前,在用在网上搜索得到的图片制作数据集时,即使批量修改图片名称后,在使用labelimg标注得到的xml文件中,图片名称还是网络上图片原本的名称,这时需要对其进行批量修改。<annotation> <folder>测试图片</folder> <filename>ae2f50b6a937df1e1a72f9bcc45b172d.jpg</filename> <path>F:\项目图像数据集\ae2f5_labelimg删除标签会把classes里的内容删除

读书笔记:getting things done_get things done读后感-程序员宅基地

文章浏览阅读729次。http://www.amazon.com/Getting-Things-Done-Stress-Free-Productivity/dp/0142000280/ref=sr_1_1?s=books&ie=UTF8&qid=1401151197&sr=1-1&keywords=getting+things+done_get things done读后感

python周期函数的拟合_Python可以拟合函数(数学意义)吗?-程序员宅基地

文章浏览阅读476次。可以的,有多种方法进行任意函数曲线的拟合。但如果你是普朗克,你得先猜出来黑体辐射的公式样子,拟合只能给出系数。——————————————1、第一种是进行多项式拟合,数学上可以证明,任意函数都可以表示为多项式形式。具体示例如下:###拟合年龄import numpy as npimport matplotlib.pyplot as plt#定义x、y散点坐标x = [10,20,30,40,50,..._python周期性函数的拟合

推荐文章

热门文章

相关标签