基于muduo网络库实现的集群聊天服务器

目录

  • 项目内容
  • 开发环境
  • 安装说明
  • 技术介绍
  • 项目目录
  • 数据库设计
  • 项目介绍
    • 启动服务器
    • 启动客户端
    • 注册账号
    • 登录成功
    • 一对一聊天业务
    • 创建群聊业务
    • 加入群聊业务
    • 群聊业务
    • 添加好友业务
    • 离线消息存储业务
  • 特殊说明

!!!项目是照着腾讯课堂施磊老师的视频学习,仅供个人学习记录使用!!!
!!!项目是照着腾讯课堂施磊老师的视频学习,仅供个人学习记录使用!!!
!!!项目是照着腾讯课堂施磊老师的视频学习,仅供个人学习记录使用!!!

项目内容

使用muduo网络库搭建网络核心模块、Nginx实现聊天服务器的集群,提高并发能力、Redis作为消息中间件、MySQL作为数据存储、json序列化和反序列化作为通信协议的实时聊天服务器。

开发环境

Centos 7 + VsCode远程Linux开发、Cmake构建、Linux Shell输出项目编译脚本

安装说明

1、Linux下安装Nginx并配置Tcp负载均衡
2、Linux下安装MySQL
3、Linux下安装Redis
4、安装CMake

技术介绍

1、使用muduo网络库作为项目的网络核心模块,提供高并发网络IO服务,解耦网络和业务模块代码;

2、使用json序列化和反序列化消息作为私有通信协议;

3、配置nginx基于tcp的负载均衡,实现聊天服务器的集群功能,提高后端服务的并发能力;

4、基于redis的发布-订阅功能,实现跨服务器的消息通信;

5、使用mysql关系型数据库作为项目数据的落地存储;

6、使用连接池提高数据库的数据存取功能。

项目目录

在这里插入图片描述

  • autobuild.sh:一键编译脚本
  • chat.sql:创建数据库表的sql脚本
  • bin:存放服务器和客户端的可执行程序
  • build:cmake编译生成的临时文件
  • CMakeLists.txt:项目使用cmake作为编译环境
  • include:项目的头文件
  • src:项目的源文件
  • test:muduo网络库使用的demo和json序列化和反序列化的demo
  • thirdparty:存放json.hpp

数据库设计

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

项目介绍

功能分为:登录账号、注册账号、退出账号、一对一聊天业务、创建群聊业务、加入群聊业务、群内发消息业务、添加好友业务、离线消息存储业务。

特别说明:以下示例已经启动Nginx和redis-server,Nginx集群了两台服务器,端口分别为6000、6002。

启动服务器

这里启动两台服务器,因为Nginx配置tcp负载均衡时配置了两台。

在这里插入图片描述在这里插入图片描述

启动客户端

同样启动两台客户端进行聊天业务。

在这里插入图片描述

注册账号

在这里插入图片描述

wang wu用户注册成功,他的用户id为3,登录时通过用户id去登录。

登录成功

在这里插入图片描述

在这里插入图片描述

两台客户端分别登录了两个用户,用户id分别为1和3,可以看到用户id为1的用户已经添加了好友和群聊,但是id为3的用户还没有添加任何好友和群聊。

一对一聊天业务

现在进行id=3和id=1之间聊天,不是好友也可以互相聊天。

一对一聊天的命令行输入为:chat:用户id:内容
在这里插入图片描述

创建群聊业务

创建群聊的命令行:creategroup:群聊名:群聊描述

创建群聊的人权限为创建者。

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述
可以看到,数据库里群聊已经创建成功,群聊id为2,userid=3的用户在groupid=2的群里的权限为创建者。

加入群聊业务

在这里插入图片描述
在这里插入图片描述

userid=1的用户加入groupid=2的群,他的权限为普通权限。

群聊业务

在这里插入图片描述userid=3的用户在groupid=2的群里发了一条消息,群内成员收到了这条消息。

添加好友业务

在这里插入图片描述
在这里插入图片描述

可以看到,userid=3的用户有一个好友,好友id=1,即userid=1的用户。

离线消息存储业务

现在我们让userid=3的用户退出,userid=1的用户持续为他发消息。

在这里插入图片描述
在这里插入图片描述
数据库里已经存了两条消息,但是中文乱码了,不影响结果。

现在我们让userid=3的用户重新登录。

在这里插入图片描述
刚刚添加的好友、群聊、离线消息在重新登录之后都成功显示出来了。

特殊说明

要使程序成功跑起来,需要在db.cpp的数据库ip和密码改成自己本机的ip和密码。

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/506115.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【QT+QGIS跨平台编译】054:【exiv2lib_int+Qt跨平台编译】(一套代码、一套框架,跨平台编译)

点击查看专栏目录 文章目录 一、exiv2lib_int介绍二、文件下载三、文件分析四、pro文件五、编译实践一、exiv2lib_int介绍 exiv2lib_int是 exiv2 这个开源的图像元数据库中的一个组件。 Exiv2是一个开源的C++库,用于读取、编辑和写入图片和视频文件的元数据。它可以处理各种类…

01-XML-04XML处理

XML处理 DOM DOM解析要求解析器将整个XML文件全部加载到内存中,生成一个Document对象。 优点:元素和元素之间保留结构,关系,可以针对元素进行增删改查操作。 缺点:如果XML文件过大,可能会导致内存溢出。SA…

【Linux】寿司线程池{单例模式之懒汉模式下的线程池}

文章目录 回顾单例模式0.多线程下的单例模式的意义1.什么是单例模式1.0设计模式1.1C单例模式的介绍及原理1.2拷贝构造和赋值重载的处理1.3if (nullptr ptr),nullptr放在比较运算符的前面?1.4实现单例模式的方式 2.实现懒汉方式的单例模式2.1单线程的单例模式2.2多…

Go 源码之 gin 框架

Go 源码之 gin 框架 go源码之gin - Jxy 博客 一、总结 gin.New()初始化一个实例:gin.engine,该实例实现了http.Handler接口。实现了ServeHTTP方法 注册路由、注册中间件,调用addRoute将路由和中间件注册到 methodTree 前缀树(节…

AR-Net网络(图像篡改检测)

AR-Net网络 摘要AbstractAR-Net1. 文献摘要2. 研究背景3. 创新点4. AR-Net 网络架构5. 实验6. 结论总结 摘要 AR-Net使用自适应注意力机制来融合位置和通道维度的特征,使网络能够充分利用不同维度的被篡改特征,此外,AR-Net 改进了预测掩模&a…

【Web and HTTP,HTTP概况,HTTP连接,持久HTTP,用户-服务器状态:cookie】

文章目录 Web and HTTPHTTP概况HTTP:超文本传输协议使用TCP:HTTP是无状态的 HTTP连接非持久HTTP持久HTTP响应时间模型 持久HTTP非持久HTTP的缺点:持久HTTP提交表单输入 用户-服务器状态:cookie Web and HTTP Web页:由一些对象组成…

智慧校园管理系统

一、项目介绍 1.1 项目简介 智慧校园管理系统:主要是以年级、班级为单位,进行老师和学生信息记录和统计功能。项目采用前后端分离架构思想,前端采用HTMLCSSVUE来实现页面效果展示,后端采用SpringBootMybatisPlus框架实现数据存储…

v3-admin-vite 改造自动路由,view页面自解释Meta

需求 v3-admin-vite是一款不错的后端管理模板,主要是pany一直都在维护,最近将后台管理也进行了升级,顺便完成一直没时间解决的小痛痒: 在不使用后端动态管理的情况下。我不希望单独维护一份路由定义,我希望页面是自解…

鸿蒙手机cordova-plugin-camera不能拍照和图片不显示问题

鸿蒙手机cordova-plugin-camera不能拍照和图片不显示问题 一、运行环境 1、硬件 手机型号:NOVA 7 系统:HarmonyOS版本 4.0.0 2、软件 android SDK platforms:14.0(API Level 34)、13.0(API Level 33) SDK Build-T…

【踩坑】荣耀系统Android8.0 system目录Read-only file system

本来以为直接把Charles证书改成系统证书格式,然后通过mt管理器root之后移动到系统证书目录就行了,结果访问baidu仍然显示网络错误,折腾一晚上。后来直接安装为用户证书,与系统证书冲突。 手机型号:荣耀v10 EMUI&…

win10 安装kubectl,配置config连接k8s集群

安装kubectl 按照官方文档安装:https://kubernetes.io/docs/tasks/tools/install-kubectl-windows/ curl安装 (1)下载curl安装压缩包: curl for Windows (2)配置环境变量: 用户变量: Path变…

牛客NC92 最长公共子序列(二)【中等 动态规划 Java,Go,PHP】

题目 题目链接: https://www.nowcoder.com/practice/6d29638c85bb4ffd80c020fe244baf11 思路 https://blog.csdn.net/qq_36544411/article/details/120021203 思路 动态规划法, 我们以dp[i][j]表示在s1中以第i个元素结尾,s2中以第j个元素结…

CCF-CSP26<2022-06>-第1/2/3题

202206-1 归一化处理 题目&#xff1a;202206-1 题目分析&#xff1a; 给出了数学上归一化的数学公式&#xff0c;直接按照要求完成即可。 AC代码&#xff1a; #include <bits/stdc.h> using namespace std; int main() {int n;cin >> n;double a[n];double s…

开关恒流源简介

目录 工作原理 设计要点 应用场景 初步想法&#xff0c;为参加活动先占贴&#xff08;带家人出去玩没时间搞~~&#xff09;&#xff0c;后面优化 开关恒流源是一种基于开关电源技术的恒流输出电源设备。它采用开关管进行高速的开关动作&#xff0c;通过控制开关管的导通和截…

【跟小嘉学 Linux 系统架构与开发】一、学习环境的准备与Linux系统概述

系列文章目录 【跟小嘉学 Linux 系统架构与开发】一、学习环境的准备与Linux系统介绍 文章目录 系列文章目录[TOC](文章目录) 前言一、Linux 概述1.1、GNU 与自由软件1.2、Linux是什么1.3、Linux 特色1.4、Linux的优缺点1.4.1、Linux 优点1.4.2、Linux 缺点 二、虚拟机介绍2.1…

数据结构与算法 顺序栈的基本运算

一、实验内容 编写一个程序sqstack.cpp&#xff0c;实现顺序栈的各种基本运算&#xff0c;并在此基础上写一个程序exp6.cpp,实现以下功能 初始化栈s判断栈是否为空依次进栈元素a,b,c,d,e判断栈是否为空输出出栈序列判断栈是否为空释放栈 二、实验步骤 1、sqstack.cpp 2、ex…

6.5物联网RK3399项目开发实录-驱动开发之LCD显示屏使用(wulianjishu666)

90款行业常用传感器单片机程序及资料【stm32,stc89c52,arduino适用】 链接&#xff1a;https://pan.baidu.com/s/1M3u8lcznKuXfN8NRoLYtTA?pwdc53f LCD使用 简介 AIO-3399J开发板外置了两个LCD屏接口&#xff0c;一个是EDP&#xff0c;一个是LVDS&#xff0c;接口对应板…

go: go.mod file not found in current directory or any parent directory.如何解决?

这个错误表明你正在执行 go get 命令&#xff0c;但是当前目录或任何父目录中都找不到 go.mod 文件。这可能是因为你的项目还没有使用 Go Modules 进行管理。 要解决这个问题&#xff0c;有几种方法&#xff1a; go mod init <module-name> 其中 <module-name>…

CentOS系统下Docker的安装教程

&#x1f31f; 前言 欢迎来到我的技术小宇宙&#xff01;&#x1f30c; 这里不仅是我记录技术点滴的后花园&#xff0c;也是我分享学习心得和项目经验的乐园。&#x1f4da; 无论你是技术小白还是资深大牛&#xff0c;这里总有一些内容能触动你的好奇心。&#x1f50d; &#x…

oracle+110个常用函数

ASCII 返回与指定的字符对应的十进制数; SQL> select ascii(A) A,ascii(a) a,ascii(0) zero,ascii( ) space from dual; A A ZERO SPACE --------- --------- --------- --------- 65 97 48 32 2. CHR 给出整数,返回对应的字符; SQL> select chr(54740) zhao,chr(65) chr…