跨境派

跨境派

跨境派,专注跨境行业新闻资讯、跨境电商知识分享!

当前位置:首页 > 工具系统 > 其他工具 > Vue3前端实现一个本地消息队列(MQ), 让消息延迟消费或者做缓存

Vue3前端实现一个本地消息队列(MQ), 让消息延迟消费或者做缓存

时间:2024-04-24 10:25:33 来源:网络cs 作者:峨乐 栏目:其他工具 阅读:

标签: 消费  延迟  队列  实现  本地 

MQ功能实现的具体代码(TsMQ.ts):

import { v4 as uuidx } from 'uuid';import emitter from '@/utils/mitt'// 消息类class Message {    // 过期时间,0表示马上就消费    exp: number;    // 消费标识,避免重复消费    tag : string;    // 消息体    body : any;    constructor( exp: number ,  body : any ) {        if (exp == 0) {            this.exp = 0;        }else {            this.exp = Date.now().valueOf() + exp;        }        this.body = body;        this.tag = uuidx();    }}export default class TsMQ {    static tsMQ : TsMQ;    cache : boolean;    repository : Map<string, any[]>;    /*     设置只作为缓存使用     */    setCache(cache : boolean)  {        this.cache = cache;    }    /*      获取单列的MQ对象     */    static getInstance() : TsMQ {        if(this.tsMQ == null) {            this.tsMQ = new TsMQ();        }        return this.tsMQ;    }    constructor() {        this.repository = new Map<string,any[]>();        this.cache = false;        setInterval(()=> {            Array.from(this.repository.keys()).forEach( key => {               let poll = this.repository.get(key) as any[];               if(poll.length > 0) {                   poll.forEach( item => {                       if (item.exp == 0 || item.exp <= Date.now().valueOf() - 100) {                           // 如果是作为缓存使用就不会放入mitt就行推送                           if(!this.cache) {                               emitter.emit(key,item.body);                           }                           let single : any[] = this.repository.get(key) as any[];                           single = single.filter(dispose => {                               return dispose.tag !== item.tag;                           });                           this.repository.set(key,single);                       }                   });               }            });        },100)    }    /*      * @describe 放消息入队列      * @param queue : string 队列名称      * @param exp : number 消息消费时间      * @param  message : any 消息体     */    pushMessage( queue : string , exp : number,  message : any ) {        if(this.repository.has(queue)) {            let single : any[] = this.repository.get(queue) as any[];            single.push(new Message(exp,message));            this.repository.set(queue,single);        }else {            let temp = [];            temp.push(new Message(exp,message));            this.repository.set(queue,temp);        }    }    /*     * @describe 直接获取消息,可以配合做本地缓存,就要去掉constructor的轮询中的事件推送     * @param queue : string 队列名称     */    takeMessage( queue : string ) : any {        let single : any[] = this.repository.get(queue) as any[];        if( single && single.length > 0) {            let message = single.shift();            this.repository.set(queue,single);            return message;        }else {            return '队列没有消息!';        }    }}
提示:其中需要用到三方的uuid和mitt,然后要消息持久化可以用到pinia来让消息持久化,本案列没有采用持久化
uuid的三方包安装命令
npm install uuid
mitt的三方安装命令 
npm install --save mitt 

 其中mitt文件的代码

import mitt from "mitt";const emitter = mitt();export default emitter;

使用方式:

投送消息
<script setup lang="ts">   import TsMQ from '@/utils/TsMQ'   import emitter from '@/utils/mitt'   let tsMQ : TsMQ = TsMQ.getInstance();   //投送消息   function pushMQs() {       console.log(`M2投递时间:${new Date().toLocaleString()}`)       tsMQ.pushMessage("HelloWord",1000 * 20,{ name : 'M2', second:20 });       tsMQ.pushMessage("HelloWord",1000 * 3,{ name : 'M1', second:3 });   }</script><template>  <div id="app" style="display: flex;flex-direction: column;justify-content: center;height: 100%;width: 100%;margin: 0;padding: 0">    <span @click="pushMQs">MQ投送</span>  </div></template>

提示:这里采用事件模拟投送消息 

 消息订阅代码:
<script setup lang="ts">   import TsMQ from '@/utils/TsMQ'   import emitter from '@/utils/mitt'   let tsMQ : TsMQ = TsMQ.getInstance();      //订阅消息   emitter.on("HelloWord",e => {     console.log(`收到消息:${JSON.stringify(e)}\n消息时间:${new Date().toLocaleString()}`)   });         function takeMQs() {       console.log(tsMQ.takeMessage('HelloWord'));   }</script><template>  <div id="app" style="display: flex;flex-direction: column;justify-content: center;height: 100%;width: 100%;margin: 0;padding: 0">    <span @click="takeMQs">MQ获取</span>  </div></template>  

效果:

总结:我们可以看到我们实现了这个功能 ,其中可以用来作为缓存使用,同理可写

本文链接:https://www.kjpai.cn/news/2024-04-24/161718.html,文章来源:网络cs,作者:峨乐,版权归作者所有,如需转载请注明来源和作者,否则将追究法律责任!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。

文章评论