jjzjj

MongoDB : Snapchat like notification schema for the database

coder 2023-10-30 原文

我已经对以下主题进行了一些研究,我想从更有经验的开发人员那里获得建议,看看我的解决方案是否是最好的。

如果您不知道 Snapchat 是什么,它是一款可让您与 friend 分享图片的移动应用程序。

我感兴趣的是应用程序的通知部分,用户可以在其中检查他是否收到了新图片。它看起来像这样:

我想做的是找到最好的方法来检查,当用户打开应用程序或刷新 View 时,他是否使用 MongoDB 收到了新的图像/消息。

经过一些研究,最好的解决方案是在我的 Mongo 数据库中拥有三个集合:

User : User_ID
       Username
       PasswordHash
       ...

其中 User_ID 是唯一的,由 MongoDB 生成

Messages: Message_ID
          Message_Content
          ...

Message_ID 是唯一的,由 MongoDB 生成。该集合可以存储其他信息,如图像 URL(存储在 BLOB 中的图像)等。

Notifications : Notification_ID
                Sender_ID
                Receiver_ID (index)
                Message_ID

其中 Notification_ID 是唯一的,由 MongoDB 生成。 Sender_ID 和 Receiver_ID 是 User 集合中的 User_ID。 Message_ID 来自 Messages 集合。 Receiver_ID 字段已编入索引。

因此,当用户启动或刷新 View 时,我查询集合 Notifications,并将字段 Receiver_ID(已编入索引)设置为实际的 User_ID 找到他可能收到的所有消息。如果他收到了消息,我查询Messages 集合,找到他收到的消息的所有信息(Message_ID 是上次查询得到的 Notifications).

之后,我删除集合Notifications 中的文档(如果他尚未打开消息,我将Message_ID 存储在设备本地) .

要将文档添加到通知消息 集合,在用户发送新消息时完成。

Notifications 集合中的字段 Receiver_ID 被索引以加快查询速度。如果我正确理解 MongoDB 的索引,写入操作会稍微慢一些,但读取速度要好得多。但可以肯定的是,Receiver_ID 索引将在新文档添加到集合 Notifications 时自动更新,否则我必须手动更新它?

这是解决这个问题的最佳方案还是有更好的方案?

编辑:我遇到了另一个问题: Receiver_ID 字段已编入索引,因此我可以更快地查询 Notifications 集合。这样做让我获得了 Message_ID,但在那之后,我需要查询 Messages 集合以检索有关该消息的所有信息。我是否还应该在集合消息中索引字段 Message_ID ,因为知道此集合将存储所有发送过的消息并且可能需要一些时间才能找到相应的消息? 或者字段 _id 是否由 Mongo 自动索引,所以我不需要这样做?

编辑 2:关于第二次编辑的问题,我发现我不需要为 Message_ID 编制索引,因为默认情况下所有 _id 都已编制索引。

MongoDB creates the _id index, which is an ascending unique index on the _id field, for all collections when the collection is created. You cannot remove the index on the _id field.

你可以了解更多here

感谢阅读!

以下是我在寻找解决方案时找到的一些链接:

Develop Database Schema for Notify like facebook

How to implement instant notification system using Express + Mongo Rest API?

Is it better to store notifications of all users under one collection / table OR rather provide each user his own collection / table to store notifications?

最佳答案

所提供的研究看起来令人印象深刻!

  1. 关于通知流程 - 看起来不错 - 但如果用户使用多个设备(平板电脑、手机等?) - 需要包括每个设备的设备 ID 和状态数组

  2. 索引一旦创建,将由数据库引擎维护

关于MongoDB : Snapchat like notification schema for the database,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35948933/

有关MongoDB : Snapchat like notification schema for the database的更多相关文章

  1. ruby-on-rails - 在一个 Rails 应用程序中使用 PostgreSQL 的 MongoDB - 2

    我可以在一个Rails应用程序中同时使用MongoDB和PostgreSQL吗?具体来说,我最终会想要使用像MongoHQ这样的东西。到目前为止,我未能在实验中进行这项工作。令我担心的是,MongoDB文档特别指出我必须禁用ActiveRecord。任何建议将不胜感激。 最佳答案 您无需禁用ActiveRecord即可使用MongoDB。查看Mongoid只需将gem加上任何模型与您现有的任何ActiveRecord模型一起添加。您应该注意到MongoHQ只是MongoDB的托管服务,可以与任何对象文档映射器(ODM)一起使用。更多

  2. ruby - 使用 mongodb/mongoid 运行时更改模型 - 2

    我必须在mongoid模型中添加几个字段,我知道MongoDB没有迁移,但如果我继续而不删除数据库,使rails完全“重新生成”数据库,它不会显示或使用新的领域!去这里最好的方法是什么?有比删除/重新打开mongodb更软的东西吗?提前致谢卢卡 最佳答案 一般来说,应该可以在运行时用新字段更新旧文档。MongoDB中不需要迁移。您可能想编写rake任务以使用新字段和默认值更新旧文档。您可以通过检查那些默认值为nil的新字段来找到这些文档。更新简单风格:如果您使用默认值定义一个新字段,只要您设置了一个新值,就应该始终使用该值:应用程序

  3. ruby-on-rails - 我如何从 Ruby 代码连接到 mongodb? - 2

    我如何从Ruby代码连接到mongodb? 最佳答案 首先,您必须安装MongoDbgem:geminstallmongo然后运行代码:require'rubygems'#notnecessaryforRuby1.9require'mongo'db=Mongo::Connection.new.db("mydb")#ORdb=Mongo::Connection.new("localhost").db("mydb")#ORdb=Mongo::Connection.new("localhost",27017).db("mydb")

  4. ruby - MongoDB:无法从 BSON 类型 EOO 转换为 Date - 2

    我正在尝试使用聚合框架(使用ruby​​)并像这样投影日期:db['requests'].aggregate([{"$project"=>{_id:0,method:'$method',user:'$user',year:{'$year'=>'$timestamp'}}}])文档是这样的:{_id:ObjectId("5177d7d7df26358289da7dfd"),timestamp:ISODate("2013-04-12T03:58:05+00:00"),method:"POST",status:"200",inputsize:"874",outputsize:"4981",u

  5. ruby - 在 Ruby 中从 MongoDB 中检索字段的子集 - 2

    我试图通过在Ruby中进行的查询从MongoDB获取字段的子集,但它似乎不起作用。它不返回任何结果这是ruby代码:coll.find("title"=>'Halo',:fields=>["title","isrc"])#thisdoesn'twork如果我删除字段散列,它会工作,返回包含所有字段的结果coll.find("title"=>'Halo')#thisworks查看mongodb控制台,第一个查询在mongodb服务器上结束,如下所示:{title:"Halo",fields:["title","isrc"]}如果我尝试从mongo客户端控制台进行查询,它会工作,我会得到结

  6. Elasticsearch和MongoDB对比 - 2

    文章目录Elasticsearch和MongoDB对比关于ElasticsearchElasticsearch应用场景关于MongoDBMongoDB优点mongodb适用场景Elasticsearch和MongoDB对比Elasticsearch和MongoDB开源许可协议参考Elasticsearch和MongoDB对比关于Elasticsearch官网:https://www.elastic.co/cn/elasticsearch/Elasticistheleadingplatformforsearch-poweredsolutions.Weaccelerateresultsthatma

  7. javascript - 类型错误 : mongodb property insertmany is not a function - 2

    db.col.insertMany([{"_id":"tt0084726","title":"StarTrekII:TheWrathofKhan","year":1982,"type":"movie"},{"_id":"tt0796366","title":"StarTrek","year":2009,"type":"movie"},{"_id":"tt0084726","title":"StarTrekII:TheWrathofKhan","year":1982,"type":"movie"}]);OS:LinuxMint17.3RosaMongoDB:dbversionv2.6.1

  8. javascript - 如何使用 javascript 中的 http.post 将图像发送到服务器并在 mongodb 中存储 base64 - 2

    我在使用mongodb在服务器端存储图像的客户端访问http请求时遇到了问题。我非常感谢帮助。我需要一个简单的示例来说明如何将图像文件作为数据添加到httppost请求(例如XMLhttprequest)中。比方说,我知道服务器方法的网址。图片来源定义在imgsrc文件名存放在name我有这个自动取款机:varhttp=newXMLHttpRequest();httpPost.onreadystatechange=function(err){if(httpPost.readyState==4&&httpPost.status==200){console.log(httpPost.res

  9. 【MongoDB】windows安装MongoDB6.0.5+可视化界面软件 - 2

    目录MongoDB简介安装MongoDB  安装MongoDBShell添加账户密码 安装MongoDBCompassMongoDB简介MongoDB是一个流行的开源文档型NoSQL数据库管理系统,使用C++语言编写。与传统的关系型数据库不同,MongoDB使用文档模型来存储数据。文档模型是一种灵活的数据模型,它允许您在单个文档中存储和查询相关数据。文档模型还支持嵌套文档和数组结构,这使得它非常适合处理复杂的数据结构。MongoDB的特点包括:非常灵活的文档模型,可以轻松存储复杂数据类型。分布式系统设计,可以通过分片技术实现横向扩展,适合大规模数据处理。支持丰富的查询语言和聚合框架,使得开发人

  10. Helm部署minio\nginx\mongodb\elasticsearch - 2

    minioappVersion:2022-06-25chartVersion:11.7.7一、独立模式auth:auth:rootPassword:"12345678rtt"#密码长度需>=8位rootUser:"root"mode:standalone#默认为单机模式persistence:storageClass:minio-data#存储类,必填size:8Giservice:type:NodePort#暴露端口port:9000nodePort:31311二、分布式模式auth:auth:rootPassword:"12345678rtt"#密码长度需>=8位rootUser:"roo

随机推荐