springboot整合MQ进行日志收集

该博客介绍了如何利用RocketMQ实现分布式日志收集。生产者在用户注册成功时发送日志到MQ,消费者接收并打印或保存到数据库。通过引入RocketMQ依赖,配置log4j2,创建生产者和消费者,实现了日志的集中管理和处理。
摘要由CSDN通过智能技术生成

需求:注册的服务可能放在不同的服务器上,使用不同的ip或端口。各自打印的日志存在不同的机器上。

           所以我们需要一个消费者,用来收集日志各个系统的日志。把不同系统的日志整合到一起。

           上一个项目每注册一个新用户打印一个日志, 我们可以利用MQ消息队列来进行日志的收集工作。

一、生产者进行消息的发送,

步骤:

1、首先引入RocketMQ依赖

        

2、配置log4j2.properties对rocketmq的支持

      

3、建一个mq的工具类

        在com.sy下建立mq包,并建立OnewayProducer.java类。这个类参数是消息主题,消息标记和消息正文。

        官方提供了多种生产者的方法,用于不同场景:http://rocketmq.apache.org/docs/simple-example/

        

 

4、在注册成功时,我们调用此方法。(实现将注册成功的用户日志发到MQ消息队列。等待消费者进行消费)

        

       

 

、消费者进行消息的接受和保存

步骤:

1、新建一个maven项目,添加mq和log4j2依赖。

    

2、建立一个简单的main方法,接受生产者发来的日志。

    

3、功能测试。


        当我们注册成功时,生产者先发送一条消息,然后消费者受到此条消息并打印到控制台。

        我们还可以将消息保存到数据库。

        

 

 

 

 

 

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Boot整合MQ(消息队列)可以使用Spring Boot集成的JMS(Java消息服务)或AMQP(高级消息队列协议)实现。下面是使用AMQP的步骤: 1. 添加AMQP依赖 在pom.xml文件中添加以下依赖: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-amqp</artifactId> </dependency> ``` 2. 配置连接信息 在application.properties文件中添加以下配置: ```properties spring.rabbitmq.host=localhost spring.rabbitmq.port=5672 spring.rabbitmq.username=guest spring.rabbitmq.password=guest ``` 3. 创建消息发送者 ```java import org.springframework.amqp.rabbit.core.RabbitTemplate; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; @Component public class MessageSender { @Autowired private RabbitTemplate rabbitTemplate; public void sendMessage(String message) { rabbitTemplate.convertAndSend("my-exchange", "my-routing-key", message); } } ``` 4. 创建消息接收者 ```java import org.springframework.amqp.rabbit.annotation.RabbitListener; import org.springframework.stereotype.Component; @Component public class MessageReceiver { @RabbitListener(queues = "my-queue") public void receiveMessage(String message) { System.out.println("Received message: " + message); } } ``` 5. 配置消息队列 ```java import org.springframework.amqp.core.Binding; import org.springframework.amqp.core.BindingBuilder; import org.springframework.amqp.core.Queue; import org.springframework.amqp.core.TopicExchange; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; @Configuration public class RabbitMQConfig { @Bean public Queue myQueue() { return new Queue("my-queue"); } @Bean public TopicExchange myExchange() { return new TopicExchange("my-exchange"); } @Bean public Binding binding(Queue myQueue, TopicExchange myExchange) { return BindingBuilder.bind(myQueue).to(myExchange).with("my-routing-key"); } } ``` 6. 测试 创建一个Spring Boot应用程序,然后使用MessageSender发送消息,MessageReceiver将接收到该消息。 ```java import org.springframework.beans.factory.annotation.Autowired; import org.springframework.boot.CommandLineRunner; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; @SpringBootApplication public class Application implements CommandLineRunner { @Autowired private MessageSender messageSender; public static void main(String[] args) { SpringApplication.run(Application.class, args); } @Override public void run(String... args) throws Exception { messageSender.sendMessage("Hello, world!"); } } ``` 可以在控制台看到以下输出: ``` Received message: Hello, world! ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值