php zmq 扩展,PHP的ZMQ扩展zeromq源码安装

具体安装步骤

下载以及安装zmq

我下载的是4.12版本

3c9b09d17302239a9d8e77c0722c6717.png

解压后,安装三部曲./configure --prefix=/usr/local/zmq4.2.1

make

make install

绑定php

参考:http://zeromq.org/bindings:php 我采用的是通过Building from Github来进行绑定。 首先下载 Git clone git://github.com/mkoppanen/PHP-zmq.git 其次,进入php-zmq目录,还是执行三部曲phpize

./configure --with-php-config=/usr/local/php/bin/php-config

make

make install

搞定以后,会在php/extensions/no-debug-non-zts-20160303/目录下生产zmq.so文件

06dd2eb8be660d574235a8b54c1cc7eb.png

接下来需要做的是在php.ini配置文件中添加extension=zmq.so

备注: 查照PHP手册上面说的,version is 5.4.x,需要在php.d目录下,创建zmq.ini配置文件

e900b2f4e59afa78a6e6002a9ea0552c.png

要看清楚自己的版本,我目前使用的是7.1.8,所以不需要这么做。

重启php-fpm

service php-fpm restart 当然这个前提是,你得将php-fpm服务注册到系统中,若没有注册,就需要执行php-fpm进程干掉,然后重新启动。

遇到的问题

问题1

遇到zmq被重复加载,入下图:

30214323901c90b48075f12379da0a16.png是在php.ini配置文件中,引入了zmq.so扩展,然后在php.d目录下,又添加了zmq配置,于是随便干掉一个就okey了。而手册上面说,仅仅是5.4.x版本需要这么搞。

问题2

在安装php-zmq的时候,执行./configure,报错:“checking libzmq installation... configure: error: Unable to find libzmq installation”,说找不到libzmq ,也就是找不到我上面安装的zeromq。

519952ccfb25a51e14c5ed522e530e41.png

因为我安装在/usr/local/zmq4.2.1目录,他不可能会遍历文件去查找。所以我们可以通过./configure --help查看如何制定zeromq安装目录。

7809efe26d43e0c15d4147d6e56e406e.png

于是重新编译./configure  --with-zmq=/usr/local/zeromq4.2.1 --with-php-config=/usr/local/php/bin/php-config

最后安装ok

eb9278f3f5b408fedf467a162f6cb14b.png

最后效果

打印phpinfo(),查看效果如:

4fceb0cadb6019e29adb3f2a62d49485.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ZMQZeroMQ)是一个高性能、异步通信库,提供了多种语言的接口,其中就包括C++。下面是使用C++语言实现的ZMQ源码示例: ``` #include <zmq.hpp> #include <string> #include <iostream> int main() { // 创建一个 zmq::context_t 对象 zmq::context_t context(1); // 创建一个 zmq::socket_t 对象,类型为 ZMQ_REP zmq::socket_t socket(context, ZMQ_REP); // 绑定 socket 到本地地址 tcp://*:5555 socket.bind("tcp://*:5555"); while (true) { zmq::message_t request; // 接收请求消息 socket.recv(&request); // 打印请求消息内容 std::cout << "Received request: " << std::string(static_cast<char*>(request.data()), request.size()) << std::endl; // 创建回复消息 zmq::message_t reply(5); memcpy(reply.data(), "World", 5); // 发送回复消息 socket.send(reply); } return 0; } ``` 上述代码中,使用 `zmq.hpp` 头文件中的类库完成了对ZMQ的封装。在程序中,首先创建了一个 `zmq::context_t` 对象,用于管理和维护ZMQ的内部状态。然后创建了一个 `zmq::socket_t` 对象,用于与其他ZMQ节点进行通信。该对象的类型为 `ZMQ_REP`,表示它是回复请求的一端。接着,将该对象绑定到本地地址 `tcp://*:5555` 上,监听来自其他节点的连接请求。接下来,使用 `while` 循环不断地接收来自其他节点的请求消息,并回复相应的回复消息。 需要注意的是,在实际的应用中,需要对ZMQ进行更加详细和深入的了解,以便能够更好地利用它提供的功能,实现高效的通信。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值