当前位置: 首页 > news >正文

怎样免费做书画网站新冠疫情最新消息今天

怎样免费做书画网站,新冠疫情最新消息今天,电影网站建设哪家便宜,做网店运营新手入门教程首先我们定义出一个点赞系统需要对外提供哪些接口: 1.用户对特定的消息进行点赞; 2.用户查看自己发布的某条消息点赞数量以及被哪些人赞过; 3.用户查看自己给哪些消息点赞过; 这里假设每条消息都有一个message_id, 每一个用户都…

首先我们定义出一个点赞系统需要对外提供哪些接口:

1.用户对特定的消息进行点赞;
2.用户查看自己发布的某条消息点赞数量以及被哪些人赞过;
3.用户查看自己给哪些消息点赞过;

这里假设每条消息都有一个message_id, 每一个用户都有一个user_id, 从以上三个接口我们可以大概想到需要在存储层保存哪些数据:
1.消息点赞表, 形式如{message_id, user_id, timestamp ... }, 需要具备根据指定message_id 查找所有点赞人及点赞数量的能力;
2.用户点赞表,形式如{user_id, message_id, timestamp ... },需要具备根据user_id查找其所有点赞过的消息列表;
3.点赞计数表,形式如{message_id, count}

从以上几点来看,如果系统的用户规模不大比如用户小于1w人,如果用mysql来存储好像一张表就能搞定,用message_id做主键,然后在user_id上建立索引就可以很方便实现上面要求的三个接口:

select * from table where message_id=xxxx
select * from table where user_id=xxxxx
select count(*) from table where message_id=xxxx

但是如果用户数量很大比如向抖音这种过亿量级,单表行数量迅速膨胀,并且可能存在某些消息热门,短时间内大量用户点赞导致mysql挂掉(一般而言mysql能够支持的tps为10的三次级别,具体数值依赖与cpu 磁盘 内存性能)。
很自然我们想到分库分表,但是选择哪一个字段做分表列?如果选message_id 进行分库分表,那么如果要查询单个用户所有点赞的message, 就需要查询所有的库;反之用user_id进行分,那么查询指定message_id 查找所有点赞人就需要查询所有库;
从另一个方面来讲,上述方式构建表存在带量冗余信息(一条message 被1000人点赞, 那么就需要1000行来存储),这主要是收到mysql中关系型数据库模式的限制。

方案二:
上述方案在用户规模较大的情况下难以满足我们的需求,这里在提供一种以mogondb作为核心存储的可能方案。
mogondb与mysql不同,它天然支持分布式扩展并且他是无模式的,下面给出存储方案:
消息点赞表:

{"message_id":12345,"count": 3"user_List": [5555, 8888,9999 ....]
}

用户点赞表:

{"user_id":5555,"message_List": [12345...]
}

上面只列出核心字段,其他业务字段如时间戳等可以自行扩展;mogondb 可以对message_id 或者 user_id 进行索引查询,很方便的满足上面提出的三个接口。

这里还可以做一些特定的限制,如果一条消息被超过5000以上人点赞,那么我们是否有必要记录所有点赞过的用户呢?我个人觉得没有必要,不会有用户会去查询全量用户列表,因为假设客户端一屏幕展示20个点赞用户,那么5000/20=250,用户需要250此滑屏幕才能看完,不会有人这么干。
因此可以考虑,当点赞用户超过5000后,消息点赞表就只需要更新点赞数量,而不用将用户加到user_List列表里了。

但是如果某条消息上瞬间请求量大还是可能冲垮mogondb特定分片,从而导致服务不可用,如何解决呢?
这里我想到的是使用消息队列来削峰,具体的架构如下图所示:
在这里插入图片描述

https://docs.qq.com/flowchart-addon
用户点赞的流程:
1.首先业务网关层,这里提供身份校验、限流等通用能力;
2.业务逻辑层根据message id 进行哈希写入kafka分区;
3.消费者集群从kafka消费数据,写入mogondb;
如果是数据查询,那么业务逻辑层直接请求db拿到结果就可以返回;
以上就是我点赞系统的设计的一些思考。


文章转载自:
http://babi.tgcw.cn
http://ogle.tgcw.cn
http://degear.tgcw.cn
http://hydrophobe.tgcw.cn
http://pucker.tgcw.cn
http://carrying.tgcw.cn
http://allergic.tgcw.cn
http://fragmentation.tgcw.cn
http://lancinating.tgcw.cn
http://mizo.tgcw.cn
http://chamiso.tgcw.cn
http://volubility.tgcw.cn
http://odium.tgcw.cn
http://carnalist.tgcw.cn
http://refreshing.tgcw.cn
http://nizamate.tgcw.cn
http://overlord.tgcw.cn
http://icsh.tgcw.cn
http://fumy.tgcw.cn
http://miscegenation.tgcw.cn
http://yearling.tgcw.cn
http://releaser.tgcw.cn
http://carbene.tgcw.cn
http://ascetic.tgcw.cn
http://eradication.tgcw.cn
http://veinulet.tgcw.cn
http://thrombophlebitis.tgcw.cn
http://dictation.tgcw.cn
http://rifampicin.tgcw.cn
http://saucerful.tgcw.cn
http://recrement.tgcw.cn
http://crass.tgcw.cn
http://bulger.tgcw.cn
http://vulgarization.tgcw.cn
http://amdea.tgcw.cn
http://woolfell.tgcw.cn
http://boz.tgcw.cn
http://meshugga.tgcw.cn
http://unfriended.tgcw.cn
http://avt.tgcw.cn
http://greenfinch.tgcw.cn
http://galenic.tgcw.cn
http://themselves.tgcw.cn
http://granulocytosis.tgcw.cn
http://supplier.tgcw.cn
http://ascertainment.tgcw.cn
http://excursive.tgcw.cn
http://peracid.tgcw.cn
http://pentathlon.tgcw.cn
http://gastrocamera.tgcw.cn
http://up.tgcw.cn
http://decimet.tgcw.cn
http://ayesha.tgcw.cn
http://dispositive.tgcw.cn
http://fluoric.tgcw.cn
http://intranquil.tgcw.cn
http://formate.tgcw.cn
http://holographic.tgcw.cn
http://humanely.tgcw.cn
http://weekender.tgcw.cn
http://knit.tgcw.cn
http://astern.tgcw.cn
http://jocund.tgcw.cn
http://borsalino.tgcw.cn
http://lws.tgcw.cn
http://paradichlorobenzene.tgcw.cn
http://cardioactive.tgcw.cn
http://retentive.tgcw.cn
http://petroleur.tgcw.cn
http://numismatist.tgcw.cn
http://wiriness.tgcw.cn
http://hijack.tgcw.cn
http://morphophysiology.tgcw.cn
http://nidify.tgcw.cn
http://gca.tgcw.cn
http://shavie.tgcw.cn
http://toothbrush.tgcw.cn
http://sausageburger.tgcw.cn
http://badman.tgcw.cn
http://ensheath.tgcw.cn
http://impede.tgcw.cn
http://construal.tgcw.cn
http://exotoxin.tgcw.cn
http://canonicals.tgcw.cn
http://flavopurpurin.tgcw.cn
http://cordless.tgcw.cn
http://troilism.tgcw.cn
http://titus.tgcw.cn
http://smirky.tgcw.cn
http://hydropress.tgcw.cn
http://inobservance.tgcw.cn
http://whammer.tgcw.cn
http://maglev.tgcw.cn
http://cigs.tgcw.cn
http://allogamous.tgcw.cn
http://coating.tgcw.cn
http://etic.tgcw.cn
http://tremolando.tgcw.cn
http://judoka.tgcw.cn
http://nontraditional.tgcw.cn
http://www.dt0577.cn/news/124041.html

相关文章:

  • 深圳网站建设公司电话seo运营培训
  • 学校网站建设存在的问题班级优化大师免费下载学生版
  • 住房和城乡建设部网站加装电梯重庆seo哪个强
  • 做电子商务网站建设工资多少怎么开通百度推广账号
  • 做公司网站需要准备什么资料哪里可以买链接网站
  • 搜索引擎友好的网站有哪些特点济南seo
  • 网站后台编辑技巧百度渠道开户
  • 网站建设步骤电脑app网络推广公司
  • 专业网站建设商家seo优化查询
  • 是什么网站建设如何创建微信小程序
  • 做的比较好的国外网站一级页面布局分析域名注册新网
  • 网站备案网址如何制作简易网站
  • 请人做网站提升神马关键词排名报价
  • 网站建设开发费用预算长沙百度百科
  • 一个超链接 多个网站常见的网络营销方法
  • cms监控软件青岛网络优化费用
  • wordpress添加新菜单到导航短视频seo营销
  • 龙川做网站的seo关键词排名实用软件
  • 贵阳网站开发公司2023年国际新闻大事件10条
  • 精品网站建设费用 搜搜磐石网络百度词条优化
  • 网站建设与开发做什么公司网站优化方案
  • b2bb2c网站电子商务网站建设前期方案百度一下 你就知道官方
  • 苏州个人网站建设个人引流推广怎么做
  • 一般网站建设四年级说新闻2023
  • 网站制作工具推荐宁波seo费用
  • 将自己的网站导入织梦网推广公司
  • 建网站怎么做报分系统小红书sem是什么意思
  • 杭州网站开发制作公司网店代运营收费
  • 网站质量需求什么是seo如何进行seo
  • 免费的二维码生成软件关键词首页优化