当前位置: 首页 > news >正文

rabbitMq------连接管理模块

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

文章目录

  • 前言
  • 管理的字段
  • 连接内存管理对象


前言

我们的网络通信框架使用的muduo库,而在mudu库中是已经有了连接的概念,但是我们呢还有一个信道的概念muduo库是没有的。其实muduo库是有一个channel的概念的,只不过这个概念和我们这里的channel不一样。
这也就是我们要封装这个模块的意义。


管理的字段

有一个信道内存管理句柄,因为一个连接上可以有多个信道。

 class Connection{private:muduo::net::TcpConnectionPtr _conn;ProtobufCodecPtr _codec;VirtualHost::ptr _host;ConsumerManager::ptr _cmp;ThreadPool::ptr _pool;ChannelManager::ptr _channels;}

提供了三个操作分别是的打开信道,关闭信道和获取指定信道。
就是调用信道内存管理句柄进行操作。
打开信道和关闭都是需要给客户端返回响应的。

 void openChannel(const openChannelRequestPtr &req){bool ret = _channels->openChannel(req->cid(),_host,_cmp,_codec,_conn,_pool);if(ret == false){return basicResponse(false,req->rid(),req->cid());}return basicResponse(true,req->rid(),req->cid());
}void closeChannel(const closeChannelRequestPtr &req){_channels->closeChannel(req->cid());return basicResponse(true, req->rid(), req->cid());
}Channel::ptr getChannel(const std::string &cid){return _channels->getChannel(cid);
}

连接内存管理对象

服务器上可能会存在多条链接,因此我们也需要把连接管理起来
通过一个哈希表,建立tcp连接和连接管理对象的映射。

class ConnectionManager{private:std::mutex _mutex;std::unordered_map<muduo::net::TcpConnectionPtr,Connection::ptr> _conns;}

提供三个操作,新建连接。关闭连接和获取指定连接。
在服务器中就需要管理这个句柄,就可以管理所有的channel了。

void newConnection(const VirtualHost::ptr &host,const ConsumerManager::ptr &cmp,const ProtobufCodecPtr &codec,const muduo::net::TcpConnectionPtr &conn,const ThreadPool::ptr &pool){std::unique_lock<std::mutex> lock(_mutex);auto it = _conns.find(conn);if (it != _conns.end()) {return ;}Connection::ptr self_conn = std::make_shared<Connection>(host,cmp, codec, conn, pool);_conns.insert(std::make_pair(conn, self_conn));   }void delConnection(const muduo::net::TcpConnectionPtr &conn){std::unique_lock<std::mutex> lock(_mutex);_conns.erase(conn);}Connection::ptr getConnection(const muduo::net::TcpConnectionPtr &conn){std::unique_lock<std::mutex> lock(_mutex);auto it = _conns.find(conn);if (it == _conns.end()) {return Connection::ptr();}return it->second;}
http://www.lryc.cn/news/453558.html

相关文章:

  • 【部署项目】禹神:前端项目部署上线笔记
  • 力扣10.1
  • TypeScript 算法手册 - 【冒泡排序】
  • 计算机网络——http和web
  • 使用 Light Chaser 进行大屏数据可视化
  • Java中的异常概念
  • flutter_鸿蒙next_Dart基础②List
  • 【2024保研经验帖】武汉大学测绘遥感国家重点实验室夏令营(计算机向)
  • PyGWalker:让你的Pandas数据可视化更简单,快速创建数据可视化网站
  • Ubuntu24.04远程开机
  • 网络编程(12)——完善粘包处理操作(id字段)
  • 「3.3」虫洞 Wormholes
  • 网页篡改防御方法
  • Pikachu-Cross-Site Scripting-xss盲打
  • JAVA思维提升案例5
  • PostgreSQL的字符集
  • CUDA 参考文章
  • 强缓存和协商缓存的区别
  • 工控系统组成与安全需求分析
  • C(十三)for、while、do - while循环的抉择 --- 打怪闯关情景
  • 【Android 源码分析】Activity生命周期之onStop-2
  • SpringCloudStream+RocketMQ多topic
  • 随记 前端框架React的初步认识
  • 数据结构 ——— 单链表oj题:链表分割(带哨兵位单向不循环链表实现)
  • 华为 HCIP-Datacom H12-821 题库 (32)
  • [C++][第三方库][brpc]详细讲解
  • Python-Learning
  • 如何让 Android 的前端页面像 iOS 一样“优雅”?
  • 10.3学习
  • Shell文本处理(三)