docker安装rabbitmq并配置hyperf使用

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

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

安装RabbitMQ:

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

    docker pull rabbitmq:management
    
    AI 代码解读

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

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

    docker run -d --name rabbitmq -p 5672:5672 -p 15672:15672 rabbitmq:management
    
    AI 代码解读

    这条命令会将容器的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 # 设置用户的角色
    
    AI 代码解读

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

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

配置Hyperf使用RabbitMQ:

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

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

    AMQP_HOST=localhost
    AMQP_PORT=5672
    AMQP_USER=myuser
    AMQP_PASS=mypassword
    AMQP_VHOST=/
    
    AI 代码解读
  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', '/'),
            // 其他配置...
        ],
    ];
    
    AI 代码解读
  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
目录
打赏
0
3
3
0
419
分享
相关文章
阿里云服务器一键安装Docker社区版教程,基于系统运维管理OOS
阿里云服务器一键安装Docker社区版教程,基于系统运维管理OOS自动化部署。支持Ubuntu 22.04/20.04、CentOS 7.7-7.9及Alibaba Cloud Linux 3.2104 LTS。前提条件:ECS实例需运行中且有公网。步骤:选择Docker扩展并安装,验证成功通过命令`docker -v`查看版本号。
111 78
《docker高级篇(大厂进阶):1.Docker复杂安装详说》包括:安装mysql主从复制、安装redis集群
《docker高级篇(大厂进阶):1.Docker复杂安装详说》包括:安装mysql主从复制、安装redis集群
44 14
《docker基础篇:8.Docker常规安装简介》包括:docker常规安装总体步骤、安装tomcat、安装mysql、安装redis
《docker基础篇:8.Docker常规安装简介》包括:docker常规安装总体步骤、安装tomcat、安装mysql、安装redis
27 7
docker高级篇(大厂进阶):安装mysql主从复制
docker高级篇(大厂进阶):安装mysql主从复制
93 24
|
19天前
|
docker高级篇(大厂进阶):安装redis集群
docker高级篇(大厂进阶):安装redis集群
81 24
|
18天前
|
Ubuntu22.04上Docker的安装
通过以上详细的安装步骤和命令,您可以在Ubuntu 22.04系统上顺利安装
248 11
百度搜索:蓝易云【docker通过dockerfile安装sftp教程。】
现在,你已经通过 Dockerfile 成功安装了 SFTP,并且可以使用指定的用户名和公钥进行远程访问。请确保替换示例中的用户名、密码和公钥为自己的实际值。
185 1
百度搜索:蓝易云 ,常用环境部署—Docker安装RocketMQ教程!
通过按照上述步骤,您可以在Docker中成功安装和部署RocketMQ。请注意,上述命令仅提供了一个基本的安装和配置过程,具体配置和使用可以根据您的需求进行进一步调整。确保在执行命令之前,您已经安装并配置好Docker环境。
189 0
【最新版正确姿势】Docker安装教程(简单几步即可完成)
之前的老版本Docker安装教程已经发生了变化,本文分享了Docker最新版安装教程,其他操作系统版本也可以参考官 方的其他安装版本文档。
1934 3
【最新版正确姿势】Docker安装教程(简单几步即可完成)
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等