阿里云docker安装rabbitmq并代码测试

阿里云docker安装rabbitmq并代码测试

拉取镜像

docker pull docker.io/rabbitmq:3.8-management

镜像列表:

在这里插入图片描述

启动容器:

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

查看容器列表

账号:guest

密码:guest

rabbtimq启动截图:

在这里插入图片描述

访问页面截图:

在这里插入图片描述

新添加一个账户

默认的guest 账户有访问限制,默认只能通过本地网络(如 localhost) 访问,远程网络访问受限,所以在使用时我们一般另外添加用户,例如我们添加一个root用户:

  • 执行docker exec -it rabbitmq /bin/bash进入到rabbitMq容器内部在这里插入图片描述

  • 执行rabbitmqctl add_user root 123456 添加用户,用户名为root,密码为123456在这里插入图片描述

  • 执行abbitmqctl set_permissions -p / root ".*" ".*" ".*" 赋予root用户所有权限在这里插入图片描述

  • 执行rabbitmqctl set_user_tags root administrator赋予root用户administrator角色在这里插入图片描述

  • 执行rabbitmqctl list_users查看所有用户即可看到root用户已经添加成功在这里插入图片描述

新建项目测试

新建cloud-stream-rabbitmq-provider8801项目

修改POM依赖文件

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <parent>
        <artifactId>cloud2020</artifactId>
        <groupId>com.hfwas.springcloud</groupId>
        <version>1.0-SNAPSHOT</version>
    </parent>
    <modelVersion>4.0.0</modelVersion>

    <artifactId>cloud-stream-rabbitmq-provider8801</artifactId>

    <dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-stream-rabbit</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>

        <dependency>
            <groupId>com.hfwas.springcloud</groupId>
            <artifactId>cloud-api-common</artifactId>
            <version>1.0-SNAPSHOT</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-devtools</artifactId>
            <scope>runtime</scope>
            <optional>true</optional>
        </dependency>
    </dependencies>
</project>

修改配置文件

server:
  port: 8801

spring:
  application:
    name: cloud-stream-consumer
  rabbitmq:
    # 使用阿里云服务器,这里要填写阿里云服务器IP地址
    host: 阿里云IP地址
    # 这里一定要填写5672端口,不要写15672端口。否则会报连接被拒接
    port: 5672
    username: root
    password: 123456
  cloud:
    stream:
      binders: # 在此处配置要绑定的rabbitMQ的服务信息
        defaultRabbit: # 表示定义的名称,用于binding的整合
          type: rabbit # 消息中间件类型
      bindings: # 服务的整合处理
        input: # 这个名字是一个通道的名称
          destination: studyExchange # 表示要使用的exchange名称定义
          content-type: application/json # 设置消息类型,本次为json,文本则设为text/plain
#          binder: defaultRabbit # 设置要绑定的消息服务的具体设置
#          group: yangluyaoA # 不同的组存在重复消费,相同的组之间竞争消费。

eureka:
  client:
    service-url:
      defaultZone: http://eureka7001.com:7001/eureka
  instance:
    lease-renewal-interval-in-seconds: 2 # 设置心跳的间隔时间,默认30
    lease-expiration-duration-in-seconds: 5 # 超过5秒间隔,默认90
    instance-id: receive-8802.com #主机名
    prefer-ip-address: true # 显示ip

新建主启动类StreamMQMain8801

package com.hfwas.springcloud;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

/**
 * @Author HFwas
 * @Date 2021/11/27 17:41
 */
@SpringBootApplication
public class StreamMQMain8801 {
    public static void main(String[] args) {
        SpringApplication.run(StreamMQMain8801 .class, args);
    }
}

新建消息接口

package com.hfwas.springcloud.service;

/**
 * @Author HFwas
 * @Date 2021/11/27 17:42
 */
public interface IMessageProvider {

    /**
     * 发送消息
     *
     * @return
     */
    String send();

}

新建实现类

package com.hfwas.springcloud.service.impl;

import com.hfwas.springcloud.service.IMessageProvider;
import org.springframework.cloud.stream.annotation.EnableBinding;
import org.springframework.cloud.stream.messaging.Source;
import org.springframework.messaging.MessageChannel;
import org.springframework.messaging.support.MessageBuilder;

import javax.annotation.Resource;
import java.util.UUID;

/**
 * @Author HFwas
 * @Date 2021/11/27 17:43
 */
// 定义消息的推送管道
@EnableBinding(Source.class)
public class MessageProviderImpl implements IMessageProvider {

    // 消息的发送管道
    @Resource
    private MessageChannel output;

    @Override
    public String send() {
        String uuid = UUID.randomUUID().toString();
        output.send(MessageBuilder.withPayload(uuid).build());
        System.out.println("uuid : {}" + uuid);
        return null;
    }
}

新建controller层

package com.hfwas.springcloud.controller;

import com.hfwas.springcloud.service.IMessageProvider;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

/**
 * @Author HFwas
 * @Date 2021/11/27 19:47
 */
@RestController
public class SendMessageController {

    @Autowired
    private IMessageProvider iMessageProvider;

    @GetMapping(value = "/senMessage")
    public String sendMessage() {
        return iMessageProvider.send();
    }

}

rabbitma网页端查看

  • output已经注册上来了

在这里插入图片描述

postman测试

  • postman测试接口
http://localhost:8801/senMessage
  • postman测试截图

在这里插入图片描述

IDEA查看控制台输出

在这里插入图片描述

rabbitmq查看

多请求几次接口信息

然后查看rabbitmq,
在这里插入图片描述

注意事项:

  • 报连接超时的错误

使用一下配置文件报连接超时的错误:

server:
  port: 8801

spring:
  application:
    name: cloud-stream-consumer
  cloud:
    stream:
      binders: # 在此处配置要绑定的rabbitMQ的服务信息
        defaultRabbit: # 表示定义的名称,用于binding的整合
          type: rabbit # 消息中间件类型
          environment: # 设置rabbitMQ的相关环境配置
            spring:
              rabbitmq:
                host: 阿里云IP地址
                port: 15672
                username: guest
                password: guest
      bindings: # 服务的整合处理
        input: # 这个名字是一个通道的名称
          destination: studyExchange # 表示要使用的exchange名称定义
          content-type: application/json # 设置消息类型,本次为json,文本则设为text/plain
          binder: defaultRabbit # 设置要绑定的消息服务的具体设置
          group: yangluyaoA # 不同的组存在重复消费,相同的组之间竞争消费。

eureka:
  client:
    service-url:
      defaultZone: http://eureka7001.com:7001/eureka
  instance:
    lease-renewal-interval-in-seconds: 2 # 设置心跳的间隔时间,默认30
    lease-expiration-duration-in-seconds: 5 # 超过5秒间隔,默认90
    instance-id: receive-8802.com #主机名
    prefer-ip-address: true # 显示ip

我这里使用的是阿里云服务器,使用docker安装的rabbitmq,需要将rabbitmq的配置信息移动到application.yml中的spring节点下,否则会报连接超时

  • 连接被拒绝
  rabbitmq:
    # 使用阿里云服务器,这里要填写阿里云服务器IP地址
    host: 101.200.178.253
    # 这里一定要填写5672端口,不要写15672端口。否则会报连接被拒接
    port: 15672
    username: root
    password: 123456

-8802.com #主机名
prefer-ip-address: true # 显示ip


我这里使用的是阿里云服务器,使用docker安装的rabbitmq,需要将rabbitmq的配置信息移动到application.yml中的spring节点下,否则会报连接超时

- 连接被拒绝

```yaml
  rabbitmq:
    # 使用阿里云服务器,这里要填写阿里云服务器IP地址
    host: 101.200.178.253
    # 这里一定要填写5672端口,不要写15672端口。否则会报连接被拒接
    port: 15672
    username: root
    password: 123456

注意这里使用的是15672接口,阿里云安全组也开放了15672的端口,使用telenet测试端口也通,但是会报连接被拒绝的错误,这里要将端口修改为5672端口,阿里云的安全组记得要开放5672的端口。就可以访问了。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值