为自己搭建一个分布式 IM(即时通讯) 系统

为自己搭建一个分布式 IM(即时通讯) 系统,第1张

如果你像其他97%的人口一样,那么至少有一次在你的生活中,你使用手机发送文本或聊天消息。普通用户在一天内发送至少14条短信,可以通过即时消息APP或SMS发送。这实际上意味着消息传递可能位于智能手机高度使用功能列表的顶部。尽管如此,语音/视频通话仍然紧随其后。

11。什么是即时消息?

即时消息或即时消息是一种在线聊天,通过互联网提供实时文本传输。一些IMAPP还使用Push技术来提供实时文本,这些文本可以在字符构成时逐字传输文本。具有高级功能的即时通讯APP甚至可以帮助用户发送文件,可点击的超链接,VoIP,视频聊天,流媒体和更多类似的服务。

那么让我们来谈谈如何开发WhatsApp之类的APP。消息市场在WhatsApp领导游戏行业(每日活跃用户数为8亿)方面占据主导地位,其次是Facebook Messenger(每日活跃用户数为7亿)和微信(每日活跃用户数量为549亿人),但这并不意味着没有更多的空间和范围,一些更有创意的解决方案,金和盛在这里提供帮助!

2 WhatsApp的Tech Stack

如果你打算制作一个聊天APP,为什么不建模一个似乎已经正确的人。让我们开始了解什么样的技术堆栈与金和盛一起开发类似WhatsApp的即时消息APP?

21。Erlang

这是用于开发WhatsApp的首席编程语言。由于其卓越的性能,速度和可扩展性,这种语言获得了最多的认可和赞赏 - 这种组合最适合实时聊天应用!

22。Ejabberd

Ejabberd XMPP(可扩展消息和存在协议)服务器是独一无二的,它具有处理成千上万条消息的能力,并且速度快,无延迟,因此非常适合您。此外,它还可以很好地与Erlang编程语言结合使用,使它成为一个神话般的二重奏,并为整个APP提供动力!该服务器使用特定的可插拔模块进行开发,该模块允许广泛的功能范围,如:

一对一聊天

联系实际和在线列表

存储和转发(离线消息)

PEP(个人事件协议)和消息键入规范

多用户聊天(MUC) - 群聊

隐私设置和帐户欺骗

消息归档管理

23。YAWS

另一个Web服务器或YAWS是为多媒体文件存储而开发的,完全由Erlang编写。这是一款高性能的Web服务器,专为具有动态内容的高负载应用而开发。YAWS在处理并行流程的能力方面独树一帜,并且具有高性能标准。

24。FreeBSD的

这是WhatsApp正在使用的 *** 作系统,并帮助它在其平台上每天发送数十亿条消息。FreeBSD *** 作系统具有精巧的网络堆栈和广泛的可靠性。这是一个功能强大,稳定,开放源码的Unix系统,实时聊天APP开发人员拥有丰富的使用经验。由于FreeBSD是一个单独的分销商,它在安装方面有一些明显的优势,并提供了二进制软件包的简单创建。

25。Lig>

Lig>

26。自定义XMPP(可扩展消息和存在协议)服务器

最初这是WhatsApp用来传输所有用户信息的东西。这项技术具有很大的优势,因为它支持一对一和多用户聊天对话。但最终公司不得不切换到不同的互联网协议,以优化其服务器性能。

27。Mnesia DB

用Erlang编写的实时数据库管理功能非常适合存储任何实时聊天APP上运行的消息,文件,图像,视频,文档以及其他多媒体文件。对于WhatsApp,数据库通过Mnesia和MySQL数据库的组合启动。

3使WhatsApp真棒的功能

从Techstacks开始,让我们深入了解更明显的视觉功能,这些功能可以帮助您制作一款酷酷的新型聊天APP。当您打算构建WhatsApp这样的APP时,在决定APP拥有哪些APP之前,研究APP的功能非常重要!

31。注册和联系

大多数实时聊天APP或即时消息APP需要用户使用电话号码登录,而有些可能会通过社交媒体登录进行登录。WhatsApp更进一步,拍摄了短信进行确认,为用户增加了一层安全性,这是通过使用第三方API(如Twilio或Nexmo等)完成的。

然后,用户应该从地址簿中添加他们的联系人。聊天只能让你周围的所有朋友聊天才能开心!你甚至可以考虑整合其他选项,如gamil或Facebook(如果你有很多口袋的话)。现在,这一步需要非常快捷方便。

在这个级别考虑Profile UX / UI可能是一个好主意。您可以考虑您可能提供的那种自定义选项,或者决定是否希望用户能够与其他社交配置文件连接,或者您是否会向用户提供任何自定义设计功能。我们提供的用户体验堪称典范,让您的用户享受注册过程。

32。即时消息/实时聊天

由于它是一个聊天APP,所以消息传递功能是给定的。然而,这不是一种肯定或否定的选择,如果你正在考虑构建一个聊天APP,那么需要解决一些小小的细节。让我们来看看金和盛的清单,以帮助您做出决定。

用户以何种方式发起聊天?

你只会提供一对一的聊天选项,还是会有群聊的功能?除了这两个选项,WhatsApp甚至允许“广播列表”功能,它允许用户将相同的消息发送到指定的人员列表。

你会只提供私人聊天选项还是提供公共聊天室?

你想添加超级秘密安全功能,消息在读取后会在指定的时间后自毁吗?

你想提供一些装饰,如字体类型,字体选项,贴纸,静音功能,共享多媒体和文档等?尽管这些功能对于MVP来说可能不是一个好主意,但是请将它们包含在未来版本的APP中。

你会提前提前安排消息的功能吗?

今天的人们高度关注数据的隐私,研究表明,大约96%的人害怕在线黑客攻击,并将他们的私人数据置于危险之中。因此,当您着手开发私人Messenger软件时,务必注意用户的安全。以下是您的计划中应该注意的主要问题。

你可以看看开发和实现一个额外的匿名自毁功能。

您可能会考虑大量投资于高级加密技术,并保护所有消息免遭劫持。

您可以看看ChatSecure和CryptoCat这两个伟大的开源加密聊天APP。他们的代码甚至可以在Github上供所有开发人员查看并理解他们的加密如何工作。金和盛开发的即时消息功能对APP用户的安全保持警惕。

33。通知和推送消息

这些可能看起来很小,但在保留用户和保持其在APP中的活跃性方面有很长的路要走。一个基本规则是让用户自定义他们想要接收的通知类型。Firebase云消息传递适用于Android和iOS平台。但本机Apple推送通知可能更适合iOS平台。但是,Firebase Cloud Messaging大大降低了开发成本和开发时间。金和盛的聊天室和MessengerAPP可让您发送相关的推送通知,并帮助您吸引和留住您的用户。

34。多媒体文件传输

当它超越文本和表情符号时,聊天确实更有趣。您的用户会寻找他们可以共享多媒体文件的功能和方式,例如图像,GIF,视频,贴纸等等!毕竟,一张可能胜过千言万语。不过,如果您拥有财力雄厚的产品,您甚至可以考虑与领先的云端服务提供同步选项,例如Google Drive,Evernote和Dropbox。金和盛制作的即时通讯APP可让您的用户完美无缺地传输多媒体文件。

35。分享位置

这是一个功能,当你的朋友在圈子里走动试图去你的房子时,它会派上用场!Apple MapKit和Google Location SDK提供了用于集成位置共享的本地工具包。如果您计划与当地企业合作以通过应用获利,您还可以在应用中考虑iBeacon和Eddystone传感器。这有助于用户在进入会场的地理围栏后收到相关消息。很像WhatsApp,金和盛 制作的即时通讯APP可让用户与其他用户分享他们的位置。

4额外的实时聊天APP功能,您可能会考虑为您的APP

虽然WhatsApp可能会引领整个潮流,但这并不意味着它们是完美无瑕的,并且可以装载各种各样的功能。您可以查看WhatsApp尚未提供的以下功能并做出明智的决定!

41。VoIP(互联网协议语音)呼叫

在实施方面,这是一个昂贵的方面,但在用户中是一个非常有价值的功能。通过Skype或Viber等实时聊天应用进行呼叫越来越受欢迎,并逐渐取代传统的手机通话。

42。视频聊天

距离已经增加,时间被证明是一种难以捉摸的商品。在这个时代和时代,视频聊天或视频通话已经超越了“酷”,并且变成了一种必需品,以便与那些居住在那里的人保持联系远。

43。音频和视频流

这是SnapChat的核心功能,并且已被其他领先渠道(包括Instagram和Facebook)效仿。这可能是一个值得投资的功能。

44。活动计划和同步日历

此功能非常适合提醒用户有关特别活动或庆祝活动的信息,以便您可以提前计划。当您试图吸引“商业”人群到您的APP时,此功能特别有利并且效果很好。

45。应用内购买和订阅计划

必须有一个收入模式,这是实时聊天应用货币化的最有效方式之一。

46。多平台聊天

当您提供跨平台使用APP的选项时,无论您的APP是连接到桌面还是始终处于运行状态,您都可以帮助用户保持与APP的联系!

47。自毁信息

这是一个很棒的功能,可以让你发送秘密聊天信息给你的朋友,然后在他们看到它的一段时间后自毁。

48。云服务同步

当您允许用户将您的应用与突出的云服务同步时,可以以更高效的方式监控,更新,存储和扩展托管环境。

5促成和影响成本的因素

成本和预算因素对正在开发APP的人有很大的影响,当你跳跃时,它应该是一个计算出来的。虽然可能很难说出制作应用需要多少费用,但是可以列出对应用开发成本有重大影响的关键决策。

你选择的平台将决定你将要咳嗽的钱的种类。明智地选择是否要为Android,iOS或两者构建!

您决定继续使用的功能范围将决定您将要投入的时间和金钱类型。很自然地,你拥有的功能越多,成本就越高。虽然您必须优化您在MVP中提供的功能数量,但保留足够的功能以保持用户参与。

制定预算是您在整个过程中必须做出的最重要的决定之一。正是这个决定会推动所有其他决策,重要的是要保持现实,不要太过分或太紧张。

选择能够帮助您完成手头任务的代理商,同时满足您的时间表,提供优质的产品,并保持在预算范围内。

微信小程序即时通讯功能只需要接入即构科技的IM即时通讯就可以实现了,即构的IM产品不仅支持基础的单聊/群聊功能,还支持消息高并发量的房间聊天,单房间人数支持到百万以上,适合对房间人数要求高的场景使用。另外支持呼叫邀请、离线消息、离线推送等功能,满足各类即时通讯的需求。

软件开发公司排行榜
极其流行,同样也是竞争力极其大的一种商业模式。虽然国内软件开发公司都发展壮大起来了,但是各地软件开发公司的实力及资质仍然参差不齐。下面为大家介绍下近期国内软件开发公司的排名汇总。
1:华盛恒辉科技有限公司
上榜理由:华盛恒辉是一家专注于高端软件定制开发服务和高端建设的服务机构,致力于为企业提供全面、系统的开发制作方案。在开发、建设到运营推广领域拥有丰富经验,我们通过建立对目标客户和用户行为的分析,整合高质量设计和极其新技术,为您打造创意十足、有价值的企业品牌。
在军工领域,合作客户包括:中央军委联合参谋(原总参)、中央军委后勤保障部(原总后)、中央军委装备发展部(原总装)、装备研究所、战略支援、军事科学院、研究所、航天科工集团、中国航天科技集团、中国船舶工业集团、中国船舶重工集团、第一研究所、训练器材所、装备技术研究所等单位。
在民用领域,公司大力拓展民用市场,目前合作的客户包括中国中铁电气化局集团、中国铁道科学研究院、济南机务段、东莞轨道交通公司、京港地铁、中国国电集团、电力科学研究院、水利部、国家发改委、中信银行、华为公司等大型客户。
2:五木恒润科技有限公司
上榜理由:五木恒润拥有员工300多人,技术人员占90%以上,是一家专业的军工信息化建设服务单位,为军工单位提供完整的信息化解决方案。公司设有股东会、董事会、监事会、工会等上层机构,同时设置总经理职位,由总经理管理公司的具体事务。公司下设有研发部、质量部、市场部、财务部、人事部等机构。公司下辖成都研发中心、西安研发中心、沈阳办事处、天津办事处等分支机构。
3、浪潮
浪潮集团有限公司是国家首批认定的规划布局内的重点软件企业,中国著名的企业管理软件、分行业ERP及服务供应商,在咨询服务、IT规划、软件及解决方案等方面具有强大的优势,形成了以浪潮ERP系列产品PS、GS、GSP三大主要产品。是目前中国高端企业管理软件领跑者、中国企业管理软件技术领先者、中国最大的行业ERP与集团管理软件供应商、国内服务满意度最高的管理软件企业。
4、德格Dagle
德格智能SaaS软件管理系统自德国工业40,并且结合国内工厂行业现状而打造的一款工厂智能化信息平台管理软件,具备工厂ERP管理、SCRM客户关系管理、BPM业务流程管理、
OMS订单管理等四大企业业务信息系统,不仅满足企业对生产进行简易管理的需求,并突破局域网应用的局限性,同时使数据管理延伸到互联网与移动商务,不论是内部的管理应用还是外部的移动应用,都可以在智能SaaS软件管理系统中进行业务流程的管控。
5、Manage
高亚的产品 (8Manage) 是美国经验中国研发的企业管理软件,整个系统架构基于移动互联网和一体化管理设计而成,其源代码编写采用的是最为广泛应用的
Java / J2EE 开发语言,这样的技术优势使 8Manage
可灵活地按需进行客制化,并且非常适用于移动互联网的业务直通式处理,让用户可以随时随地通过手机apps进行实时沟通与交易。

WebRTC需要通过长链接查找到通信双方,然后通过 peer to peer 的方式传输音频数据。

WebRTC中最主要的就是一个叫做 PeerConnection 的对象,这个是WebRTC中已经封装好的对象。每一路的音视频会话都会有唯一的一个 PeerConnection 对象,WebRTC通过这个 PeerConnection 对象进行视频的发起、传输、接收和挂断等 *** 作。
PeerConnection中包含的属性如下:

PeerConnection 中还包含了一些方法:

RTCSessionDescription 类型中包含了两个属性:

A向B发起通信请求

首先WebRTC需要一个信令服务器,也就是一个socket链接用来发起视频通信,发送WebRTC中的 offer 和回复 answer 。
如何搭建一个简单的socket服务器,可以找我的这篇文章《》,也可以是用webSocket搭建信令服务器。

WebRTC需要打洞服务器(一个 stun ,一个 turn )来穿透防火墙等,我们需要配置打洞服务器:

WebRTC由于是未来的一种即时通信的标准,所以目前在Chrome、Firefox和Opera浏览器中有内置插件,均提供一个全局的PeerConnection类。

创建PeerConnection的对象:

创建时需要传入打洞服务器的配置信息,如果不穿入打洞服务器的配置信息,则只可以在内网中使用实时音频通讯。

由于PeerConnection是全局的,所以我们可以通过另外的一种方式进行创建:

如何判断浏览器是否支持WebRTC:

WebRTC也提供了一个全局单例来获取本地的音视频信息:

GetUserMedia需要传入三个参数,第一个参数为配置信息,第二个参数为获取成功的回调,第三个参数为获取失败的回调。
获取到视频流之后

创建一个offer并发送给指定的对象:

创建offer时要同时发送打洞服务器配置信息,WebRTC给了一个监听:

返回的参数中有一个 candidate 属性,便是打洞服务器的配置信息。

音频通话请求是通过socket发来的,需要通过socket去监听。

如果收到了offer,那么需要将offer存到自己的peerConnection中,并且创建一个answer发送回对方。
将offer存入peerConnection中:

创建一个answer并返回给对方:

如果收到了打洞服务器的配置信息,那么需要将打洞服务器的配置信息存入到 peerConnection 中:

发送给对方answer后便可以等待接受对方的数据流了:

至此,整个简单的WebRTC的流程就完成了


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zz/12750411.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-27
下一篇 2023-05-27

发表评论

登录后才能评论

评论列表(0条)

保存