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 | 评论(104) | 引用(0) | 阅读(262100)
keyganker
2013-12-19 08:34
我能说些什么呢?!php越来越强大了!楼主文章都是精髓,就是好少啊
无线网 Email Homepage
2013-12-19 13:58
很详细~~~赞个
lovelover Email Homepage
2013-12-20 13:11
张哥是个好人
ddd Email
2013-12-21 17:10
博主杂不贴出结果呢??

再说,如果能有一个简单的案例会更好些。
lawyer Homepage
2013-12-23 13:28
首页了吗?
Goloy Homepage
2013-12-23 19:25
zan 赞一个 嘛时候安装一个来看看 看看是不是真的多线程
磨途歌 Homepage
2013-12-24 15:29
感谢分享,一直在寻找PHP实现多线程的解决方案,有空试试
灵气 Homepage
2013-12-26 21:51
curl 本身支持并发的,性能不一定比这个差。
kairi
2013-12-27 17:50
这个内存开销大吗?
佩服
2013-12-29 15:17
张兄,你好!浏览了下你部分历史文章,太崇拜你了!虽然我也是IT业的,只比你小一岁,但和你比起来差距太大了。我很想知道像你这样的技术大牛到底是如何成长起来的?能否专门出个文章分享下你的成长经历和学习心得。这个真会更其他愿意进步的人很大帮助!
biby
2013-12-29 15:59
博主,请教一个问题!在这个例子中,需要等待数据下载完了一并返回是吗?如果我需要在每个线程里面数据一下载完就开始处理,比如把需要的数据插入数据库,请问应该处理?不知道我有没有理解错误,请问是在run 方法里面继续处理吗?我试了,好像不行,在run里面调用 $this->join();好像不行,要是有空,请给个简单的例子哈!
biby
2013-12-29 16:04
不知道join是啥子意思哈,英文不怎么好,如果要处理数据,是不是在获取完数据后就可以马上处理了啊?
seo博客 Homepage
2013-12-31 16:52
大师级就是不一样!
9.9 Email Homepage
2014-1-1 15:19
楼主辛苦,新年快乐
yation
2014-1-2 14:18
关于BigSea, 大师可否介绍一番?
david_bj
2014-1-3 11:33
学习
大json Homepage
2014-1-5 16:56
其实不错
在哪些环境上能用到?
neo
2014-1-7 10:06
--enable-maintainer-zts Enable thread safety - for code maintainers only!!
neo
2014-1-7 10:06
--enable-maintainer-zts Enable thread safety - for code maintainers only!!
享受痛苦
2014-1-7 13:13
刚开始学php就是用的老大的apmserv的集成环境学习php的,转眼过去三年了,老大都创业了,zan
分页: 2/6 第一页 上页 1 2 3 4 5 6 下页 最后页
发表评论
表情
emotemotemotemotemot
emotemotemotemotemot
emotemotemotemotemot
emotemotemotemotemot
emotemotemotemotemot
打开HTML
打开UBB
打开表情
隐藏
记住我
昵称   密码   游客无需密码
网址   电邮   [注册]