一个服务器摆设 集群(服务器集群必要 几台服务器)

媒介

给各人 保举 一个.NET Core WebSocket实现浅显 、高性能、集群即时通讯组件:FreeIM 。

官方组件先容

FreeIM 利用 WebSocket 协议实现浅显 、高性能(单机支持5万+毗连 ) 、集群即时通讯组件 ,支持点对点通讯、群聊通讯、上线下线变乱 消息等浩繁 实用性功能。

WebSocket先容

WebSocket是一种在Web应用程序和服务器之间创建 长期 毗连 的通讯 协议。它通过在客户端和服务器之间创建一个全双工通讯 通道,实现了服务器主动 向客户端推送数据的功能 。相比起传统的HTTP哀求 -相应 模式,WebSocket具有以下几个上风 :

及时 性:WebSocket提供了及时 的双向通讯 ,服务器可以主动 推送数据给客户端,而不必要 客户端发起哀求 。这使得及时 通讯 应用如谈天 室 、股票行情等变得更加简单 和高效。

镌汰 数据传输量:WebSocket在创建 毗连 时必要 举行 握手,之后数据帧的开销较小 ,只必要 发送少量的控制信息,因此相比于HTTP哀求 的头部信息,可以镌汰 数据传输的开销 。

低耽误 :由于WebSocket是一个长毗连 ,克制 了每次哀求 都要创建 TCP毗连 的开销,从而低落 了耽误 。

节流 服务器资源:WebSocket利用 一个TCP毗连 举行 全双工通讯 ,相比于传统的HTTP哀求 ,克制 了频仍 的毗连 和关闭操纵 ,镌汰 了服务器的负担。

支持跨域通讯 :WebSocket答应 在欣赏 器中通过Java与差别 域名下的服务器举行 通讯 ,实现了跨域通讯 的功能 。

项目源码截图

计划 思绪

终端(如欣赏 器/小程序/iOS/android) 同一 利用 websocket 毗连 ImServer;ImServer(支持集群)根据 clientId 分区管理 websocket 毗连 ;WebApi利用 ImHelper 调用方法(如:SendMessage、群聊相干 方法),将数据推至 Redis chan;ImServer订阅 Redis chan ,收到消息后向 终端推送消息;

一个服务器部署集群(服务器集群需要几台服务器) 一个服务器摆设
集群(服务器集群必要
几台服务器) 新闻资讯

缓解了并发推送消息过多的题目 ;

办理 了毗连 数过多的题目 ;

解耦了业务和通讯,架构更加清淅;

ImServer充当消息转发,毗连 维护 ,代码万年稳固 、且不必要 重启维护

WebApi负责全部 业务

ImServer 服务端

publicvoidConfigure(IApplicationBuilder app)

{

app.UseFreeImServer( newImServerOptions

{

Redis = newFreeRedis.RedisClient( "127.0.0.1:6379,poolsize=5"),

Servers = new[] { "127.0.0.1:6001"}, //集群设置

Server = "127.0.0.1:6001"

});

}

WebApi 业务端publicvoidConfigure(IApplicationBuilder app)

{

//...

ImHelper.Initialization( newImClientOptions

{

Redis = newFreeRedis.RedisClient( "127.0.0.1:6379,poolsize=5"),

Servers = new[] { "127.0.0.1:6001"}

});

ImHelper.EventBus(

t = Console.WriteLine(t.clientId + "上线了"),

t = Console.WriteLine(t.clientId + "下线了"));

}

Html5 终端

终端毗连 websocket 前,应该先哀求 WebApi 得到 授权过的地点 (ImHelper.PrevConnectServer),伪代码:

ajax( '/prev-connect-imserver', function(data) {

varurl = data; //此时的值:ws://127.0.0.1:6001/ws?token=xxxxx

varsock = newWebSocket(url);

sock.onmessage = function (e) {

//...

};

})

项目源码

https://github.com/2881099/FreeIM

- EOF -

点击标题可跳转

C# 解压缩开源库 ,轻松完成解压缩文件

.NET 7+Vue 前后端分离框架Admin.Core

C# 中怎样 利用 BCrypt 进步 用户暗码 安全性

看完本文有劳绩 ?请转发分享给更多人

一个服务器部署集群(服务器集群需要几台服务器) 一个服务器摆设
集群(服务器集群必要
几台服务器) 新闻资讯

保举 关注「DotNet」,提拔 .Net技能

点赞和在看就是最大的支持❤️