rabbitMq------虚拟机管理模块

news/2024/10/3 11:36:38 标签: rabbitmq, 网络, 分布式

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录

  • 前言
  • 管理的对象
  • 提供的操作
    • 申明/删除交换机
    • 申明/删除队列
    • 绑定/解除绑定
    • 发布消息
    • 消费消息/消息确认


前言

虚拟机管理模块就是对交换机/队列/绑定/消息管理的一个整合,因为这几个模块他们存在一个这关联关系,而这几个模块又是独立的。所以我们将他们整合在一起,提供一个统一的操作。


管理的对象

需要把四个数据管理的句柄保存一份。

    class VirtualHost
    {
    private:
        std::string _host_name;     //虚拟机名称
        ExchangeManager::ptr _emp;
        MsgQueueManager::ptr _mqmp;
        BindingManager::ptr _bmp;
        MessageManager::ptr _mmp;
    }

在构造函数中构造对象。其他三个对象会在构造的时候进行数据的恢复。但是队列消息是以队列为单位进行管理的,我们需要获取已经存在的队列,来进行初始化。

VirtualHost(const std::string &hname,const std::string &basedir,const std::string &dbfile)
  :_host_name(hname),
  _emp(std::make_shared<ExchangeManager>(dbfile)),
  _mqmp(std::make_shared<MsgQueueManager>(dbfile)),
  _bmp(std::make_shared<BindingManager>(dbfile)),
  _mmp(std::make_shared<MessageManager>(basedir)){
      //交换机,队列和绑定信息会在构造函数的时候进行数据恢复。
      //而队列消息没有在构造函数时进行数据恢复,因为我们的队列信息是按照队列为单元进行存储的,这个MessageManager是队列消息的总体管理类
      //获取当前已经存在的队列,为这些队列创建队列消息类,并进行数据恢复
      std::unordered_map<std::string,MsgQueue::ptr> qmap = _mqmp->AllQueue();
      for(auto &q : qmap){
          _mmp->InitQueueMessage(q.first);    //进行数据恢复
      }
  }

提供的操作

申明/删除交换机

删除交换机的时候也需要删除交换机的所有绑定关系

 //交换机操作
bool declareExchange(const std::string &name,
    ExchangeType type, bool durable, bool auto_delete,
    const google::protobuf::Map<std::string, std::string> &args){
    return _emp->declareExchange(name,type,durable,auto_delete,args);
}
void deleteExchange(const std::string &name){
    //删除交换机,同时需要删除交换机的所有绑定信息
   _bmp->removeExchangeBindngs(name);
   _emp->deleteExchange(name);
}

申明/删除队列

申明队列时,需要为队列创建队列消息管理。
删除队列时需要删除队列的绑定信息和队列消息管理对象.

bool declareQueue(const std::string &name, bool durable,
	           bool exclusive, bool auto_delete,
	           const google::protobuf::Map<std::string, std::string> &args){
	//创建队列时,需要位队列创建队列消息管理
	_mmp->InitQueueMessage(name);
	return _mqmp->declareQueue(name,durable,exclusive,auto_delete,args);
	}
	void deleteQueue(const std::string &name){
	//删除队列,同时需要删除队列所有的绑定信息和队列消息
	_bmp->removeMsgQueueBindings(name);
	_mmp->DestoryQueueMessage(name);
	_mqmp->deleteQueue(name);
	}

绑定/解除绑定

绑定关系的持久化是由交换机个队列的持久化决定的。只要当两个的持久化都为1,绑定关系的持久化标志位才为1.

 //绑定信息的操作
        void bind(const std::string &ename, const std::string &qname, const std::string &key){
 //需要判断队列和交换机的持久化标志位
 Exchange::ptr ecp = _emp->selectExchange(ename);
 if(ecp.get() == nullptr){
     ELOG("进行队列绑定失败,交换机%s不存在",ename.c_str());
     return;
 }
 MsgQueue::ptr mqp = _mqmp->selectQueue(qname);
 if(mqp.get() == nullptr){
     ELOG("进行队列绑定失败,队列%s不存在",qname.c_str());
     return;
 }

 //交换机和队列的持久化位必须同时满足,绑定消息的数据才可以持久化
 _bmp->bind(ename,qname,key,ecp->durable && mqp->durable);
}


void unbind(const std::string &ename, const std::string &qname){
 _bmp->unbind(ename,qname);
}

发布消息

发布消息就是调用指定队列的队列消息管理对象的操作,插入一个MessagePtr到链表中,同时持久化。另外需要把队列的持久化标志传入进去,进行判断。

//发布一条消息,只是做了一个存储
 bool basicPublish(const std::string &qname, BasicProperties *bp, std::string body){
     //需要判断队列的持久化标志位
     MsgQueue::ptr mqp = _mqmp->selectQueue(qname);
     if(mqp.get() == nullptr){
         ELOG("发布消息失败,队列%s不存在",qname.c_str());
         return false;
     }

     return _mmp->insert(qname,bp,body,mqp->durable);
 }

消费消息/消息确认

消费消息则是获取指定队列的队列消息管理对象进行操作。
消息确认类似的操作.

//消费一条消息,只是把消息取出,由路由交换模块进行推送消息
MessagePtr basicConsume(const std::string &qname){
    return _mmp->front(qname);
}

//确认一条消息,就是做删除
void basicAck(const std::string &qname,const std::string &msg_id){
    _mmp->ack(qname,msg_id);
}

http://www.niftyadmin.cn/n/5688276.html

相关文章

Docker Compose 部署大模型GPU集群:高效分配与管理算力资源

Docker Compose 部署大模型GPU集群&#xff1a;高效分配与管理算力资源 文章目录 Docker Compose 部署大模型GPU集群&#xff1a;高效分配与管理算力资源一 Dockerfile 编写二 Dockerfile 示例三 分配GPU资源1&#xff09;GPU分配&#xff1a;指定count2&#xff09;GPU分配&am…

SpringSession微服务

一.在linux中确保启动起来redis和nacos 依赖记得别放<dependencyManagement></dependencyManagement>这个标签去了 1.首先查看已经启动的服务 docker ps 查看有没有安装redis和nacos 2.启动redis和nacos 发现没有启动redis和nacos,我们先来启动它。&#xff0c;…

[Linux] Linux 的进程如何调度——Linux的 O(1)进程调度算法

标题&#xff1a;[Linux] Linux 的进程如何调度——优先级与进程调度 个人主页水墨不写bug 目录 一、前言 二、将要出现的概念 1.进程调度队列 2.位图 3.进程的优先级 三、Linux进程的调度过程 1.活动队列&#xff08;*active指向的队列&#xff09; 2.过期队列&#…

thinkphp6入门(25)-- 分组查询 GROUP_CONCAT

假设表名为 user_courses&#xff0c;字段为 user_id 和 course_name&#xff0c;存储每个用户选修的课程&#xff0c;想查询每个学生选修的所有课程 SQL 原生查询 SELECT user_id, GROUP_CONCAT(course_name) as courses FROM user_courses GROUP BY user_id; ThinkPHP 代码…

Bilibili视频如何保存到本地

Bilibili(哔哩哔哩)作为中国领先的视频分享平台之一&#xff0c;汇聚了大量的优质内容&#xff0c;从搞笑动画、综艺节目到专业教程&#xff0c;应有尽有。许多用户时常会遇到这样的需求&#xff1a;希望将视频保存到本地&#xff0c;方便离线观看或者保存珍藏。由于版权保护等…

滚雪球学Oracle[3.4讲]:事务控制与锁管理

全文目录&#xff1a; 前言一、事务隔离级别的深入探讨1.1 事务的定义与基本特性1.2 事务隔离级别的概念1.3 各隔离级别中的问题案例演示&#xff1a;不同隔离级别的行为 1.4 隔离级别与性能的权衡 二、锁的种类与死锁问题解决2.1 锁的种类2.2 锁的粒度2.3 死锁与解决策略死锁的…

三、数据链路层(上)

目录 3.1数据链路层概述 3.1.1术语 3.1.2功能 3.2封装成帧和透明传输 3.2.1封装成帧 ①字符计数法 ②字符&#xff08;节&#xff09;填充法 ③零比特填充法 ④违规编码法 3.2.2透明传输 3.2.3差错控制 差错原因 检错编码 奇偶校验 ☆循环冗余码CRC 例题 纠错…

`git fetch` 检查更新

git fetch 是 Git 中的一个命令&#xff0c;主要用于从远程仓库获取最新的更新&#xff0c;但不会自动将这些更新合并到你的本地分支。它的主要作用是让你可以查看远程仓库的最新变化&#xff0c;而不改变你当前正在工作的代码。 1. 获取远程更新 git fetch 会从远程仓库下载…