panhaibo/xz-rabbitmq-bundle

集成了php-amqplib与Symfony及RabbitMq。之前为oldsound/rabbitmq-bundle。

安装次数: 8,473

依赖者: 0

建议者: 0

安全性: 0

星标: 3

关注者: 0

分支: 2

公开问题: 0

类型:symfony-bundle

v3.2 2019-06-05 07:40 UTC

This package is auto-updated.

Last update: 2024-09-05 18:49:31 UTC


README

本程序基于开源 https://github.com/php-amqplib/RabbitMqBundle 进行二次开发,增加了监控程序和部分优化以及个性化定制

安装程序包

composer require panghaibo/xz-rabbitmq-bundle dev-master

配置文件可以参考 php-amqplib/RabbitMqBundle

配置文件中增加 xiao_zhu_rabbit_xz 节点

xiao_zhu_rabbit_xz:
    connections:
        default:
            cluster: 
                0: '10.0.2.114:5672,10.0.2.114:5672' #第一个集群 一般一个集群由三台机器组成,连接的时候会随机选择可以使用的节点
                1: '10.0.2.114:5672,10.0.2.114:5672' 
            user:     'panghaibo'  #用户名 由运维给出
            password: '123456'  #密码 由运维给出
            vhost:    'lodgeUnitOrder' #虚拟host 由运维给出
            lazy:     false
            connection_timeout: 60
            read_write_timeout: 10
            keepalive: false
            heartbeat: 5
            use_socket: true
    producers:
        queue_haibo_test:   #一般用队列key
            connection:       default
            exchange_options: {name: 'queue_haibo_test', type: topic}
            enable_logger: true
    consumers:
        queue_haibo_test: #一般用队列key 监控的时候基于这个key
            connection:       default
            exchange_options: {name: 'queue_haibo_test', type: topic}
            callback:         App\Acme\TestBundle\Consumer\QueueHaiboConsumer
            queue_options:    {name: 'haibo_test'}
            qos_options:      {prefetch_size: 0, prefetch_count: 1, global: false}
            enable_logger: true

监控程序的启动

由于PHP的常驻进程在某些条件下会退出执行,我们确保监控进程一直存在,因此我们使用crontab启动监控进程:如下示例:

*/1 * * * * /usr/bin/php /data1/www/my-project/bin/console rabbitmq:monitor /usr/bin/php /tmp/queue 127.0.0.1 newapp 1314 >/dev/null 2>&1

  • /data1/www/my-project/bin/console: 代表symfony bin/console目录
  • rabbitmq:monitor: 监控程序
  • /usr/bin/php 当前机器使用的PHP版本bin路径
  • /tmp/queue 队列的工作目录,该目录必须存在且可读可写
  • 127.0.0.1 代表本机的IP,监控进程会向监控中心注册本监控
  • newapp 代表公司项目的名称,按照业务分且唯一
  • 1314 代表监控监听的端口

启动队列

telnet 127.0.0.1 1314
Connected to 127.0.0.1.
Escape character is '^]'.
ADD queue_haibo_test 3   #代表需要在本机器启动队列key `queue_haibo_test` 3个消费进程 0代表不启动消费进程
OK success
REBOOT queue_haibo_test  #代表重启本机器的queue_haibo_test 队列
OK success
STAT    #查看当前机器有多少任务 以及监控进程本身的一些信息
STAT queue_haibo_test 代表查看 queue_haibo_test 消费着的具体信息 以及向监控进程心跳的时间 每隔120s 会向监控中心心跳消费者信息
QUIT #退出