PHP 真正多线程的使用

| |
[不指定 2013-12-17 11:17 | by 张宴 ]
  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"


  2、给出一段PHP多线程、与For循环,抓取百度搜索页面的PHP代码示例:





技术大类 » PHP/JS/Shell | 评论(295) | 引用(0) | 阅读(435000)
武林萌主
2014-5-21 16:58
请教下师兄:--with-mysql=/Data/apps/mysql --with-mysqli=/Data/apps/mysql/bin/mysql_config 为什么这里不用mysqlnd驱动,仅仅是--with-pdo-mysql 用了。这里是有什么讲究的地方么?
合页 Email Homepage
2014-5-25 16:01
文章写的很好加油
timemet Email Homepage
2014-5-28 09:56
多线程是个好东西,应该能大大加强PHP的能力。但是如果能支持到事件机制就会使得能力进一步强大了。
soccer Homepage
2014-6-1 13:54
博客现在都不更新了为嘛?
屌丝智慧 Email Homepage
2014-6-5 17:00
路过学习了 屌丝智慧 http://www.diaosiiq.com
Nic
2014-7-14 18:49
宴哥,可以转载吗?
yearnfar
2014-7-23 13:21
当创建新的线程上下文(Thread 或 Worker 对象)的时候,仅有简单类型的静态成员会被复制到上下文中,而资源类型或者对象类型的静态成员不会被复制。。。
厦门商标 Homepage
2014-8-3 15:16
这个没试过不太懂的
dreamcastzh
2014-8-16 09:51
引用:
yearnfar 2014-7-23 13:21
当创建新的线程上下文(Thread 或 Worker 对象)的时候,仅有简单类型的静态成员会被复制到上下文中,而资源类型或者对象类型的静态成员不会被复制。。。

我也发现有这个情况,run里面如果引用一个单例类的静态变量,是引用不到的,谁知道是什么原因呢?
厦门商标申请 Homepage
2014-8-17 16:18
php功能还是很强大的
谭技安 Email
2014-8-17 23:42
张老师,php 有没有像node样的 非阻塞啊?
厦门品讯科技微信营销 Email Homepage
2014-8-20 17:04
学习了
tan技安
2014-8-21 10:58
张老师,试了一下,多数情况,for 要比thread 要快...... 奇怪
dreamcastzh
2014-8-24 21:54
github上Pthread还有一些很严重的未解决的bug,暂时不建议使用在生产环境中
北京破小孩
2014-9-12 18:29
膜拜啊envyenvy
cc Homepage
2014-9-22 21:23
PHP用户量好大的说。
gump
2014-9-29 17:33
while($thread_array[$thread_array_key]->isRunning())   为什么 不直接用$thread_array_value 弱问一下 question
hughen Email Homepage
2014-11-30 21:42
看见师兄的教程格外的开心grin套套近乎,嘻嘻
橙子
2014-12-10 11:34
请问大神!!  为什么我申明的全局变量不能在run方法里面就是null了呢???
分页: 4/15 第一页 上页 1 2 3 4 5 6 7 8 9 10 下页 最后页
发表评论
表情
emotemotemotemotemot
emotemotemotemotemot
emotemotemotemotemot
emotemotemotemotemot
emotemotemotemotemot
打开HTML
打开UBB
打开表情
隐藏
记住我
昵称   密码   游客无需密码
网址   电邮   [注册]