docker安装rabbitmq并配置hyperf使用

简介: 通过以上步骤,您可以实现在Docker容器中安装和配置RabbitMQ,并在PHP的Hyperf框架中进行集成和使用。这种方式为开发者提供了快速部署并实现消息队列解决方案的能力,同时维持了环境与生产环境的一致性,从而为开发高效的分布式应用程序提供了便利。

为满足您的高标准需求,我将分步骤为您详细解释如何通过Docker安装RabbitMQ服务器,并展示如何配置PHP的Hyperf框架来使用RabbitMQ。

安装RabbitMQ:

  1. 获取RabbitMQ镜像在终端中运行以下命令来拉取RabbitMQ的官方Docker镜像:

    docker pull rabbitmq:management
    

    这里我们使用带有 management标签的镜像,因为它包含了RabbitMQ管理插件,此插件可以通过Web UI来管理和查看RabbitMQ的状态。

  2. 运行RabbitMQ容器使用以下命令来创建并启动一个RabbitMQ容器实例:

    docker run -d --name rabbitmq -p 5672:5672 -p 15672:15672 rabbitmq:management
    

    这条命令会将容器的5672端口(RabbitMQ服务器端口)和15672端口(Web管理界面端口)映射到宿主机上的相同端口。

  3. 设置RabbitMQ用户为了增强安全性,我们需要设置RabbitMQ的用户名和密码,您可以通过以下命令进入RabbitMQ容器,并使用RabbitMQ的命令行工具来创建新用户、设置密码以及配置相应的权限:

    docker exec -it rabbitmq bash # 进入RabbitMQ容器
    rabbitmqctl add_user myuser mypassword # 添加新用户
    rabbitmqctl set_permissions -p / myuser ".*" ".*" ".*" # 配置用户权限
    rabbitmqctl set_user_tags myuser administrator # 设置用户的角色
    

    这些命令创建了一个名为 myuser的用户,并为其设置了 mypassword密码和管理员权限。

  4. 访问RabbitMQ管理界面
    打开您的浏览器并导航到 http://localhost:15672,您可以使用步骤3中设置的用户名和密码登录到RabbitMQ的管理界面。

配置Hyperf使用RabbitMQ:

  1. 安装Hyperf及其组件假设您已经有一个Hyperf项目,您需要安装 hyperf/amqp扩展来使Hyperf支持AMQP协议,从而可以与RabbitMQ进行交互。

    composer require hyperf/amqp
    
  2. 配置 .env文件在您的Hyperf项目根目录中找到 .env文件,并设置与RabbitMQ容器对应的AMQP连接信息:

    AMQP_HOST=localhost
    AMQP_PORT=5672
    AMQP_USER=myuser
    AMQP_PASS=mypassword
    AMQP_VHOST=/
    
  3. 配置 config/autoload/amqp.php在Hyperf项目的 config/autoload目录下编辑(或创建)amqp.php配置文件,以匹配您的RabbitMQ连接设置:

    <?php
    return [
        'default' => [
            'host' => env('AMQP_HOST', 'localhost'),
            'port' => (int) env('AMQP_PORT', 5672),
            'user' => env('AMQP_USER', 'myuser'),
            'password' => env('AMQP_PASS', 'mypassword'),
            'vhost' => env('AMQP_VHOST', '/'),
            // 其他配置...
        ],
    ];
    
  4. 创建生产者和消费者
    按照Hyperf的官方文档创建消息生产者(Publisher)和消费者(Consumer)类。生产者负责向特定的队列发送消息,而消费者则负责接收消息并进行处理。

验证:

通过您的Hyperf应用来发布一个消息,并检查RabbitMQ管理界面的Queues部分,查看消息是否已成功进入队列。同样地,启动Hyperf消费者服务,你应该能看到消费者从队列中获取并处理消息。

通过以上步骤,您可以实现在Docker容器中安装和配置RabbitMQ,并在PHP的Hyperf框架中进行集成和使用。这种方式为开发者提供了快速部署并实现消息队列解决方案的能力,同时维持了环境与生产环境的一致性,从而为开发高效的分布式应用程序提供了便利。

相关实践学习
消息队列RocketMQ版:基础消息收发功能体验
本实验场景介绍消息队列RocketMQ版的基础消息收发功能,涵盖实例创建、Topic、Group资源创建以及消息收发体验等基础功能模块。
消息队列 MNS 入门课程
1、消息队列MNS简介 本节课介绍消息队列的MNS的基础概念 2、消息队列MNS特性 本节课介绍消息队列的MNS的主要特性 3、MNS的最佳实践及场景应用 本节课介绍消息队列的MNS的最佳实践及场景应用案例 4、手把手系列:消息队列MNS实操讲 本节课介绍消息队列的MNS的实际操作演示 5、动手实验:基于MNS,0基础轻松构建 Web Client 本节课带您一起基于MNS,0基础轻松构建 Web Client
目录
相关文章
|
23天前
|
Prometheus 监控 Cloud Native
Prometheus配置docker采集器
本文介绍了如何使用 Prometheus 监控 Docker 容器,涵盖环境准备、配置文件编写及服务启动等步骤。首先确保安装 Docker 和 Docker Compose,接着通过 `docker-compose.yml` 配置 Prometheus 和示例应用。创建 `prometheus.yml` 指定数据采集目标,最后用 `docker-compose up -d` 启动服务。文章还展示了甘特图和类图,帮助理解服务状态与关系,助力提升系统可靠性和可维护性。
57 11
|
22天前
|
存储 安全 C++
Odoo 安装方式选择:源码安装 vs Docker
Odoo部署常采用源码编译或Docker容器化,但分别面临依赖复杂、版本风险和服务化难题,以及镜像臃肿和扩展受限的问题。Websoft9提出混合方案,融合两者优势:通过智能环境适配、三阶段部署流程(环境预检、混合模式选择、持久化配置)及声明式YAML配置,实现高效、灵活的双模运行时。此方案显著降低依赖冲突解决时间(从83分钟至0),生产环境构建耗时缩短至8分钟,并达100% CVE漏洞修复率,适合ERP定制开发与规模化部署的企业需求。
|
14天前
|
存储 弹性计算 Linux
安装Docker
常见操作系统安装docker步骤
66 15
|
15天前
|
Docker 容器
在openEuler 22.03 LTS上安装Docker CE和Docker Compose
以上就是在openEuler 22.03 LTS上安装Docker CE和Docker Compose的过程。希望这个指南能帮助你顺利完成安装。
82 12
|
16天前
|
Prometheus 监控 Cloud Native
Prometheus+Grafana(docker安装)
本文档详细介绍了如何使用Docker容器快速部署Prometheus监控系统和Grafana数据可视化平台。该方案适用于需要快速搭建监控环境的开发测试场景,具备部署简单、资源占用低、易于维护等特点。
|
1月前
|
Linux 虚拟化 Docker
win11怎么安装docker的必要设置自学软硬件工程师778天
win11怎么安装docker的必要设置自学软硬件工程师778天
win11怎么安装docker的必要设置自学软硬件工程师778天
|
1月前
|
Ubuntu 关系型数据库 MySQL
在Ubuntu系统的Docker上安装MySQL的方法
以上的步骤就是在Ubuntu系统的Docker上安装MySQL的详细方法,希望对你有所帮助!
166 12
|
7月前
|
消息中间件 JSON Java
开发者如何使用轻量消息队列MNS
【10月更文挑战第19天】开发者如何使用轻量消息队列MNS
585 36
|
7月前
|
消息中间件 安全 Java
云消息队列RabbitMQ实践解决方案评测
一文带你详细了解云消息队列RabbitMQ实践的解决方案优与劣
182 29
|
6月前
|
消息中间件 存储 Kafka
MQ 消息队列核心原理,12 条最全面总结!
本文总结了消息队列的12个核心原理,涵盖消息顺序性、ACK机制、持久化及高可用性等内容。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。