草庐IT

MySql vs NoSql - 社交网络评论和通知数据结构和实现

coder 2023-10-14 原文

我真的很难弄清楚社交网站(以 Facebook 为引用)如何管理用户的评论和通知。

他们实际上如何存储评论数据?还有如何存储通知并将其发送给所有用户。一个示例场景是,一位 friend 对我的状态发表评论,并且包括我在内的所有喜欢我的状态的人都会收到通知。此外,每个用户都有自己的已读/未读功能,所以我想每个用户都存储了一个通知引用。但是这样就会有很多通知信息的冗余。如果我们使用单独的表/集合来存储这些引用实际通知,那么这将产生实时可伸缩性问题。那么您将如何决定权衡哪种方式。当我想到这一切时,我的大脑崩溃了。太多的东西无法通过网络获得帮助。

现在如何将每个通知发送给所有应该接收通知的用户......以及数据结构如何。

我阅读了很多建议使用 MySql 的实现。我的理解是那种数据(大小),即为了可扩展性目的使用 NoSql 会更好。 那么 MySql 如何适用于此类用例,以及为什么不建议在任何地方使用像 Mongo 这样的 NoSql 来实现此类实现,而这些都意味着具有高度可扩展性。

嗯,很多题我都知道一个。但我并不是在这里寻找完整的答案,对特定事物的见解也会对我构建自己的应用程序有很大帮助。

最佳答案

这个问题非常广泛,但我会尽力回答。

How would they actually store the comments data? also how would a notification be stored and sent to all the users that.

我通常不喜欢回答这样的问题,因为看起来您在来到 SO 之前几乎没有做任何研究。您似乎也对应用程序和数据库角色感到困惑。我至少会先给你一些 Material /想法,然后让你自己决定。

后端设计没有“ Elixir ”,尤其是涉及到数据库时。 SQL 数据库通常非常擅长大多数数据库功能,这是理所当然的;这是一项非常成熟的技术,并且出于某种原因经受住了时间的考验。大多数 NOSQL 解决方案专门用于特定目的。例如:如果您要记录大量信息,您可能想看看 Cassandra。如果您要处理大量关系数据,您会希望使用 Neo4j(或用于 RMDBS 的 PostgreSQL/MySQL)之类的东西。如果您要处理大量实时数据,您可能想看看 Redis。

询问 NOSQL 与 SQL 的原因很愚蠢:

NOSQL 通常是一个不好的术语。这并不意味着“没有 SQL”。它的意思是“不仅仅是 SQL”。不幸的是,该术语甚至包含了与数据库最极端的对立面。

只有您知道应用程序的全部功能。即使我知道你想要达到的目标的基础知识,我仍然无法给你一个明确的答案。别人也不行。这是非常主观的,而且只有您才确切知道您的应用程序应该做什么。

最大的原因:现在是 2014 年。为什么是一个数据库?十年前,“DatabaseX vs DatabaseY”将是一个实际问题。现在,您可以在几分钟内配置许多应用程序框架以可靠地使用多个数据库。故事的寓意:将每个数据库用于其特定目的。有关多语言持久性的更多信息 here .

就 Facebook 而言:五分钟的 Google 搜索揭示了他们过去使用的后端技术,并且研究他们当前的一些后端解决方案并不难。你不是 Facebook 。您现在不需要为十亿用户做准备。从简单、成熟的技术开始。这将使您自然地扩展您的应用程序。当这些技术开始成为瓶颈时,请担心可扩展性。

我希望这对您开始编码之旅有所帮助,但如果您在编写代码时遇到问题,请将 Stack Overflow 作为最后的手段。不是立即前往。

关于MySql vs NoSql - 社交网络评论和通知数据结构和实现,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23442601/

有关MySql vs NoSql - 社交网络评论和通知数据结构和实现的更多相关文章

  1. ruby - 使用 ruby​​ 将 HTML 转换为纯文本并维护结构/格式 - 2

    我想将html转换为纯文本。不过,我不想只删除标签,我想智能地保留尽可能多的格式。为插入换行符标签,检测段落并格式化它们等。输入非常简单,通常是格式良好的html(不是整个文档,只是一堆内容,通常没有anchor或图像)。我可以将几个正则表达式放在一起,让我达到80%,但我认为可能有一些现有的解决方案更智能。 最佳答案 首先,不要尝试为此使用正则表达式。很有可能你会想出一个脆弱/脆弱的解决方案,它会随着HTML的变化而崩溃,或者很难管理和维护。您可以使用Nokogiri快速解析HTML并提取文本:require'nokogiri'h

  2. ruby-on-rails - Rails 常用字符串(用于通知和错误信息等) - 2

    大约一年前,我决定确保每个包含非唯一文本的Flash通知都将从模块中的方法中获取文本。我这样做的最初原因是为了避免一遍又一遍地输入相同的字符串。如果我想更改措辞,我可以在一个地方轻松完成,而且一遍又一遍地重复同一件事而出现拼写错误的可能性也会降低。我最终得到的是这样的:moduleMessagesdefformat_error_messages(errors)errors.map{|attribute,message|"Error:#{attribute.to_s.titleize}#{message}."}enddeferror_message_could_not_find(obje

  3. ruby - 解析 RDFa、微数据等的最佳方式是什么,使用统一的模式/词汇(例如 schema.org)存储和显示信息 - 2

    我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i

  4. ruby - Ruby 有 `Pair` 数据类型吗? - 2

    有时我需要处理键/值数据。我不喜欢使用数组,因为它们在大小上没有限制(很容易不小心添加超过2个项目,而且您最终需要稍后验证大小)。此外,0和1的索引变成了魔数(MagicNumber),并且在传达含义方面做得很差(“当我说0时,我的意思是head...”)。散列也不合适,因为可能会不小心添加额外的条目。我写了下面的类来解决这个问题:classPairattr_accessor:head,:taildefinitialize(h,t)@head,@tail=h,tendend它工作得很好并且解决了问题,但我很想知道:Ruby标准库是否已经带有这样一个类? 最佳

  5. ruby - 用 Ruby 编写一个简单的网络服务器 - 2

    我想在Ruby中创建一个用于开发目的的极其简单的Web服务器(不,不想使用现成的解决方案)。代码如下:#!/usr/bin/rubyrequire'socket'server=TCPServer.new('127.0.0.1',8080)whileconnection=server.acceptheaders=[]length=0whileline=connection.getsheaders想法是从命令行运行这个脚本,提供另一个脚本,它将在其标准输入上获取请求,并在其标准输出上返回完整的响应。到目前为止一切顺利,但事实证明这真的很脆弱,因为它在第二个请求上中断并出现错误:/usr/b

  6. ruby-on-rails - 简单的 Ruby on Rails 问题——如何将评论附加到用户和文章? - 2

    我意识到这可能是一个非常基本的问题,但我现在已经花了几天时间回过头来解决这个问题,但出于某种原因,Google就是没有帮助我。(我认为部分问题在于我是一个初学者,我不知道该问什么......)我也看过O'Reilly的RubyCookbook和RailsAPI,但我仍然停留在这个问题上.我找到了一些关于多态关系的信息,但它似乎不是我需要的(尽管如果我错了请告诉我)。我正在尝试调整MichaelHartl'stutorial创建一个包含用户、文章和评论的博客应用程序(不使用脚手架)。我希望评论既属于用户又属于文章。我的主要问题是:我不知道如何将当前文章的ID放入评论Controller。

  7. ruby - 是否有用于序列化和反序列化各种格式的对象层次结构的模式? - 2

    给定一个复杂的对象层次结构,幸运的是它不包含循环引用,我如何实现支持各种格式的序列化?我不是来讨论实际实现的。相反,我正在寻找可能会派上用场的设计模式提示。更准确地说:我正在使用Ruby,我想解析XML和JSON数据以构建复杂的对象层次结构。此外,应该可以将该层次结构序列化为JSON、XML和可能的HTML。我可以为此使用Builder模式吗?在任何提到的情况下,我都有某种结构化数据-无论是在内存中还是文本中-我想用它来构建其他东西。我认为将序列化逻辑与实际业务逻辑分开会很好,这样我以后就可以轻松支持多种XML格式。 最佳答案 我最

  8. ruby - 我如何添加二进制数据来遏制 POST - 2

    我正在尝试使用Curbgem执行以下POST以解析云curl-XPOST\-H"X-Parse-Application-Id:PARSE_APP_ID"\-H"X-Parse-REST-API-Key:PARSE_API_KEY"\-H"Content-Type:image/jpeg"\--data-binary'@myPicture.jpg'\https://api.parse.com/1/files/pic.jpg用这个:curl=Curl::Easy.new("https://api.parse.com/1/files/lion.jpg")curl.multipart_form_

  9. 世界前沿3D开发引擎HOOPS全面讲解——集3D数据读取、3D图形渲染、3D数据发布于一体的全新3D应用开发工具 - 2

    无论您是想搭建桌面端、WEB端或者移动端APP应用,HOOPSPlatform组件都可以为您提供弹性的3D集成架构,同时,由工业领域3D技术专家组成的HOOPS技术团队也能为您提供技术支持服务。如果您的客户期望有一种在多个平台(桌面/WEB/APP,而且某些客户端是“瘦”客户端)快速、方便地将数据接入到3D应用系统的解决方案,并且当访问数据时,在各个平台上的性能和用户体验保持一致,HOOPSPlatform将帮助您完成。利用HOOPSPlatform,您可以开发在任何环境下的3D基础应用架构。HOOPSPlatform可以帮您打造3D创新型产品,HOOPSSDK包含的技术有:快速且准确的CAD

  10. ruby-on-rails - 如何在发布新的 Ruby 或 Rails 版本时收到通知? - 2

    有人知道在发布新版本的Ruby和Rails时收到电子邮件的方法吗?他们有邮件列表,RubyonRails有一个推特,但我不想听到那些随之而来的喧嚣,我只想知道什么时候发布新版本,尤其是那些有安全修复的版本。 最佳答案 从therailsblog获取提要.http://weblog.rubyonrails.org/feed/atom.xml 关于ruby-on-rails-如何在发布新的Ruby或Rails版本时收到通知?,我们在StackOverflow上找到一个类似的问题:

随机推荐