对rabbitmq进行压测

添加rabbitmq依赖

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-amqp</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework.amqp</groupId>
            <artifactId>spring-rabbit-test</artifactId>
            <scope>test</scope>
        </dependency>

配置文件中加入rabbitmq配置

server:
  port: 18072
spring:
  rabbitmq:
    host: 127.0.0.1
    port: 5672
    username: guest
    password: guest

在启动类上添加注解

@EnableRabbit
@SpringBootApplication
public class RabbitMqBootApplication {

    public static void main(String[] args) {
        SpringApplication.run(RabbitMqBootApplication.class, args);
    }

}

创建Rabbit配置类

@Configuration
public class RabbitConfig {
    //定义队列
    public static final String SIMPLE_QUEUE_NAME = "mqTest1";

    @Bean
    public Queue simpleQueue() {
        /**
         durable(): 是否持久化,当mq 重启之后还在
         exclusive(): 是否独占:只能有一个消费者监听这个队列,当Connection 关闭时,是否删除队列
         autoDelete(): 是否自动删除,当没有Consumer 监听时,自动删除
         withArgument(): 参数
         */
        return QueueBuilder.durable(SIMPLE_QUEUE_NAME).build();
    }
}

 创建消费者

@Service
@Slf4j
public class RabbitMqConsumer {

    @RabbitListener(queues = "mqTest1")
    public void receive(@Payload String message){
        log.info("收到了mqTest1队列消息:" + message);
    }
}

创建生产者

@Slf4j
@RestController
@RequestMapping("/mq")
public class ProducerController {

    @Autowired
    private RabbitTemplate rabbitTemplate;

    @RequestMapping("/send")
    public String send(String message){
        rabbitTemplate.convertAndSend(RabbitConfig.SIMPLE_QUEUE_NAME,message);
        return "发送 " + message + " 到" + RabbitConfig.SIMPLE_QUEUE_NAME;
    }

    
}

压测

使用for循环创建20个线程,每个线程向队列中插入一百万条数据

@RequestMapping("/strongSend")
    public String strongSend(){
        for (int i = 0; i < 20; i++) {
            new Thread(() -> {
                for (int i1 = 0; i1 < 1000000; i1++) {
                    rabbitTemplate.convertAndSend(RabbitConfig.SIMPLE_QUEUE_NAME,
                            Thread.currentThread().getName());
                }
            }).start();
        }
        return "压测完成";
    }

启动项目进行压测(记得把消费者关掉,或者消费者另启一个项目)

调用压测接口

进入rabbitmq管理页面查看

 

已经写入了96万数据,写入速度约每秒1.5万条,后面启动消费者进行消费即可 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
RabbitMQ是一个开源的企业级消息队列系统,它具有高度可扩展性和可靠性。在进行RabbitMQ性能压测时,我们可以采取以下几个方面的方法来评估其性能: 1. 高并发测试:通过发送大量的消息并进行高并发的消费操作来测试RabbitMQ的并发性能。可以模拟多个客户端同时发送消息,然后观察RabbitMQ在高并发情况下的处理能力和消息吞吐量。 2. 延迟测试:通过发送一条消息并进行消费的时间来评估RabbitMQ的消息延迟性能。可以通过记录消息发送的时间和消费的时间间隔来计算延迟时间,并观察消息延迟在不同负载下的表现。 3. 持久化消息测试:测试RabbitMQ在持久化消息的情况下的性能表现。可以将消息设置为持久化,然后发送大量的消息并进行消费操作,观察消息的持久化能力和系统的稳定性。 4. 高可靠性测试:测试RabbitMQ在节点故障或网络断开的情况下的可靠性表现。可以模拟节点宕机或网络中断的情况,观察RabbitMQ在故障恢复后是否能够正确处理消息并保持系统的可用性。 在进行性能压测时,需要注意以下几个方面: 1. 测试环境的准备:需要构建一个具有一定规模的测试环境,包括多个生产者、消费者和消息队列节点,以模拟真实的生产环境。 2. 压测工具的选择:可以使用一些专业的压测工具,如Apache JMeter等,来模拟高并发的消息发送和消费操作。 3. 参数的调优:可以尝试调整RabbitMQ的参数,如连接池大小、线程池大小等,以获得更好的性能表现。 4. 结果的分析:在进行性能压测后,需要对测试结果进行分析和比较,以评估系统的性能和稳定性,并找出可能存在的性能瓶颈和优化点。 通过以上的测试和分析,可以对RabbitMQ性能进行全面的评估,并根据实际需求来合理调整配置和优化系统,以提升其性能和可靠性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值