微博2面:微信朋友圈是怎么实现的?


点击上方蓝字关注趣学程序!

来源:r6d.cn/E8pb

差不多十年前,随着功能机的淘汰和智能机的普及,互联网开始进入移动互联网时代,最具代表性的产品就是微博、微信,以及后来的今日头条、快手等。这些移动化联网时代的新产品在过去几年间借着智能手机的风高速成长。


# 简介

差不多十年前,随着功能机的淘汰和智能机的普及,互联网开始进入移动互联网时代,最具代表性的产品就是微博、微信,以及后来的今日头条、快手等。这些移动化联网时代的新产品在过去几年间借着智能手机的风高速成长。

这些产品都是Feed流类型产品,由于Feed流一般是按照时间“从上往下流动”,非常适合在移动设备端浏览,最终这一类应用就脱颖而出,迅速抢占了上一代产品的市场空间。

Feed流是Feed + 流,Feed的本意是饲料,Feed流的本意就是有人一直在往一个地方投递新鲜的饲料,如果需要饲料,只需要盯着投递点就可以了,这样就能源源不断获取到新鲜的饲料。在信息学里面,Feed其实是一个信息单元,比如一条朋友圈状态、一条微博、一条咨询或一条短视频等,所以Feed流就是不停更新的信息单元,只要关注某些发布者就能获取到源源不断的新鲜信息,我们的用户也就可以在移动设备上逐条去浏览这些信息单元。

当前最流行的Feed流产品有微博、微信朋友圈、头条的资讯推荐、快手抖音的视频推荐等,还有一些变种,比如私信、通知等,这些系统都是Feed流系统,接下来我们会介绍如何设计一个Feed流系统架构。

# Feed流系统特点

Feed流本质上是一个数据流,是将 “N个发布者的信息单元” 通过 “关注关系” 传送给 “M个接收者”。

Feed流系统是一个数据流系统,所以我们核心要看数据。从数据层面看,数据分为三类,分别是:

  • 发布者的数据:发布者产生数据,然后数据需要按照发布者组织,需要根据发布者查到所有数据,比如微博的个人页面、朋友圈的个人相册等。

  • 关注关系:系统中个体间的关系,微博中是关注,是单向流,朋友圈是好友,是双向流。不管是单向还是双向,当发布者发布一条信息时,该条信息的流动永远是单向的。

  • 接收者的数据:从不同发布者那里获取到的数据,然后通过某种顺序(一般为时间)组织在一起,比如微博的首页、朋友圈首页等。这些数据具有时间热度属性,越新的数据越有价值,越新的数据就要排在最前面。

针对这三类数据,我们可以有如下定义:

  • 存储库:存储发布者的数据,永久保存。

  • 关注表:用户关系表,永久保存。

  • 同步库:存储接收者的时间热度数据,只需要保留最近一段时间的数据即可。

设计Feed流系统时最核心的是确定清楚产品层面的定义,需要考虑的因素包括:

  • 产品用户规模:用户规模在十万、千万、十亿级时,设计难度和侧重点会不同。

  • 关注关系(单向、双写):如果是双向,那么就不会有大V,否则会有大V存在。上述是选择数据存储系统最核心的几个考虑点,除此之外,还有一些需要考虑的:

  • 如何实现Meta和Feed内容搜索?

    • 虽然Feed流系统本身可以不需要搜索,但是一个Feed流产品必须要有搜索,否则信息发现难度会加大,用户留存率会大幅下降。

  • Feed流的顺序是时间还是其他分数,比如个人的喜好程度?

    • 双向关系时由于关系很紧密,一定是按时间排序,就算一个关系很紧密的人发了一条空消息或者低价值消息,那我们也会需要关注了解的。

    • 单向关系时,那么可能就会存在大V,大V的粉丝数量理论极限就是整个系统的用户数,有一些产品会让所有用户都默认关注产品负责人,这种产品中,该负责人就是最大的大V,粉丝数就是用户规模。接下来,我们看看整个Feed流系统如何设计。


# Feed流系统设计

上一节,我们提前思考了Feed流系统的几个关键点,接下来,在这一节,我们自顶向下来设计一个Feed流系统。

1. 产品定义

第一步,我们首先需要定义产品,我们要做的产品是哪一种类型,常见的类型有:

  • 微博类

  • 朋友圈类

  • 抖音类

  • 私信类

接着,再详细看一下这几类产品的异同:

类型关注关系是否有大V时效性排序
微博类单向秒~分时间
抖音类单向/无秒~分推荐
朋友圈类双向时间
私信类双向时间

上述对比中,只对比各类产品最核心、或者最根本特点,其他次要的不考虑。比如微博中互相关注后就是双向关注了,但是这个不是微博的立命之本,只是补充,无法撼动根本。

从上面表格可以看出来,主要分为两种区分:

  • 关注关系是单向还是双向:

    • 如果是单向,那么可能就会存在大V效应,同时时效性可以低一些,比如到分钟级别;

    • 如果是双向,那就是好友,好友的数量有限,那么就不会有大V,因为每个人的精力有限,他不可能主动加几千万的好友,这时候因为关系更精密,时效性要求会更高,需要都秒级别。

  • 排序是时间还是推荐:

    • 用户对feed流最容易接受的就是时间,目前大部分都是时间。

    • 但是有一些场景,是从全网数据里面根据用户的喜好给用户推荐和用户喜好度最匹配的内容,这个时候就需要用推荐了,这种情况一般也会省略掉关注了,相对于关注了全网所有用户,比如抖音、头条等。确定了产品类型后,还需要继续确定的是系统设计目标:需要支持的最大用户数是多少?十万、百万、千万还是亿?

用户数很少的时候,就比较简单,这里我们主要考虑 亿级用户 的情况,因为如果系统能支持亿级,那么其他量级也能支持。为了支持亿级规模的用户,主要子系统选型时需要考虑水平扩展能力以及一些子系统的可用性和可靠性了,因为系统大了后,任何一个子系统的不稳定都很容易波及整个系统。

2. 存储

我们先来看看最重要的存储,不管是哪种同步模式,在存储上都是一样的,我们定义用户消息的存储为存储库。存储库主要满足三个需求:

  • 可靠存储用户发送的消息,不能丢失。否则就找不到自己曾经发布到朋友圈状态了。

  • 读取某个人发布过的所有消息,比如个人主页等。

  • 数据永久保存。

所以,存储库最重要的特征就是两点:

  • 数据可靠、不丢失。

  • 由于数据要永久保存,数据会一直增长,所以要易于水平扩展。

综上,可以选为存储库的系统大概有两类:

特点分布式NoSQL关系型数据库(分库分表)
可靠性极高
水平扩展能力线性需要改造
水平扩展速度毫秒
常见系统Tablestore、BigtableMySQL、PostgreSQL

  • 对于可靠性,分布式NoSQL的可靠性要高于关系型数据库,这个可能有违很多人的认知。主要是关系型数据库发展很长时间了,且很成熟了,数据放在上面大家放心,而分布式NoSQL数据库发展晚,使用的并不多,不太信任。但是,分布式NoSQL需要存储的数据量更多,对数据可靠性的要求也加严格,所以一般都是存储三份,可靠性会更高。目前在一些云厂商中的关系型数据库因为采用了和分布式NoSQL类似的方式,所以可靠性也得到了大幅提高。

  • 水平扩展能力:对于分布式NoSQL数据库,数据天然是分布在多台机器上,当一台机器上的数据量增大后,可以通过自动分裂两部分,然后将其中一半的数据迁移到另一台机器上去,这样就做到了线性扩展。而关系型数据库需要在扩容时再次分库分表。

所以,结论是:

  • 如果是自建系统,且不具备分布式NoSQL数据库运维能力,且数据规模不大,那么可以使用MySQL,这样可以撑一段时间。

  • 如果是基于云服务,那么就用分布式NoSQL,比如Tablestore或Bigtable。

  • 如果数据规模很大,那么也要用分布式NoSQL,否则就是走上一条不归路。

如果使用Tablestore,那么存储库表设计结构如下:

主键列第一列主键第二列主键属性列属性列
列名user_idmessage_idcontentother
解释消息发送者用户ID消息顺序ID,可以使用timestamp。内容其他内容

到此,我们确定了存储库的选型,那么系统架构的轮廓有了:


3. 同步

系统规模和产品类型,以及存储系统确定后,我们可以确定同步方式,常见的方式有三种:

  • 推模式(也叫写扩散):和名字一样,就是一种推的方式,发送者发送了一个消息后,立即将这个消息推送给接收者,但是接收者此时不一定在线,那么就需要有一个地方存储这个数据,这个存储的地方我们称为:同步库。推模式也叫写扩散的原因是,一个消息需要发送个多个粉丝,那么这条消息就会复制多份,写放大,所以也叫写扩散。这种模式下,对同步库的要求就是写入能力极强和稳定。读取的时候因为消息已经发到接收者的收件箱了,只需要读一次自己的收件箱即可,读请求的量极小,所以对读的QPS需求不大。归纳下,推模式中对同步库的要求只有一个:写入能力强。

  • 拉模式(也叫读扩散):这种是一种拉的方式,发送者发送了一条消息后,这条消息不会立即推送给粉丝,而是写入自己的发件箱,当粉丝上线后再去自己关注者的发件箱里面去读取,一条消息的写入只有一次,但是读取最多会和粉丝数一样,读会放大,所以也叫读扩散。拉模式的读写比例刚好和写扩散相反,那么对系统的要求是:读取能力强。另外这里还有一个误区,很多人在最开始设计feed流系统时,首先想到的是拉模式,因为这种和用户的使用体感是一样的,但是在系统设计上这种方式有不少痛点,最大的是每个粉丝需要记录自己上次读到了关注者的哪条消息,如果有1000个关注者,那么这个人需要记录1000个位置信息,这个量和关注量成正比的,远比用户数要大的多,这里要特别注意,虽然在产品前期数据量少的时候这种方式可以应付,但是量大了后就会事倍功半,得不偿失,切记切记。

  • 推拉结合模式:推模式在单向关系中,因为存在大V,那么一条消息可能会扩散几百万次,但是这些用户中可能有一半多是僵尸,永远不会上线,那么就存在资源浪费。而拉模式下,在系统架构上会很复杂,同时需要记录的位置信息是天量,不好解决,尤其是用户量多了后会成为第一个故障点。基于此,所以有了推拉结合模式,大部分用户的消息都是写扩散,只有大V是读扩散,这样既控制了资源浪费,又减少了系统设计复杂度。但是整体设计复杂度还是要比推模式复杂。

用图表对比:

类型推模式拉模式推拉结合模式
写放大
读放大
用户读取延时毫秒
读写比例1:9999:1~50:50
系统要求写能力强读能力强读写都适中
常见系统Tablestore、Bigtable等LSM架构的分布式NoSQLRedis、memcache等缓存系统或搜索系统(推荐排序场景)两者结合
架构复杂度简单复杂更复杂

介绍完同步模式中所有场景和模式后,我们归纳下:

  • 如果产品中是双向关系,那么就采用推模式。

  • 如果产品中是单向关系,且用户数少于1000万,那么也采用推模式,足够了。

  • 如果产品是单向关系,单用户数大于1000万,那么采用推拉结合模式,这时候可以从推模式演进过来,不需要额外重新推翻重做。

  • 永远不要只用拉模式。

  • 如果是一个初创企业,先用推模式,快速把系统设计出来,然后让产品去验证、迭代,等客户数大幅上涨到1000万后,再考虑升级为推拉集合模式。

  • 如果是按推荐排序,那么是另外的考虑了,架构会完全不一样,这个后面专门文章介绍。

如果选择了Tablestore,那么同步库表设计结构如下:

确定了同步库的架构如下:

4. 元数据

前面介绍了同步和存储后,整个Feed流系统的基础功能完成了,但是对于一个完整Feed流产品而言,还缺元数据部分,接下来,我们看元数据如何处理:

Feed流系统中的元数据主要包括:

  • 用户详情和列表。

  • 关注或好友关系。

  • 推送session池。

我们接下来逐一来看。

4.1 用户详情和列表

主要是用户的详情,包括用户的各种自定义属性和系统附加的属性,这部分的要求只需要根据用户ID查询到就可以了。

可以采用的分布式NoSQL系统或者关系型数据库都可以。

如果使用NoSQL数据库Tablestore,那么用户详情表设计结构如下:

主键顺序第一列主键属性列-1属性列-2......
字段名user_idnick_namegenderother
备注主键列,用于唯一确定一个用户用户昵称,用户自定义属性用户性别,用户自定义属性其他属性,包括用户自定义属性列和系统附加属性列。Tablestore是FreeSchema类型的,可以随时在任何一行增加新列而不影响原有数据。


4.2 关注或好友关系

这部分是存储关系,查询的时候需要支持查询关注列表或者粉丝列表,或者直接好友列表,这里就需要根据多个属性列查询需要索引能力,这里,存储系统也可以采用两类,关系型、分布式NoSQL数据库。

  • 如果已经有了关系型数据库了,且数据量较少,则选择关系型数据库,比如MySQL等。

  • 如果数据量比较大,这个时候就有两种选择:

  1. 使用具有索引的系统,比如云上的Tablestore,更简单,吞吐更高,扩容能力也一并解决了。

  1. 需要分布式事务,可以采用支持分布式事务的系统,比如分布式关系型数据库。

如果使用Tablestore,那么关注关系表设计结构如下:

Table:user_relation_table

主键顺序第一列主键第一列主键属性列属性列
Table字段名user_idfollow_user_idtimestampother
备注用户ID粉丝用户ID关注时间其他属性列

多元索引的索引结构:

Table字段名user_idfollow_user_idtimestamp
是否Index
是否enableSortAndAgg
是否store

查询的时候:

  • 如果需要查询某个人的粉丝列表:使用TermQuery查询固定user_id,且按照timestamp排序。

  • 如果需要查询某个人的关注列表:使用TermQuery查询固定follow_user_id,且按照timestamp排序。

  • 当前数据写入Table后,需要5~10秒钟延迟后会在多元索引中查询到,未来会优化到2秒以内。

除了使用多元索引外,还可以使用GlobalIndex。


4.3 推送session池

思考一个问题,发送者将消息发送后,接收者如何知道自己有新消息来了?客户端周期性去刷新?如果是这样子,那么系统的读请求压力会随着客户端增长而增长,这时候就会有一个风险,比如平时的设备在线率是20%~30%,突然某天平台爆发了一个热点消息,大量休眠设备登陆,这个时候就会出现“查询风暴”,一下子就把系统打垮了,所有的用户都不能用了。

解决这个问题的一个思路是,在服务端维护一个推送session池,这个里面记录哪些用户在线,然后当用户A发送了一条消息给用户B后,服务端在写入存储库和同步库后,再通知一下session池中的用户B的session,告诉他:你有新消息了。然后session-B再去读消息,然后有消息后将消息推送给客户端。或者有消息后给客户端推送一下有消息了,客户端再去拉。

这个session池使用在同步中,但是本质还是一个元数据,一般只需要存在于内存中即可,但是考虑到failover情况,那就需要持久化,这部分数据由于只需要指定单Key查询,用分布式NoSQL或关系型数据库都可以,一般复用当前的系统即可。

如果使用Tablestore,那么session表设计结构如下:

主键列顺序第一列主键第二列主键属性列
列名user_iddevice_idlast_sequence_id
备注接收者用户ID设备ID,同一个用户可能会有多个设备,不同设备的读取位置可能不一致,所以这里需要一个设备ID。如果不需要支持多终端,则这一列可以省略。该接收者已经推送给客户端的最新的顺序ID


5. 评论

除了私信类型外,其他的feed流类型中,都有评论功能,评论的属性和存储库差不多,但是多了一层关系:被评论的消息,所以只要将评论按照被被评论消息分组组织即可,然后查询时也是一个范围查询就行。这种查询方式很简单,用不到关系型数据库中复杂的事务、join等功能,很适合用分布式NoSQL数据库来存储。

所以,一般的选择方式就是:

  • 如果系统中已经有了分布式NoSQL数据库,比如Tablestore、Bigtable等,那么直接用这些即可。

  • 如果没有上述系统,那么如果有MySQL等关系型数据库,那就选关系型数据库即可。

  • 如果选择了Tablestore,那么“评论表”设计结构如下:

主键列顺序第一列主键第二列主键属性列属性列属性列
字段名message_idcomment_idcomment_contentreply_toother
备注微博ID或朋友圈ID等消息的ID这一条评论的ID评论内容回复给哪个用户其他

如果需要搜索评论内容,那么对这张表建立多元索引即可。


6. 赞

最近几年,“赞”或“like”功能很流行,赞功能的实现和评论类似,只是比评论少了一个内容,所以选择方式和评论一样。

如果选择了Tablestore,那么“赞表”设计结构同评论表,这里就不再赘述了。

系统架构中加了元数据系统后的架构如下:


7. 搜索

到此,我们已经介绍完了Feed流系统的主题架构,Feed流系统算是完成了。但是Feed流产品上还未结束,对于所有的feed流产品都需要有搜索能力,比如下面场景:

  • 微博中的搜索用户。

  • 搜索微博内容。

  • 微信中搜索好友等。

这些内容搜索只需要字符匹配到即可,不需要非常复杂的相关性算法,所以只需要有能支持分词的检索功能即可,所以一般有两种做法:

使用搜索引擎,将存储库的内容和用户信息表内容推送给搜索系统,搜索的时候直接访问搜索系统。使用具备全文检索能力的数据库,比如最新版的MySQL、MongoDB或者Tablestore。

所以,选择的原则如下:

  • 如果存储库使用了MySQL或者Tablestore,那么直接选择这两个系统就可以了。

  • 如果整个系统都没使用MySQL、Tablestore,且已经使用了搜索系统,那么可以直接复用搜索系统,其他场景都不应该再额外加一个搜索系统进来,徒添复杂度。

如果使用Tablestore,那么只需要在相应表上建立多元索引即可:

  • 如果需要对用户名支持搜索,那么需要对user_table建立多元索引,其中的nick_name需要是Text类型,且单字分词。

  • 如果需要对Feed流内容支持搜索,那么需要对存储库表:store_table建立多元索引,这样就能直接对Feed流内容进行各种复杂查询了,包括多条件筛选、全文检索等。

系统架构中加了搜索功能后的架构如下:

8. 排序

目前的Feed流系统中的排序方式有两种,一种是时间,一种是分数。

我们常用的微博、朋友圈、私信这些都是时间线类型的,因为这些产品定义中,需要我们主动关注某些人后才会看到这些人发表的内容,这个时候,最重要的是实时性,而不是发布质量,就算关注人发布了一条垃圾信息,我们也会被动看到。这种类型的产品适用于按照时间线排序。这一篇我们介绍的架构都是基于时间类型的。

另外一种是不需要关注任何人,我们能看到的都是系统希望我们看到的,系统在后台会分析我们的每个人的爱好,然后给每个人推送差异化的、各自喜欢的内容,这一种的架构和基于时间的完全不一样,我们在后续的推荐类型中专门介绍。

9. 删除Feed内容

在Feed流应用中有一个问题,就是如果用户删除了之前发表的内容,系统该如何处理?因为系统里面有写扩散,那么删除的时候是不是也要写扩散一遍?这样的话,删除就不及时了,很难应对法律法规要求的快速删除。

针对这个问题,我们在之前设计的时候,同步表中只有消息ID,没有消息内容,在用户读取的时候需要到存储库中去读消息内容,那么我们可以直接删除存储库中的这一条消息,这样用户读取的时候使用消息ID是读不到数据的,也就相当于删除的内容,而且删除速度会很快。除了直接删除外,另外一种办法是逻辑删除,对于删除的feed内容,只做标记,当查询到带有标记的数据时就认为删除了。

10. 更新Feed内容

更新和删除Feed处理逻辑一样,如果使用了支持多版本的存储系统,比如Tablestore,那么也可以支持编辑版本,和现在的微博一样。

11. 总结

上面介绍了不同子功能的特点和系统要求,能满足需求的系统主要有两类,一类是阿里云的Tablestore单系统,一类是开源组件组成的组合系统。

  • 开源组件组成的组合系统:包括MySQL、Redis、HBase等,这些系统单个都不能解决Feed流系统中遇到的问题,需要组合在一起,各司其职才能完成一个Feed流系统,适用于热衷开源系统,人多且喜欢运维操作的团队。

  • Tablestore单系统:只使用Tablestore单个系统就能解决上述的所有问题,这时候肯定有人要问?你是不是在吹牛?这里不是吹牛,Tablestore在三年前就已经开始重视Feed流类型业务,之前也发表过多篇文章介绍,功能上也在专门为Feed流系统特别定制设计,所以到今天,只使用Tablestore一款产品,是可以满足上述需求的。选择Tablestore做Feed流系统的用户具有以下一些特征:

    • 产品设计目标规模大,千万级或亿级。

    • 不喜欢运维,喜欢专注于开发。

    • 高效率团队,希望尽快将产品实现落地。

    • 希望一劳永逸,未来系统随着用户规模增长可以自动扩容。

    • 希望能按量付费,用户少的时候费用低,等用户增长起来后费用在跟随用户数增长。如果具有上述四个特征的任何一个,那么都是适合于用Tablestore。


# 架构实践

上面我们介绍了Feed流系统的设计理论,具体到不同的类型中,会有不同的侧重点,下面会逐一介绍。

朋友圈

朋友圈是一种典型的Feed流系统,关系是双写关系,关系有上限,排序按照时间,如果有个人持续产生垃圾内容,那就只能屏蔽掉TA,这一种类型就是典型的写扩散模型。

微博

微博也是一种非常典型的Feed流系统,但不同于朋友圈,关系是单向的,那么也就会产生大V,这个时候就需要读写扩散模式,用读扩散解决大V问题。同时,微博也是主动关注类型的产品,所以排序也只能是时间,如果按照推荐排序,那么效果就会比较差。

头条

头条是最近几年快速崛起的一款应用,在原有微博的Feed流系统上产生了进化,用户不需要主动关注其他人,只要初始浏览一些内容后,系统就会自动判断出你的喜好,然后后面再根据你的喜好给你推荐你可能会喜好的内容,训练时间长了后,推送的内容都会是你最喜欢看的。

私信

私信也算是一种简单的Feed流系统,或者也可以认为是一种变相的IM,都是单对单的,没有群。

# 总结

上面我们介绍了Feed流系统的整体框架,主要是产品定义、同步、存储、元数据、评论、赞、排序和搜索等内容。

往期推荐

经典:十步完全理解 SQL

面试:HashMap 夺命二十一问!

10个Vue开发技巧助力成为更好的工程师

今天面试,问我什么是布隆过滤器?

面试官给我挖坑:rm删除文件之后,空间就被释放了吗?

 由于微信公众号近期改变了推送规则,如果你想如常看到我们的文章,可以时常点击文末右下角的「在看」;或者将 趣学程序 星标。这样操作后,我们每次新的推送才能第一时间出现在你的订阅列表中~扫描二维码获取更多精彩趣学程序

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://xiahunao.cn/news/251871.html

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

微博朋友圈亿级Feed流如何轻松设计?

简介 Feed流是Feed 流,Feed的本意是饲料,Feed流的本意就是有人一直在往一个地方投递新鲜的饲料,如果需要饲料,只需要盯着投递点就可以了,这样就能源源不断获取到新鲜的饲料。 在信息学里面,Feed其实是一个…

h5端登录是什么意思_关于app、小程序和h5之间的区别

1.APP 运行环境——Android和IOS手机操作系统 系统权限—— 最多最全面,但有些属于隐私需要用户授权才能调用。(安卓与IOS也有许多差异:Android类似于Windows,App几乎可读取本地所有文件;iOS端App无法读取本地除图片和…

python爬取微博非好友圈_Python爬虫之微博好友圈

数学建模已结束,刚开始的目标就是不熬夜,结果还是熬夜了(QAQ),缓了一天就来写简书了,感觉很久没爬虫了,今天就爬下移动端的微博好友圈信息。 代码 import requests import json headers { Cookie:xxxxxxxx, User_Agen…

设计模式之~原型模式

定义:用原型实例指导创建对象的种类,并且通过拷贝这些原型创建新的对象。原型模式其实就是从一个对象再创建另外一个可定制的对象,而且不需知道任何创建的细节。 优点: 一般在初始化的信息不发生变化的情况下,克隆是最…

华安鑫创:创新举措推动新旧产业融合升级

华安鑫创控股(北京)股份有限公司(以下简称“华安鑫创”、“公司”)是一家汽车智能座舱电子综合服务商,主营业务为汽车中控和液晶仪表等座舱电子产品的核心显示器件定制选型、软件系统开发及配套器件的销售。华安鑫创自…

华安泰VIKOR“跨越者”解码服务器:深入系统全面应用

随着视频监控系统的高清化、智能化趋势,监控设备前端采集的数据量愈加庞大,这就必定需要一个强大的后端管理平台进行有效的储存和处理。VIKOR“跨越者”高清监控系统包涵了高清前端设备的同时,又有多种后端存储设备、管理平台、软硬件解码等设…

专精特新、高端领航 中交华安核心技术及产品介绍第1期:单侧型桥墩防护解决方案——SA级高强型低变形量护栏...

来源:中交华安 导读 1.大型车辆撞击桥墩可能引发重特大交通事故,造成严重事故后果和不良社会影响。 2.目前国内外鲜少有专门用于桥墩防护的安全设施,可用于路侧距离较近桥墩或中分带内薄壁墩的安全设施仍处于空白。 3.中交华安品牌SA级高强型…

凝聚安防正能量 华安泰坚定细分市场发展之路

中国安防行业经过三十多年的快速发展,目前已进入了转型期,这种转型既是自身发展使然,也有不得己的外因影响。今年,安防行业洗牌加速,更有传言四起,动摇军心。每一次重大的变革都必须经历一次痛苦的蜕变。中…

华安泰2014摄影作品征集:盛夏里的青春

2014年夏天,华安泰邀请您用镜头记录生活,以“盛夏里的生活”和“盛夏里的青春”为主题征集图片故事,优秀照片将在企业内刊《华安泰人》、公众微信“华安泰智能”和官网www.vikorcctv.com中展示。 征集主题: 1、盛夏里的生活 盛夏里…

mx250显卡天梯图_mx250显卡天梯图_2020年最新笔记本显卡天梯图,看看你的显卡排在哪!...

显卡天梯图就是显卡的性能排行榜,目前显卡主要有Nvidia(英伟达)和AMD(超微半导体)两大品牌。我们都知道,显卡性能决定了电脑的图像处理能力。对于喜欢玩游戏的电脑用户来说,处理器和显卡是用户最关心的电脑硬件,一块好的显卡对于游…

adreno性能天梯图_深度学习之GPU显卡性能天梯图

在深度学习的显卡市场,英伟达的地位还是暂时无人能够撼动的。专业卡暂不纳入考虑,毕竟性价比太低了。大家平时使用的还是老黄的游戏卡,性能排第一的就是Titan RTX了,具备24G大显存,然而售价也高达两万块。接下来就是大…

计算机显卡排名,显卡天梯图_显卡性能天梯图_2021笔记本显卡天梯图-中关村在线...

7612 影驰Geforce RTX 3090 HOF Extreme 限量版 排名 2领先 98.56%的对手 重要参数 核心频率:基础频率:1395MHz加速频率:1860MHz 显存类型:GDDR6X 流处理器:10496个 显存容量:24GB 详细参数 > 7466 七彩虹iGame GeForce RTX 3090 Neptune OC 排名 3领先 97.84%的对手 …

笔记本显卡天梯图2023 笔记本显卡性能天梯图2023年2月

2023最值得入手的笔记本选哪个版本好这些点很重要看过你就懂了http://www.adiannao.cn/dy 一、RTX 3080Ti笔记本显卡 1、将旗舰3080Ti显卡引入笔记本电脑,笔记本将搭载16GB GDDR6显存。 2、RTX 3080Ti笔记本电脑的起售价为2499美元。 3、满功耗的RTX 3080Ti可以达…

[转载]pAppLocale(微软AppLocale修改版,不会有乱码后遗症)+辅助配件

【转码】pAppLocale(微软AppLocale修改版,不会有乱码后遗症)辅助配件 这里仅就修改版及辅助配件进行介绍,对此软件没概念的烦请自行搜寻引擎查找! pAppLocale(Microsoft AppLocale 修改版) ◎出处 http://www.csie.ntu.edu.tw/~piaip/ ◎下载…

转 Applocale:非Unicode程序界面乱码解决方法笔记

转 Applocale:非Unicode程序界面乱码解决方法笔记 2008年11月25日 星期二 下午 1:33 注: 为了不让 pAppLocale 消失 我也做了个下载备份 地址: http://www.brsbox.com/filebox/down/fc/1d30198f826cbb28eb110a0a8cfe5429 -------------------…

推荐工具:微软AppLocale

可以在不用更改“区域和语言选项”(不需要重启系统)的情况下,使应用程序读取非Unicode文件(本文示例为日文EA文档),微软出品。 1.下载 & 安装:: http://www.microsoft.com/down…

Win7系统下如何成功安装 Microsoft Applocale (附安装软件技巧)

相信玩游戏的都知道 Microsoft Applocale,在这里不做介绍,我要讲的是如何正确并成功安装这个软件,可能是由于和win7系统不兼容的缘故吧,很多人都安装失败,安装的出现下面这个图。 我就直入主题吧,一次进行…

app locale Android 8,AppLocale2模块

App Locale 2模块是一款非常实用简单的切换设置语言的应用软件。这款软件里面被植入了世界上的大多数语言,可以让用户与各个国家的朋友进行交流与沟通,功能很强大,软件使用方法非常简单,如果有需要的朋友,就快来下载这…

浏览器表情包

浏十年变化 浏览器00001-十年变化.jpg 快乐 浏览器00002-快乐.gif IE你是算了 浏览器00003-IE你是算了.png IE使人头痛 浏览器00004-IE使人头痛.jpg 给IE一点尊重因为要是没有IE你们就无法下载这些浏览器了 浏览器00005-给IE一点尊重因为要是没有IE你们就无法下载这些浏览器了.…