MQ 是message queue ,消息队列,也叫消息中间件,遵守JMS(java message service)规范的一种软件。是类似于数据库一样需要独立部署在服务器上的一种应用,提供接口给其他系统调用。
之前一直在接触MQ但是也不知道自己是用的它的那个功能,或者是哪个场景。之前转过别人的总结,大概是有三种场景。我现在做的项目用MQ比较多的是”在一个课程管理系统中,学员看完课程之后,进行一个保存观看记录或者是对学分的一个统计“,它是属于Mq队列上游不关心下游的结果,只负责发出消息,然后下游(消费者)去处理(消费)数据。今天就根据我用的比较多的场景,大概说一下整个过程和一些关键代码作用。
当学员看完课程之后,调用一个MQ去发一个消息,将用到的一些关键信息,以及一个队列名一起放到MQ对象中,并且用JSON对象转成String并转成Bytes类型,JSON.toJSONString(mqInfo存放信息的对象).getBytes()。然后生产者接收传来的消息调用convertAndSend(XXX,XXX,mqInfo)去转化消息以及发送。到这里生产者的所有都结束了,接下来等待消费者根据队列名去拦截(接收)他的消息。
消费者根据开始接收到的mqInfo先把消息转换成Json对象,然后根据其中的Mq名字去拦截到生产者的消息,然后进行下一步的处理。将开始传入的参数取出,然后进行增删改查以及别的操作。我这里就是查询记录然后代码中增加积分,然后保存到数据库中。
代码就不附了,感觉这就是一个过程遇到问题前几次一定不会理解到位,只有反复做几次才会有点心得。有小小小白想知道的可以私信一起讨论,一定会回。