基于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和密码。

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

NC20128 不重复数字

题目描述 给出N个数,要求把其中重复的去掉,只保留第一次出现的数。 例如,给出的数为1 2 18 3 3 19 2 3 6 5 4,其中2和3有重复,去除后的结果为1 2 18 3 19 6 5 4。 输入描述: 输入第一行为正整数T,表示…

04---java面试八股文——spring-----注解-------10题

31、ComponentScan注解的作用 ComponentScan 注解用于指定 Spring 容器在启动时要扫描的基础包路径,以及要扫描的包路径下应该被自动注册为 Spring bean 的类。 具体来说,ComponentScan 注解的作用有以下几个方面: 组件扫描:Comp…

docker部署DOS游戏

下载镜像 docker pull registry.cn-beijing.aliyuncs.com/wuxingge123/dosgame-web-docker:latestdocker-compose部署 vim docker-compose.yml version: 3 services:dosgame:container_name: dosgameimage: registry.cn-beijing.aliyuncs.com/wuxingge123/dosgame-web-docke…

How to install JDK on mac

文章目录 1. Install JDK on mac2. zshenv, zshrc, zprofile3. 查看java环境变量配置 1. Install JDK on mac Installation of the JDK on macOS 2. zshenv, zshrc, zprofile How Do Zsh Configuration Files Work? 3. 查看java环境变量配置 open Terminal,cd…

02-JDK新特性-Lambda表达式

JDK新特性 Lambda表达式 什么是Lambda表达式 Lambda表达式是一个匿名代码块,用于简单的传递一段代码片段。 Lambda表达式标准格式 格式:(形式参数) -> {代码块} 形式参数 如果有多个参数,参数只见用逗号隔开;如果没有&…

普通数据库索引与搜索引擎的索引有何区别

普通数据库索引,如关系型数据库(RDBMS)中的B树(B-tree)或哈希索引,与搜索引擎使用的倒排索引(Inverted Index)之间存在几个关键区别: 数据结构: 普通数据库索…

【Linux 10】环境变量

文章目录 🌈 Ⅰ 命令行参数⭐ 1. main 函数的参数⭐ 2. main 函数参数的意义⭐ 3. 查看 argv 数组的内容⭐ 4. 命令行参数结论⭐ 5. 为什么要有命令行参数⭐ 6. 命令行参数传递由谁执行 🌈 Ⅱ 环境变量基本概念⭐ 1. 常见环境变量 🌈 Ⅲ 查看…

macOS Catalina for mac (macos 10.15系统)v10.15.7正式版

macOS Catalina是苹果公司专为麦金塔电脑推出的桌面操作系统,是macOS的第16个主要版本。它继承了苹果一贯的优雅与高效,不仅引入了分割视图和侧边栏,还带来了全新的音乐和播客应用,极大地提升了用户体验。在隐私保护和安全性方面&…

【Laravel】07 快速套用一个网站模板

【Laravel】07 快速套用一个网站模板 1. 新增post表2.补充 :生成Model、Controller、迁移文件3. 使用php artisan tinker4. 网站模板下载 课程地址 1. 新增post表 在Model中创建Post (base) ➜ example-app php artisan make:model Post Model created successfu…

ubuntu如何升级Cmake

在编译最新版的OBS时提示我cmake版本太老了: CMake Error at CMakeLists.txt:1 (cmake_minimum_required):CMake 3.22 or higher is required. You are running version 3.20.2先看下没升级前的版本: 升级一下cmake 1、下载需要的版本 https://cmake…

练习3-2 计算符号函数的值

对于任一整数n,符号函数sign(n)的定义如下: 请编写程序计算该函数对任一输入整数的值。 输入格式: 输入在一行中给出整数n。 输出格式: 在一行中按照格式“sign(n) 函数值”输出该整数n对应的函数值。 输入样例1: 10 输出样例1: sign(10) 1 输入样例…

微信小程序(3.3.5) 对实时帧数据调速

前言 小程序返回的实时帧数据帧率很高,需要减速处理。 处理思路:打开监听端口,监听到1帧数据,调用回调函数处理,然后关闭监听端口。 把上述过程封装到一个函数里,再用setInterval()函数按一定时间调用1次…

pytest--python的一种测试框架--pytest常用断言类型

一、pytest常用断言类型 等于: 不等于&#xff1a;&#xff01; 大于&#xff1a;> 小于&#xff1a;< 属于&#xff1a;in 不属于&#xff1a;not in 大于等于&#xff1a;> 小于等于&#xff1a;< 是&#xff1a;is 不是&#xff1a;is not def test_two():ass…

opencv加载出来的灰度图如何传递给pyqt的QImage?

在将OpenCV图像数据传递到PyQt的QImage之前&#xff0c;需要理解两者之间的转换关系。OpenCV通常使用cv2.imread()等函数加载图像&#xff0c;返回的是一个NumPy数组。而QImage是Qt框架中用于图像显示的类。 要将OpenCV的灰度图像转换为QImage&#xff0c;你需要执行以下步骤&a…

【开发总结】Rust的命令行库clap

偶然了解到Rust中有命令行处理的相关库clap&#xff0c;可以很方便的解决程序员需要编写命令行程序时的命令行输入参数问题。 在CSDN中找到了一篇文章进行学习&#xff0c;将一些感想记录如下&#xff1a; 首先该文章的运行环境是cargo&#xff0c;首先需要通过 cargo new &qu…

Java_21 完成一半题目

完成一半题目 有 N 位扣友参加了微软与力扣举办了「以扣会友」线下活动。主办方提供了 2*N 道题目&#xff0c;整型数组 questions 中每个数字对应了每道题目所涉及的知识点类型。 若每位扣友选择不同的一题&#xff0c;请返回被选的 N 道题目至少包含多少种知识点类型。 示例…

selenium 4 自动化~~~操作浏览器

前言 无意中将selenium版本更新了&#xff0c;原先的脚本跑不起来&#xff0c;报错一直是浏览器驱动版本不对&#xff0c;尝试了几种启动浏览器的方法&#xff0c;一直无法解决&#xff0c;直到看到了一篇selenium版本更新的文章才意识到可能是版本升级后的差异&#xff0c;于…

【Spring Boot 源码学习】ConditionEvaluationReport 日志记录上下文初始化器

《Spring Boot 源码学习系列》 ConditionEvaluationReport 日志记录上下文初始化器 一、引言二、往期内容三、主要内容3.1 源码初识3.2 ConditionEvaluationReport 监听器3.3 onApplicationEvent 方法3.4 条件评估报告的打印展示 四、总结 一、引言 上篇博文《共享 MetadataRe…

spark log4j日志文件动态参数读取

需要在log4j xml文件中设置动态参数&#xff0c;并支持spark任务在集群模式下&#xff0c;动态参数读取正常&#xff1b; 1.log4j配置文件 log4j2.xml <?xml version"1.0" encoding"UTF-8"?> <Configuration status"info" name&quo…

cuda cudnn pytorch 的下载方法(anaconda)

文章目录 前言cuda查看当前可支持的最高cuda版本显卡驱动更新下载cuda cudnnpytorch配置虚拟环境创建虚拟环境激活虚拟环境 1.直接下载2.conda 下载(清华源&#xff0c;下载速度慢的看过来)添加清华镜像channel下载下载失败 下载失败解决办法1.浑水摸鱼&#xff0c;风浪越大鱼越…