基于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,一经查实,立即删除!

相关文章

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表达式标准格式 格式:(形式参数) -> {代码块} 形式参数 如果有多个参数,参数只见用逗号隔开;如果没有&…

【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…

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

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

Java_21 完成一半题目

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

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

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

cuda cudnn pytorch 的下载方法(anaconda)

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

五、Yocto集成QT5(基于Raspberrypi 4B)

Yocto集成QT5 本篇文章为基于raspberrypi 4B单板的yocto实战系列的第五篇文章&#xff1a; 一、yocto 编译raspberrypi 4B并启动 二、yocto 集成ros2(基于raspberrypi 4B) 三、Yocto创建自定义的layer和image 四、Yocto创建静态IP和VLAN 本章节实操代码请查看github仓库&…

数据可视化-Python

师从黑马程序员 Json的应用 Json的概念 Json的作用 Json格式数据转化 Python数据和Json数据的相互转化 注&#xff1a;把字典列表变为字符串用dumps,把字符串还原回字典或列表用loads import json#准备列表&#xff0c;列表内每一个元素都是字典&#xff0c;将其转化为Json …

python实战之常用内置模块

一. 数学计算模块(math) 二. 日期时间模块(datetime) 1. datetime类 datetime类的常用方法 2. date类 1. date类的常用方法 3. time类 4. 计算时间跨度类(timedelta) 5. 日期时间与字符串相互转换 1. 日期和时间格式控制符 三. 正则表达式模块(re) 正则表达式指预先定义好一个’…

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…

吴恩达:现在做GPT-4智能体,或将提前达到GPT-5效果|钛媒体AGI

斯坦福大学客座教授吴恩达&#xff08;Andrew Ng&#xff09;© 林志佳 美国斯坦福大学教授吴恩达&#xff08;Andrew Ng&#xff09; 人工智能智能体&#xff08;AI Agents&#xff09;似乎将引领 AI 行业新的发展趋势。 近日红杉资本&#xff08;Sequoia&#xff09;在…

全面概述Gitee和GitHub生成/添加SSH公钥

前言 现如今将代码开源已经成为软件开发行业的一种趋势&#xff0c;而现在比较有名的代码托管平台有GItHub、Gitee、Gitlab等相关平台。而我们在使用代码托管平台最为常见的就是如何将自己本地的代码推送到远程托管平台中的仓库中&#xff0c;现如今各大托管平台基本上都提供了…

Mac m1 Flink的HelloWorld

首先在官方下载Downloads | Apache Flink 下载好压缩包后解压&#xff0c;得到Flink文件夹 进入&#xff1a;cd flink-1.19.0 ls 查看里面的文件&#xff1a; 执行启动集群 ./bin/start-cluster.sh 输出显示它已经成功地启动了集群&#xff0c;并且正在启动 standalonesessio…

云计算探索-剖析虚拟化技术

引言 虚拟化技术&#xff0c;作为现代信息技术架构的核心构成元素&#xff0c;以其独特的资源抽象与模拟机制&#xff0c;成功地瓦解了物理硬件与操作系统间的刚性连接&#xff0c;开创了一个资源共享、灵活调配的崭新天地。本文将详细解析虚拟化技术的内涵、发展历程、分类及特…

Kafka 学习之:基于 flask 框架通过具体案例详解生产消费者模型,这一篇文章就够了

文章目录 案例信息介绍后端异步处理请求和后端同步处理请求同步方式异步方式 环境文件目录配置.envrequirements.txt 完整代码ext.pyapp.pykafka_create_user.py 运行方式本地安装 kafka运行 app.py使用 postman 测试建立 http 长连接&#xff0c;等待后端处理结果发送 RAW DAT…