【AMQP】macOS下的AMQP服务器以及PHP扩展搭建

来源:互联网 发布:java socket 发送文件 编辑:程序博客网 时间:2024/06/06 03:21

环境说明

  • macOS版本, macOS Sierra 10.12.3 (16D32)
  • PHP集成环境, XAMPP 7.0.15-0
  • Apache 2.4.25,
  • MariaDB 10.1.21
  • PHP 7.0.15

前期准备

修改本地path文件

sudo vi /etc/paths

在文件的最上面添加/Applications/XAMPP/xamppfiles/bin

重启中端

bogon:~ xiaoyu$ php -vPHP 7.0.15 (cli) (built: Jan 20 2017 07:22:25) ( NTS )Copyright (c) 1997-2017 The PHP GroupZend Engine v3.0.0, Copyright (c) 1998-2017 Zend Technologies

安装RabbitMQ扩展

wget http://www.rabbitmq.com/releases/rabbitmq-server/v3.6.6/rabbitmq-server-mac-standalone-3.6.6.tar.xztar -xf rabbitmq-server-mac-standalone-3.6.6.tar.xz cd rabbitmq_server-3.6.6/sbin/rabbitmq-server

报错 ERROR: epmd error for host bogon: timeout (timed out)

修改hosts , 增加 127.0.0.1 bogon

继续

bogon:rabbitmq_server-3.6.6 xiaoyu$ sbin/rabbitmq-server              RabbitMQ 3.6.6. Copyright (C) 2007-2016 Pivotal Software, Inc.  ##  ##      Licensed under the MPL.  See http://www.rabbitmq.com/  ##  ##  ##########  Logs: /Applications/XAMPP/rabbitmq_server-3.6.6/var/log/rabbitmq/rabbit@bogon.log  ######  ##        /Applications/XAMPP/rabbitmq_server-3.6.6/var/log/rabbitmq/rabbit@bogon-sasl.log  ##########              Starting broker... completed with 0 plugins.

添加到本地PATH

sudo vi /etc/paths

添加所在sbin路径/Applications/XAMPP/rabbitmq_server-3.6.6/sbin

重启终端

再次启动服务

rabbitmq-server

安装 RabbitMQ management UI

这个图形化界面是一个插件

bogon:~ xiaoyu$ rabbitmq-plugins enable rabbitmq_managementThe following plugins have been enabled:  mochiweb  webmachine  rabbitmq_web_dispatch  amqp_client  rabbitmq_management_agent  rabbitmq_managementApplying plugin configuration to rabbit@bogon... failed. * Could not contact node rabbit@bogon.   Changes will take effect at broker restart. * Options: --online  - fail if broker cannot be contacted.            --offline - do not try to contact broker.

重启服务后,就会变成completed with 6 plugins.

访问图形化登录界面的地址为http://localhost:15672/

用户管理

# 创建用户rabbitmqctl add_user demo pwd# 赋予超级管理员权限rabbimqctl set_user_tags  demo administrator

之后就可以登录图形化管理界面了

用户标签

在创建用户的之后,需要通过标签的形式给用户赋予对应的权限

administrator | monitoring | policymaker | management |

Comma-separated list of tags to apply to the user. Currently supported by the management plugin:
- management
User can access the management plugin
- policymaker
User can access the management plugin and manage policies and parameters for the vhosts they have access to.
- monitoring
User can access the management plugin and see all connections and channels as well as node-related information.
- administrator
User can do everything monitoring can do, manage users, vhosts and permissions, close other user’s connections, and manage policies and parameters for all vhosts.
Note that you can set any tag here; the links for the above four tags are just for convenience.

安装AMQP扩展

sudo pecl install amqp#失败configure: error: Please reinstall the librabbitmq distribution itself or (re)install librabbitmq development package if it available in your system

安装 rabbitmq-c

git clone git://github.com/alanxz/rabbitmq-c.gitcd rabbitmq-cgit submodule initgit submodule update#报错bogon:rabbitmq-c xiaoyu$  autoreconf -i && ./configure && make && sudo make installCan't exec "aclocal": No such file or directory at /usr/local/Cellar/autoconf/2.69/share/autoconf/Autom4te/FileUtils.pm line 326.autoreconf: failed to run aclocal: No such file or directory

安装 aclocal

`aclocal’ is part of automake package, try to install it first.

所以需要重新安装automake

brew install automake

继续安装rabbitmq-c

autoreconf -i#报错 Makefile.am:6: error: Libtool library used but 'LIBTOOL' is undefinedbrew install libtool
autoreconf -i#报错Can't exec "libtoolize": No such file or directory at /usr/local/share/autoconf/Autom4te/FileUtils.pm line 344, <GEN3> line 4.autoreconf: failed to run libtoolize: No such file or directoryautoreconf: libtoolize is needed because this package uses Libtool#添加PATH /usr/local/Cellar/libtool/2.4.6_1/binbrew install boost double-conversion gflags glog libeventsudo ln -s /usr/local/bin/glibtoolize /usr/local/bin/libtoolize

继续

autoreconf -i./configure && make && sudo make install#报错./librabbitmq/amqp_openssl_bio.h:26:10: fatal error: 'openssl/bio.h' file not found#include <openssl/bio.h>         ^1 error generated.make[1]: *** [librabbitmq/librabbitmq_librabbitmq_la-amqp_openssl.lo] Error 1make: *** [all] Error 2#xcode安装opensslxcode-select --installxcode-select -p #找到xcode的路径找不到 对应文件夹,失败#编译安装opensslgit clone  https://github.com/openssl/openssl.gitcd openssl./configmakemake testmake install ## 编译安装报错Cannot find "ERR_get_error(3)" in podpath: cannot find suitable replacement path, cannot resolve link经过下面验证可以用

继续

./configure && make && sudo make install

继续安装AMQP

sudo pecl install amqp#成功Build process completed successfullyInstalling '/Applications/XAMPP/xamppfiles/lib/php/extensions/no-debug-non-zts-20151012/amqp.so'install ok: channel://pecl.php.net/amqp-1.8.0configuration option "php_ini" is not set to php.ini locationYou should add "extension=amqp.so" to php.ini

修改配置文件

重启服务器

php -m# 扩展安装成功[PHP Modules]**amqp**bcmathbz2calendarCore.....

编写测试代码

创建项目

创建 composer.json文件

{  "require": {      "php-amqplib/php-amqplib": "2.6.*"  }}

在项目所在目录执行composer install

测试demo

配置文件config.php

<?phprequire_once __DIR__ . '/vendor/autoload.php';define('HOST', 'bogon');define('PORT', 5672);define('USER', 'guest');define('PASS', 'guest');define('VHOST', '/');//If this is enabled you can see AMQP output on the CLIdefine('AMQP_DEBUG', true);

demo文件test.php

<?phpinclude(__DIR__ . '/config.php');use PhpAmqpLib\Connection\AMQPStreamConnection;use PhpAmqpLib\Message\AMQPMessage;$exchange = 'basic_get_test';$queue = 'basic_get_queue';$connection = new AMQPStreamConnection(HOST, PORT, USER, PASS, VHOST);$channel = $connection->channel();/*    The following code is the same both in the consumer and the producer.    In this way we are sure we always have a queue to consume from and an        exchange where to publish messages.*//*    name: $queue    passive: false    durable: true // the queue will survive server restarts    exclusive: false // the queue can be accessed in other channels    auto_delete: false //the queue won't be deleted once the channel is closed.*/$channel->queue_declare($queue, false, true, false, false);/*    name: $exchange    type: direct    passive: false    durable: true // the exchange will survive server restarts    auto_delete: false //the exchange won't be deleted once the channel is closed.*/$channel->exchange_declare($exchange, 'direct', false, true, false);$channel->queue_bind($queue, $exchange);$toSend = new AMQPMessage('test message', array('content_type' => 'text/plain', 'delivery_mode' => 2));$channel->basic_publish($toSend, $exchange);$message = $channel->basic_get($queue);$channel->basic_ack($message->delivery_info['delivery_tag']);var_dump($message->body);$channel->close();$connection->close();

命令行运行代码php test.php,得到debug信息,和正确的返回

< [hex]: 0000  41 4D 51 50 00 00 09 01                            AMQP.... waiting for 10,10waiting for a new frame> 10,10: Connection.startStart from server, version: 0.9, properties: capabilities=(publisher_confirms=1, exchange_exchange_bindings=1, basic.nack=1, consumer_cancel_notify=1, connection.blocked=1, consumer_priorities=1, authentication_failure_close=1, per_consumer_qos=1, direct_reply_to=1), cluster_name=rabbit@bogon, copyright=Copyright (C) 2007-2016 Pivotal Software, Inc., information=Licensed under the MPL.  See http://www.rabbitmq.com/, platform=Erlang/OTP, product=RabbitMQ, version=3.6.6, mechanisms: AMQPLAIN, PLAIN, locales: en_US< 10,11:: Connection.start_ok< [hex]: 0000  01 00 00 00 00 01 31 00  0A 00 0B 00 00 00 F3 07   ......1. ......?.0010  70 72 6F 64 75 63 74 53  00 00 00 07 41 4D 51 50   productS ....AMQP0020  4C 69 62 08 70 6C 61 74  66 6F 72 6D 53 00 00 00   Lib.plat formS...0030  03 50 48 50 07 76 65 72  73 69 6F 6E 53 00 00 00   .PHP.ver sionS...0040  03 32 2E 36 0B 69 6E 66  6F 72 6D 61 74 69 6F 6E   .2.6.inf ormation0050  53 00 00 00 00 09 63 6F  70 79 72 69 67 68 74 53   S.....co pyrightS0060  00 00 00 00 0C 63 61 70  61 62 69 6C 69 74 69 65   .....cap abilitie0070  73 46 00 00 00 8C 1C 61  75 74 68 65 6E 74 69 63   sF...?.a uthentic0080  61 74 69 6F 6E 5F 66 61  69 6C 75 72 65 5F 63 6C   ation_fa ilure_cl0090  6F 73 65 74 01 12 70 75  62 6C 69 73 68 65 72 5F   oset..pu blisher_00A0  63 6F 6E 66 69 72 6D 73  74 01 16 63 6F 6E 73 75   confirms t..consu00B0  6D 65 72 5F 63 61 6E 63  65 6C 5F 6E 6F 74 69 66   mer_canc el_notif00C0  79 74 01 1A 65 78 63 68  61 6E 67 65 5F 65 78 63   yt..exch ange_exc00D0  68 61 6E 67 65 5F 62 69  6E 64 69 6E 67 73 74 01   hange_bi ndingst.00E0  0A 62 61 73 69 63 2E 6E  61 63 6B 74 01 12 63 6F   .basic.n ackt..co00F0  6E 6E 65 63 74 69 6F 6E  2E 62 6C 6F 63 6B 65 64   nnection .blocked0100  74 01 08 41 4D 51 50 4C  41 49 4E 00 00 00 23 05   t..AMQPL AIN...#.0110  4C 4F 47 49 4E 53 00 00  00 05 67 75 65 73 74 08   LOGINS.. ..guest.0120  50 41 53 53 57 4F 52 44  53 00 00 00 05 67 75 65   PASSWORD S....gue0130  73 74 05 65 6E 5F 55 53  CE                        st.en_US ?< 10,11:: Connection.start_okwaiting for 10,20, 10,30waiting for a new frame> 10,30: Connection.tune< 10,31:: Connection.tune_ok< [hex]: 0000  01 00 00 00 00 00 0C 00  0A 00 1F FF FF 00 02 00   ........ ...??...0010  00 00 00 CE                                        ...?< 10,31:: Connection.tune_ok< 10,40:: Connection.open< [hex]: 0000  01 00 00 00 00 00 08 00  0A 00 28 01 2F 00 00 CE   ........ ..(./..?< 10,40:: Connection.openwaiting for 10,41waiting for a new frame> 10,41: Connection.open_okOpen OK! known_hosts: using channel_id: 1< 20,10:: Channel.open< [hex]: 0000  01 00 01 00 00 00 05 00  14 00 0A 00 CE            ........ ....?< 20,10:: Channel.openwaiting for 20,11waiting for a new frame> 20,11: Channel.open_okChannel open< 50,10:: Queue.declare< [hex]: 0000  01 00 01 00 00 00 1B 00  32 00 0A 00 00 0F 62 61   ........ 2.....ba0010  73 69 63 5F 67 65 74 5F  71 75 65 75 65 02 00 00   sic_get_ queue...0020  00 00 CE                                           ..?< 50,10:: Queue.declarewaiting for 50,11waiting for a new frame> 50,11: Queue.declare_ok< 40,10:: Exchange.declare< [hex]: 0000  01 00 01 00 00 00 21 00  28 00 0A 00 00 0E 62 61   ......!. (.....ba0010  73 69 63 5F 67 65 74 5F  74 65 73 74 06 64 69 72   sic_get_ test.dir0020  65 63 74 02 00 00 00 00  CE                        ect..... ?< 40,10:: Exchange.declarewaiting for 40,11waiting for a new frame> 40,11: Exchange.declare_ok< 50,20:: Queue.bind< [hex]: 0000  01 00 01 00 00 00 2B 00  32 00 14 00 00 0F 62 61   ......+. 2.....ba0010  73 69 63 5F 67 65 74 5F  71 75 65 75 65 0E 62 61   sic_get_ queue.ba0020  73 69 63 5F 67 65 74 5F  74 65 73 74 00 00 00 00   sic_get_ test....0030  00 00 CE                                           ..?< 50,20:: Queue.bindwaiting for 50,21waiting for a new frame> 50,21: Queue.bind_ok< 60,40:: Basic.publish< [hex]: 0000  01 00 01 00 00 00 17 00  3C 00 28 00 00 0E 62 61   ........ <.(...ba0010  73 69 63 5F 67 65 74 5F  74 65 73 74 00 00 CE 02   sic_get_ test..?.0020  00 01 00 00 00 1A 00 3C  00 00 00 00 00 00 00 00   .......< ........0030  00 0C 90 00 0A 74 65 78  74 2F 70 6C 61 69 6E 02   ..?..tex t/plain.0040  CE 03 00 01 00 00 00 0C  74 65 73 74 20 6D 65 73   ?....... test mes0050  73 61 67 65 CE                                     sage?< 60,70:: Basic.get< [hex]: 0000  01 00 01 00 00 00 17 00  3C 00 46 00 00 0F 62 61   ........ <.F...ba0010  73 69 63 5F 67 65 74 5F  71 75 65 75 65 00 CE      sic_get_ queue.?< 60,70:: Basic.getwaiting for 60,71, 60,72waiting for a new frame> 60,71: Basic.get_okwaiting for a new framewaiting for a new frame< 60,80:: Basic.ack< [hex]: 0000  01 00 01 00 00 00 0D 00  3C 00 50 00 00 00 00 00   ........ <.P.....0010  00 00 01 00 CE                                     ....?< 60,80:: Basic.ackstring(12) "test message"< 20,40:: Channel.close< [hex]: 0000  01 00 01 00 00 00 0B 00  14 00 28 00 00 00 00 00   ........ ..(.....0010  00 00 CE                                           ..?< 20,40:: Channel.closewaiting for 20,41waiting for a new frame> 20,41: Channel.close_ok< 10,50:: Connection.close< [hex]: 0000  01 00 00 00 00 00 0B 00  0A 00 32 00 00 00 00 00   ........ ..2.....0010  00 00 CE                                           ..?< 10,50:: Connection.closewaiting for 10,51waiting for a new frame> 10,51: Connection.close_okclosing inputclosing socket

到此,环境配置完成

总结

本次配置环境涉及到了

  • 不同bash下的环境变量的修改
  • 软件环境的相互依赖关系
  • 编译的报错以及排查
  • 出现问题之后的问题搜索技巧
  • 只要可能出问题就一定出问题的墨菲定律

参考资料

  • http://pecl.php.net/package/amqp
  • http://www.php.net/manual/pl/book.amqp.php
  • http://www.infoq.com/cn/articles/AMQP-RabbitMQ/
  • http://www.th7.cn/system/mac/201409/70274.shtml
  • http://www.rabbitmq.com/download.html
  • http://stackoverflow.com/questions/9520914/installing-amqp-through-pecl
  • https://github.com/alanxz/rabbitmq-c
  • http://www.cnblogs.com/hurricane2011/articles/2503582.html
  • http://blog.csdn.net/sky_qing/article/details/9707647
  • https://github.com/facebook/redex/issues/22
  • https://www.openssl.org/
  • https://github.com/pdezwart/php-amqp
  • https://github.com/php-amqplib/php-amqplib
0 0
原创粉丝点击