php使用zeromq
admin
2023-06-12 06:02:03
0

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

/*

 * * Hello World server

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

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

 * * @author Ian Barber

 * */


$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

/*

 * * Hello World client

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

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

 * * @author Ian Barber

 * */


$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


相关内容

热门资讯

国家两部门:开展矿山机器人应用... 国家矿山安全监察局综合司 工业和信息化部办公厅关于开展矿山机器人应用验证试点工作的通知 国家矿山安全...
打造“终身学习之城”,杭州积极... 潮新闻客户端 记者 徐婷 俞刘东 通讯员 许慧敏 人工智能时代日新月异,培养适应时代生存发展的人才,...
荣耀平板20问世 内置1010... 【CNMO科技消息】5月25日晚间,CNMO科技注意到,荣耀平板20已正式发布,新品首销价1899元...
华为芯片破局!五年干到1.4n... 说起何庭波这个名字,想必各位IT之家家友是既熟悉又陌生。 熟悉在于她坐拥华为公司董事、半导体业务部总...
美加州故障化学品储罐爆炸风险排... 新华社洛杉矶5月25日电(记者高山 谭晶晶)美国加利福尼亚州奥兰治县官员25日说,当地此前发生泄漏的...
雷军:小米汽车电池安全测试项目... 来源:环球网 【环球网科技综合报道】5月25日消息,小米创办人、董事长兼 CEO 雷军发布了小米汽...
2026续航“顶级”的全能旗舰... 要说近两年手机行业感知最强的技术进步,电池肯定算一个,毕竟今年连影像旗舰和小屏机都能把电池堆到700...
在德国失联的23岁中国留学生,... 近日,有网友发帖称,一名23岁中国男留学生在德国失联数日,其家属正在紧急寻人,引发关注。据极目新闻报...
美光HBM4增产进展顺利,HB... IT之家 5 月 25 日消息,据韩媒 The Elec 今日报道,美光科技第六代高带宽内存 HBM...
AIROBO正式发布“冲刺全球... 全球机器人产业,正在经历一次比“智能手机时代”更深层的产业迁移。 过去十年,机器人行业的竞争核心始终...