继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

php使用zeromq

慕田峪0738999
关注TA
已关注
手记 344
粉丝 88
获赞 494

Zeromq是个啥玩意?

Connect your code in any language, on any platform.
Carries messages across inproc, IPC, TCP, TPIC, multicast.
Smart patterns like pub-sub, push-pull, and router-dealer.
High-speed asynchronous I/O engines, in a tiny library.
Backed by a large and active open source community.
Supports every modern language and platform.
Build any architecture: centralized, distributed, small, or large.
Free software with full commercial support


以上是官方页面的介绍,大意是说一种跨平台,可以使用任何语言使用的消息中间件,可以通过inproc,IPC,TCP,TPIC,多播的消息传递消息,包括多种模式,pub-sub(分发-订阅),push-pull(推送模式),router-dealer(路由模式)等等等等。极高的处理速度是其重要的特性之一。

官方详细介绍请访问:http://zeromq.org/


安装:

#wget http://download.zeromq.org/zeromq-4.0.4.tar.gz

#tar zxvf zeromq-4.0.4.tar.gz

#cd zeromq-4.0.4

#./configure=/usr/local/zeromq404

#make

#make install


安装PHP扩展:

#git clone git://github.com/mkoppanen/php-zmq.git

#cd php-zmq

#/usr/local/php/bin/phpize         //自己PHP的安装目录,根据需要更改

#./configure --with-php-config=/usr/local/php/bin/php-config --with-zmq=/usr/local/zeromq404    //php-config需要根据自己的情况进行更改

#make

#make install


安装好之后会在/usr/local/php/lib/php/extensions/no-debug-zts-20090626/目录下面生成zmq.so


修改配置文件:

#vim /etc/php.ini

修改extension_dir="/usr/local/php/lib/php/extensions/no-debug-zts-20090626/"

增加extension=zmq.so


重启apache

访问phpinfo,如果看到zmq的相关信息表明已经OK了


测试:

系统分两部分:client和server端

server端一般由phpcli来执行,常驻后台,监听一个端口,此例中使用5555,代码如下:


zmqserver.php

<?php

/*

 * * Hello World server

 * * Binds REP socket to tcp://*:5555

 * * Expects "Hello" from client, replies with "World"

 * * @author Ian Barber <ian(dot)barber(at)gmail(dot)com>

 * */


$context = new ZMQContext(1);


// Socket to talk to clients

$responder = new ZMQSocket($context, ZMQ::SOCKET_REP);

$responder->bind("tcp://*:5555");


while (true) {

    $request = $responder->recv();

    printf ("Received request: [%s]\n", $request);


    logtxt($request);


    usleep (100);

    $responder->send("World");

}


function logtxt($msg){

    $handler = fopen("/tmp/log/zmq.log","a+");

    fwrite($handler,date('Y-m-d H:i:s').'    '.$msg."\r\n");

    fclose($handler);

}



当我执行

#php zmqserver.php

的时候,报错,找不到"ZMQContext"的类


使用

#php -m

查看加载的类,发现木有,只有一些默认的


继续使用

#php --ini

发现加载INI的路径并不是/etc/php.ini


于是cp /etc/php.ini /usr/local/php/lib/php.ini

再次执行

#php zmqserver.php

ok


查看一下5555端口是否被监听:

#lsof -i:5555

在我的机器上出现了

COMMAND   PID USER   FD   TYPE DEVICE SIZE/OFF NODE NAME

php     35145 root    9u  IPv4 272314      0t0  TCP *:personal-agent (LISTEN)


表明监听成功.



下面编写client端


zmqclient.php

<?php

/*

 * * Hello World client

 * * Connects REQ socket to tcp://localhost:5555

 * * Sends "Hello" to server, expects "World" back

 * * @author Ian Barber <ian(dot)barber(at)gmail(dot)com>

 * */


$context = new ZMQContext();


// Socket to talk to server

echo "Connecting to hello world server…\n";

$requester = new ZMQSocket($context, ZMQ::SOCKET_REQ);

$requester->connect("tcp://localhost:5555");

$date = mktime();



if($requester->send($date) !== false){

    echo "send success\n";

}

$reply = $requester->recv();

printf ("Received:[%s]\n",$reply);



从浏览器访问zmqclient.php

可以正确接收到World的数据,同时在/tmp/log/zmq.log下面有新生成的日志文件

表明一切正常。


PS:

此例中使用了简单的:rep/req的请求应答模式,其实zmq支持的模式非常多,使用的场景也不尽相同,可以根据自己的实际情况灵活的选择合适的模式。


一些有用的资源:

官网:http://zeromq.org/

http://blog.fity.cn/post/382/

http://iyuan.iteye.com/category/148998


打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP