首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

im协议设计选型(上)

im协议设计选型(上) 周末在一个Qcon群里分享了一些im技术,抽取出其中im协议选型相关的内容,跟大家分享。 分享人:58沈剑,58同城技术委员会主席,高级架构师,优秀讲师。...前百度hi团队成员,负责过58同城im系统的架构设计。 一、im协议的分层设计 所谓“协议”是双方共同遵守的规则,例如:离婚协议,停战协议。协议有语法、语义、时序三要素。...(1)语法:即数据与控制信息的结构或格式 (2)语义:即需要发出何种控制信息,完成何种动作以及做出何种响应 (3)时序:即事件实现顺序的详细说明 今天的重点是在“协议选型”上,重点讲选哪种协议。...im协议设计分为三层:应用层、安全层、传输层。 ? 后文将详细介绍这三层的协议应该如何选型与设计。 二、im应用层协议设计 应用层协议选型,常见的有三种:文本协议、二进制协议、流式XML协议。...ps:文本只介绍了im协议选型,只是协议设计的上半部分,选型完之后,协议细节如何设计也没有展开讲,后续会撰文讨论《im协议设计细节(下)》。

1.2K110

移动端IM系统的协议选型:UDP还是TCP?

从PC时代的IM开始,IM开发者就在为数据传输协议的选型争论不休(比如:《为什么QQ用的是UDP协议而不是TCP协议?》这样的问题,隔一段时间就能在社区里看到)。...(本文同步发布于:http://www.52im.net/thread-33-1-1.html) 2、学习交流 - 移动端IM开发推荐文章:《新手入门一篇就够:从零开发移动端IM》 3、参考资料 《为什么...这些问题都是讨论�移动端IM、消息推送等类似话题时,几乎一定被问到的问题。这里尝试正本清源一下。...也因为如此,移动端IM、推送系统必须实现所谓的心跳包机制,以保持端口映射关系的老化时间不会减少到0而被回收,从而避免连接中断。...(本文同步发布于:http://www.52im.net/thread-33-1-1.html)

2K10
您找到你想要的搜索结果了吗?
是的
没有找到

IM系统的MQ消息中间件选型:Kafka还是RabbitMQ?

IM系统的MQ消息中间件选型:Kafka还是RabbitMQ?...1、前言 在IM这种讲究高并发、高消息吞吐的互联网场景下,MQ消息中间件是个很重要的基础设施,它在IM系统的服务端架构中担当消息中转、消息削峰、消息交换异步化等等角色,当然MQ消息中间件的作用远不止于此...,它的价值不仅仅存在于技术上,更重要的是改变了以往同步处理消息的思路(比如进行IM消息历史存储时,传统的信息系统作法可能是收到一条消息就马上同步存入数据库,这种作法在小并发量的情况下可以很好的工作,但互联网大并发环境下就是灾难...但市面上的MQ消息中间件产品很多,作为IM系统中必不可少的一环,我们该如何选型?那么请继续阅读本文。...11、消息中间件选型误区总结 在进行消息中间件选型之前可以先问自己一个问题:是否真的需要一个消息中间件?在搞清楚这个问题之后,还可以继续问自己一个问题:是否需要自己维护一套消息中间件?

92920

IM系统的MQ消息中间件选型:Kafka还是RabbitMQ?

1、前言 在IM这种讲究高并发、高消息吞吐的互联网场景下,MQ消息中间件是个很重要的基础设施,它在IM系统的服务端架构中担当消息中转、消息削峰、消息交换异步化等等角色,当然MQ消息中间件的作用远不止于此...,它的价值不仅仅存在于技术上,更重要的是改变了以往同步处理消息的思路(比如进行IM消息历史存储时,传统的信息系统作法可能是收到一条消息就马上同步存入数据库,这种作法在小并发量的情况下可以很好的工作,但互联网大并发环境下就是灾难...但市面上的MQ消息中间件产品很多,作为IM系统中必不可少的一环,我们该如何选型?那么请继续阅读本文。...6、具体技术选型指标2:性能 功能维度是消息中间件选型中的一个重要的参考维度,但这并不是唯一的维度。...10、消息中间件选型误区总结 在进行消息中间件选型之前可以先问自己一个问题:是否真的需要一个消息中间件?在搞清楚这个问题之后,还可以继续问自己一个问题:是否需要自己维护一套消息中间件?

1.7K30

IM系统的MQ消息中间件选型:Kafka还是RabbitMQ?

但市面上的MQ消息中间件产品很多,作为IM系统中必不可少的一环,我们该如何选型?那么请继续阅读本文。...6、具体技术选型指标1:功能维度 功能维度又可以划分个多个子维度,大致可以分为以下这些。...7、具体技术选型指标2:性能 功能维度是消息中间件选型中的一个重要的参考维度,但这并不是唯一的维度。...11、消息中间件选型误区总结 在进行消息中间件选型之前可以先问自己一个问题:是否真的需要一个消息中间件?在搞清楚这个问题之后,还可以继续问自己一个问题:是否需要自己维护一套消息中间件?...:32人工程团队创造的技术神话》 《微信朋友圈千亿访问量背后的技术挑战和实践总结》 《王者荣耀2亿用户量的背后:产品定位、技术架构、网络方案等》 《IM系统的MQ消息中间件选型:Kafka还是RabbitMQ

1.9K30

探探的IM长连接技术实践:技术选型、架构设计、性能优化

本文将要分享的是陌生人社交应用探探的IM长连接模块从技术选型到架构设计,再到性能优化的整个技术实践过程和经验总结。...学习交流: - 移动端IM开发入门文章:《新手入门一篇就够:从零开发移动端IM》 - 开源IM框架源码:https://github.com/JackJiang2011/MobileIMSDK 2、关于作者...4、一个小插曲 项目大概持续了一个季度时间,首先是拿IM业务落地,我们觉得长连接跟IM绑定比较紧密一些。 IM落地之后,后续长连接上线之后,各个业务比较依赖于长连接服务。...(▲ 上图引用自《移动端IM/推送系统的协议选型:UDP还是TCP?》) TCP实现长连接的四个问题: 1)移动端的消息量还是比较稀疏,用户每次拿到手机之后,发的消息总数比较少,每条消息的间隔比较长。...(本文已同步发布于:http://www.52im.net/thread-3780-1-1.html) 14、参考资料 [1] 移动端IM/推送系统的协议选型:UDP还是TCP?

1.5K20

IM跨平台技术学习(三):vivo的Electron技术栈选型、全方位实践总结

2、系列文章本文是系列文章中的第3篇,本系列总目录如下:《IM跨平台技术学习(一):快速了解新一代跨平台桌面技术——Electron》《IM跨平台技术学习(二):Electron初体验(快速开始、跨进程通信...、打包、踩坑等)》《IM跨平台技术学习(三):vivo的Electron技术栈选型、全方位实践总结》(* 本文)《IM跨平台技术学习(四):蘑菇街基于Electron开发IM客户端的技术实践》(稍后发布..... )《IM跨平台技术学习(五):融云基于Electron的IM跨平台SDK改造实践总结》(稍后发布.. )《IM跨平台技术学习(六):网易云信基于Electron的IM消息全文检索技术实践》(稍后发布...4、开发技术栈选型4.1编程语言选型我们最终选择的是Typescript,理由如下。...的聊天消息全文检索技术实践学习交流:- 移动端IM开发入门文章:《新手入门一篇就够:从零开发移动端IM》 - 开源IM框架源码:https://github.com/JackJiang2011/MobileIMSDK

1.3K30

IM消息ID技术专题(七):网易严选分布式ID的技术选型、优化、落地实践

本篇中的订单ID虽然不同于IM系统中的消息ID,但其技术实践仍然相通,希望能给你的IM系统消息ID技术选型也来更多的启发。...3、系列文章本文是系列文章中的第7篇,本系列总目录如下:《IM消息ID技术专题(一):微信的海量IM聊天消息序列号生成实践(算法原理篇)》《IM消息ID技术专题(二):微信的海量IM聊天消息序列号生成实践...(容灾方案篇)》《IM消息ID技术专题(三):解密融云IM产品的聊天消息ID生成策略》《IM消息ID技术专题(四):深度解密美团的分布式ID生成算法》《IM消息ID技术专题(五):开源分布式ID生成器UidGenerator...的技术实现》《IM消息ID技术专题(六):深度解密滴滴的高性能ID生成器(Tinyid)》《IM消息ID技术专题(七):网易严选分布式ID的技术选型、优化、落地实践》(* 本文)4、为什么需要分布式ID...5、我们的分布式ID架构原理5.1 技术选型下表是业内常见的分布式ID解决方案:综合考虑是否支持水平扩展以及能够显示指定ID长度,最终选择的是Leaf的Segment模式(详见《深度解密美团的分布式ID

29220

一套分布式IM即时通讯系统的技术选型和架构设计

为了更好的理解分布式IM即时通讯系统的设计,我站在架构师的角度,在充分了解系统需求、业务流程和技术流程后,从全局视角为系统设定方案目标,对技术方案进行选型,对系统进行总体架构设计和分层架构设计,并梳理清楚发送消息的交互链路...2、方案目标 在进行技术选型与总体架构设计之前,需要明确一个事项,就是系统无论采用哪种方案,采用哪种架构设计都需要明确这种方案的业务目标、技术目标和架构目标,并在研发过程中不断评估系统的总体性能表现,发现系统瓶颈并不断进行优化...3、技术选型 在技术选型上,除了采用SpringBoot等基础框架外,也会采用容器化方案。...同时,考虑到为了尽量降低技术门槛,在整个分布式IM即时通讯系统的技术选型中,主要采用市面上比较流行的技术框架和方案。...具体选型如下所示: 1)开发框架:SpringBoot、SpringCloud、SpringCloud Alibaba、Dubbo; 2)缓存:Redis分布式缓存+Guava本地缓存; 3)数据库:MySQL

49101

用户接口和IM表达式(IM 5.6)

上接IM 5.5。本章为IM系列第五章 使用In-Memory表达式优化查询第六部分用户接口和IM表达式。...· DISABLE 数据库不会将IM表达式(无论是静态还是动态)都填充到IM列存储中。 注: IM表达式不支持依赖于NLS的数据类型。...(IM-4.2 第二部分) 第四章 为IM 启用填充对象之启用和禁用列(IM-4.3 第三部分) 第四章 为IM 启用填充对象之在NO INMEMORY表上指定INMEMORY列属性:示例(IM-4.4...第四部分) 第四章 为IM 启用填充对象之启用和禁用表空间的IM列存储(IM 4.5) 第四章 为物化视图启用和禁用IM列存储(IM 4.6) 第四章 为IM 启用填充对象之强制填充In-Memory...对象:教程(IM 4.7) 第四章 为IM 启用填充对象之为IM列存储启用ADO(IM 4.8) 第五章 使用In-Memory表达式优化查询(IM 5.1) IM表达式的目的(IM 5.2) IM表达式如何工作

1.1K20

IM表达式的目的(IM 5.2)

上接IM 5.1,本章为IM系列第五章 使用In-Memory表达式优化查询第二部分IM表达式的目的。 IM表达式的目的 IM表达式通过预先计算计算密集表达式来加速大数据集的查询速度。...IM表达式和物化视图解决了相同的问题:如何避免重复计算表达式。然而,IM表达式具有优于物化视图的优点: · IM表达式可以捕获未持久存储的数据。...(IM-4.2 第二部分) 第四章 为IM 启用填充对象之启用和禁用列(IM-4.3 第三部分) 第四章 为IM 启用填充对象之在NO INMEMORY表上指定INMEMORY列属性:示例(IM-4.4...第四部分) 第四章 为IM 启用填充对象之启用和禁用表空间的IM列存储(IM 4.5) 第四章 为物化视图启用和禁用IM列存储(IM 4.6) 第四章 为IM 启用填充对象之强制填充In-Memory...对象:教程(IM 4.7) 第四章 为IM 启用填充对象之为IM列存储启用ADO(IM 4.8) 第五章 使用In-Memory表达式优化查询(IM 5.1) 山东Oracle用户组(Shandong

1K30

抖音技术分享:飞鸽IM桌面端基于Rust语言进行重构的技术选型和实践总结

1)历史技术选型,包含者成本、人力、效率等考量,飞鸽客户端使用的技术栈是react + electron:* im sdk与业务渲染代码都由 js 编写,im sdk同时是cpu密集型 & io 密集型的组件...通过POC,我们得出的结论是:具体就是:1)rust 整体优于 js,计算占比越重,优势越明显(高压时cpu差别能到达3倍以上);2)架构选型上,rust进程独立是最好的方案,稳定性更优、性能损耗相差较小...此阶段要实现im sdk的全部能力、 并对线上运行的js im sdk进行替换。...的移动端跨端改造实践[2] IM开发干货分享:有赞移动端IM的组件化SDK架构设计实践[3] IM开发干货分享:我是如何解决大量离线消息导致客户端卡顿的[4] 如约而至:微信自用的移动端IM网络层跨平台组件库...Mars已正式开源[5] 从客户端的角度来谈谈移动端IM的消息可靠性和送达机制[6] IM开发干货分享:IM客户端不同版本兼容运行的技术思路和实践总结[7] IM全文检索技术专题(四):微信iOS端的最新全文检索技术优化实践

19310

基于Netty,徒手撸IM(一):IM系统设计篇

注意:本系列是给IM初学者的文章,IM老油条们还望海涵,勿喷!...,有的只是从IM入门者的角度的思路和实战,适合IM初学者阅读。...2、知识准备* 重要提示:本系列文章主要是代码实战分享,如果你对即时通讯(IM)技术理论了解的不多,建议先详细阅读:《零基础IM开发入门:什么是IM系统?》、《新手入门一篇就够:从零开发移动端IM》。...(一):IM系统设计篇》(* 本文)《基于Netty,徒手撸IM(二):编码实践篇(单聊功能)》《基于Netty,徒手撸IM(三):编码实践篇(群聊功能)》《基于Netty,徒手撸IM(一):编码实践篇...[11] 基于实践:一套百万消息量小规模IM系统技术要点总结[12] 探探的IM长连接技术实践:技术选型、架构设计、性能优化(本文已同步发布于:http://www.52im.net/thread-3963

1.8K10

IM开发快速入门(一):什么是IM系统?

2、系列文章目录 《IM开发快速入门(一):什么是IM系统?》(* 本文) 《IM开发快速入门(二):什么是IM系统的实时性? (稍后发布)》 《IM开发快速入门(三):什么是IM系统的可靠性? ...(稍后发布)》 《IM开发快速入门(四):什么是IM系统的一致性? (稍后发布)》 《IM开发快速入门(五):什么是IM系统的安全性? ...(稍后发布)》 《IM开发快速入门(六):什么是IM系统的的心跳机制? (稍后发布)》 《IM开发快速入门(七):如何理解并实现IM系统消息未读数? ...下面这些场景是我们大家都熟悉的,都用到了IM技术: 1)微信、qq、钉钉等主流IM应用:这是IM技术的典型应用场景; 2)微博、知乎等社区应用:它们利用IM技术实现了用户私信等点对点聊天; 3)抖音、快手等直播...以下文章适合IM架构设计入门,有兴趣可以读一读: 《浅谈IM系统的架构设计》 《简述移动端IM开发的那些坑:架构设计、通信协议和客户端》 《从游击队到正规军(一):马蜂窝旅游网的IM系统架构演进之路》

2.3K12

数据库如何填充IM表达式(IM 5.4)

上接IM 5.3。本章为IM系列第五章 使用In-Memory表达式优化查询第四部分数据库如何填充IM表达式。...相关概念(续)(IM-1.2) 第二章 Oracle Database In-Memory 体系结构(上) (IM-2.1) 第二章 In-Memory 体系结构 (IM-2.2) 第二章 IM 体系结构...(IM-4.2 第二部分) 第四章 为IM 启用填充对象之启用和禁用列(IM-4.3 第三部分) 第四章 为IM 启用填充对象之在NO INMEMORY表上指定INMEMORY列属性:示例(IM-4.4...第四部分) 第四章 为IM 启用填充对象之启用和禁用表空间的IM列存储(IM 4.5) 第四章 为物化视图启用和禁用IM列存储(IM 4.6) 第四章 为IM 启用填充对象之强制填充In-Memory...对象:教程(IM 4.7) 第四章 为IM 启用填充对象之为IM列存储启用ADO(IM 4.8) 第五章 使用In-Memory表达式优化查询(IM 5.1) IM表达式的目的(IM 5.2) IM表达式如何工作

82430

第四章 为IM 启用填充对象之为IM列存储启用ADO(IM 4.8)

(续)(IM-1.2) 第二章 Oracle Database In-Memory 体系结构(上) (IM-2.1) 第二章 In-Memory 体系结构 (IM-2.2) 第二章 IM 体系结构:CPU...架构:SIMD向量处理(IM-2.3) 第三章 启用和调整IM列存储的大小(IM-3.1) 第四章 为In-Memory 启用填充对象(IM-4.1 第一部分) 第四章 为In-Memory 启用填充对象...(IM-4.2 第二部分) 第四章 为IM 启用填充对象之启用和禁用列(IM-4.3 第三部分) 第四章 为IM 启用填充对象之在NO INMEMORY表上指定INMEMORY列属性:示例(IM-4.4...第四部分) 第四章 为IM 启用填充对象之启用和禁用表空间的IM列存储(IM 4.5) 第四章 为物化视图启用和禁用IM列存储(IM 4.6) 第四章 为IM 启用填充对象之强制填充In-Memory...对象:教程(IM 4.7) 本篇为IM系列的第四章:为IM 启用填充对象之为IM列存储启用ADO(IM 4.8) 为IM列存储启用ADO 信息生命周期管理(ILM)是一组用于管理从创建到归档或删除的数据的过程和策略

1.4K20
领券