springboot整合其他中间件

本文详细介绍了如何将SpringBoot与多种中间件整合,包括MongoDB主从集群的配置,RabbitMQ的连接与消息处理,以及Redis的集成与使用。通过具体的步骤和配置示例,展示了SpringBoot在分布式系统中的应用。
摘要由CSDN通过智能技术生成

1、springboot整合mongodb(主从集群模式整合)

(1)导入jar包: spring-boot-starter-data-mongodb

(2)进行配置:

spring:
  data:
    mongodb:
      uri: mongodb://192.168.71.132:27018,192.168.71.133:27018/springboot_test?slaveOk=true&replicaSet=test&write=1&readPreference=secondaryPreferred&connectTimeoutMS=300000
      #每个主机的连接数
      connections-per-host: 50
      #线程队列数,它以上面connectionsPerHost值相乘的结果就是线程队列最大值
      threads-allowed-to-block-for-connection-multiplier: 50
      connect-timeout: 5000
      socket-timeout: 3000
      max-wait-time: 1500
      #控制是否在一个连接时,系统会自动重试
      auto-connect-retry: true
      socket-keep-alive: true

(3)注入接口
@Autowired
MongoTemplate mongoTemplate;

2、springboot整合rabbitmq

(1)导入jar包: spring-boot-starter-amqp

(2)进行配置

spring:
  rabbitmq:
    host: 192.168.71.132,192.168.71.133
    port: 5672
    username: fort
    password: fort
#      publisher-confirms: true
    publisher-returns: true
    virtual-host: /
    listener:
      simple:
        concurrency: 1
        max-concurrency: 1

(3)设置mq

import org.springframework.amqp.core.Binding;
import org.springframework.amqp.core.BindingBuilder;
import org.springframework.amqp.core.DirectExchange;
import org.springframework.amqp.core.Queue;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

/**
 *  配置质量类型的mq
 * @author zjh
 */
@Configuration
public class MqConfig {
	//队列 起名:TestDirectQueue
    @Bean
    public Queue TestDirectQueue() {
        // durable:是否持久化,默认是false,持久化队列:会被存储在磁盘上,当消息代理重启时仍然存在,暂存队列:当前连接有效
        // exclusive:默认也是false,只能被当前创建的连接使用,而且当连接关闭后队列即被删除。此参考优先级高于durable
        // autoDelete:是否自动删除,当没有生产者或者消费者使用此队列,该队列会自动删除。
        //   return new Queue("TestDirectQueue",true,true,false);
 
        //一般设置一下队列的持久化就好,其余两个就是默认false
        return new Queue("TestDirectQueue",true);
    }
    //Direct交换机 起名:TestDirectExchange
    @Bean
    DirectExchange TestDirectExchange() {
      //  return new DirectExchange("TestDirectExchange",true,true);
        return new DirectExchange("TestDirectExchange",true,false);
    }
    //绑定  将队列和交换机绑定, 并设置用于匹配键:TestDirectRouting
    @Bean
    Binding bindingDirect() {
        return BindingBuilder.bind(TestDirectQueue()).to(TestDirectExchange()).with("TestDirectRouting");
    }
    @Bean
    DirectExchange lonelyDirectExchange() {
        return new DirectExchange("lonelyDirectExchange");
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值