任何一个优质的软件服务都必须考虑高性能高可用(HighAvailability)可伸缩可拓展安全性等5大核心要素,推荐系统也不例外。

 

所以,我们会围绕这5个点来说明,怎么构建高效的推荐服务。

 

本文会从推荐服务背景介绍、什么是优质的推荐服务、构建优质服务面临的挑战、一般指导原则、具体策略等5个部分来展开讲解。

 

希望读者读完本文后,对什么是优质的推荐服务能有初步了解。同时,我也试图为读者提供相应的方法和策略,期望本文可以作为大家的参考指南。

  

推荐服务背景介绍

 

 

推荐产品是通过推荐服务来为用户提供个性化推荐能力的,我们可以从广义狭义两个角度来理解推荐服务。

 

从广义上讲,推荐服务是指整个推荐业务,包括数据收集、数据ETL、推荐模型构建、推荐推断、推荐web服务、推荐前端展示与交互等(见下面图1)。

 

640?wx_fmt=png

图1:推荐系统的业务流

 

图1中,大数据平台包含的数仓、计算平台等模块很多公司(特别是初创公司和中小型公司)都是基于开源的大数据平台(Hadoop、Spark、Hive等)来构建的,这些系统本身(或者通过增加一些组件)的设计是具备高可用、可拓展、可伸缩、安全等特性的。

 

同时,我们的数据ETL、推荐模型训练、推荐模型推断是基于数仓、计算平台基础之上构建的,也需要具备上面这些特征,这部分我们在这里不做介绍, 在未来分享推荐算法时会单独讲解。

 

从狭义上讲,推荐服务是指用户通过终端(手机、Pad、电视等)与推荐系统的web模块的交互, 即图1中红色虚线框中的部分(其实Kafka管道不属于直接参与Web服务的组件,但是我们是通过这个模块来跟更底层的数据处理算法组件解耦合,通过它来对接计算出的推荐结果,所以也包括进来了)。

  

本文我们将主要精力放到关注推荐系统Web服务上, 即狭义上的推荐服务

 

用户与终端交互的过程见下面图2,用户通过终端请求推荐服务,推荐服务模块通过返回相关的推荐结果给到终端,终端将推荐结果展示给用户。用户与终端的交互虽属于视觉及交互设计范畴,与推荐工程师的工作无直接关系,但是会直接影响到用户的体验,也在我们讨论之列。绿色虚线框中是真正的推荐系统Web服务过程。

 

640?wx_fmt=png

图2:用户与推荐系统交互的数据流向

 

后文所有关于构建优质服务策略的主题,都围绕这里所指的狭义的推荐服务来展开。

 

简单介绍完什么是我们本文要讨论的推荐服务, 那么什么是优质的推荐服务呢?我们又可以从哪些维度来衡量推荐服务是否优质呢?

 

 

什么是优质的推荐服务

 

 

推荐服务作为一类软件服务,遵循通用的软件设计原则。

 

在复杂的软件设计中我们需要从高性能、高可用、可伸缩、可拓展、安全性等5个维度来衡量软件架构的质量,对于推荐系统也一样,推荐系统也属于一类非常偏业务的较复杂的软件系统,我们也会从这5个方面来说明什么是优质的推荐服务。

 

01

高性能

 

所谓高性能,是指推荐服务可以在较短的时间内给用户返回相关推荐结果,并且数据是准确可靠的,同时用户会感觉整个交互过程很流畅,不会感到非常慢或者卡顿。

 

一般用响应时间(用户触发推荐页面到返回推荐结果的时间)来衡量高性能,通常服务需要在200ms之内返回结果,否则用户肉眼就可以直观感受到慢了, 好的系统可以做到50ms之内返回结果。这个时间当然是越短越好,相应技术实现成本和难度都会更大。

 

当然,网络会存在各种偶发情况,即使推荐服务性能很好,我们也没法保证每个用户请求都可以在这个时间内响应, 所以一般可以采用百分之多少的请求可以在多少毫秒内返回(比如99%的请求可以在75毫秒内返回)来衡量高性能。

 

02

高可用

 

所谓高可用,从字面理解就是用户可以一直使用而不出现问题。

 

由于软件服务是基于现代芯片及硬件基础上构建的,硬件会产生故障宕机,软件也会由于bug或者偶发情况等出现问题,所以一般故障是几乎无法避免的,特别是对于大规模分布式服务,共同服务于同一服务的计算机集群越大,出现故障的可能性也会越大。

 

这里举个例子:比如飞机是最安全的交通工具,但是一两年基本都有一些飞机相关的事故,主要是全球每天有大量的航班飞行,虽然单次飞行出问题概率非常小,但一两年累计下来至少一次飞行出问题的概率就很大了,学过概率统计的读者应该很好理解。

 

当这些故障出现时,软件系统将无法响应用户请求,导致提供的服务不及时、不稳定、不可靠,甚至不可用。

 

计算机行业的高可用一般是通过故障出现后的影响时长、等级及故障恢复的快慢来衡量一个软件系统是否高可用。如果故障不频繁、故障影响面不大、在很短的时间就恢复正常了就是高可用的系统,否则就不是高可用的系统。

 

很多大型网站,比如淘宝,百度基本达到了99.99%的高可用了,算下来一年大约只有0.88小时不可用。

 

推荐系统本身就是一项软件服务,对于推荐系统来说,高可用就是推荐服务是否稳定高效的为用户提供服务。

 

03

可伸缩

 

我们可以这样来理解伸缩性, 将一个模块或者系统类比为一条生产线(如富士康中苹果手机生产线),当有大量的订单需求时,可以通过扩充生产线来应对大规模的业务需求,这就是生产线的伸缩性。

 

推荐系统需要面对海量用户的推荐请求, 同时也要为每个用户存储相关的推荐结果。可伸缩性是指是否可以通过不断增加服务器(在该服务器上部署相关的推荐服务)的手段来应对不断新增的用户及在服务高峰期暴增的请求。这种增加服务器来提供无差别的服务,必须是对用户无感知的,不会影响用户体验。

 

互联网产品(特别是toC互联网产品)是基于规模效应的一种生意,发展用户是公司最重要的事情,在用户发展阶段,用户是爆发增长的,这时原有的推荐服务是无法满足快速增长的用户需求的, 所以要求推荐服务具备伸缩能力是必然的。

 

由于推荐系统需要存储用户推荐结果, 因此相应的存储数据库也需要具备可伸缩的能力,当前很多NoSQL数据库都是具备可伸缩能力的。

 

04

可拓展

 

互联网产品是需要快速响应用户需求变化的,所以对产品做调整,或者增加新的产品形态是常有的事情。

 

可拓展性指的就是推荐服务可以快速响应业务需求变化,非常容易对服务做调整修改,可以非常方便地增加新的推荐业务。

 

比如,公司在前期没有接入广告,等做商业变现时,需要在信息流推荐中插入广告,这时就需要对信息流推荐产品做调整,整合广告投放能力。

 

05

安全性

 

互联网是一个开放的服务体系,我们需要采用技术手段确保网站数据不会轻易被恶意攻击,防止数据被盗。

 

衡量推荐服务安全性的主要指标是针对各种恶意攻击及窃密手段是否有有效的应对方案,同时是否可以很好的保护用户隐私,特别是今年315曝光了很多数据黑产的利益链,用户数据安全性只会越来越重要,相信不久的将来,就会有更完善的法律保护措施出台。

 

我们已经介绍完了好的服务设计需要具备的5大要素,这些要素是任何一个互联网服务都必须关注的,更需要我们基于已有的人力资源、经验、投入成本、业务特性等做好平衡。构建优质的推荐服务,也需要关注上面的5点,需要在这5大要素之间做好取舍和平衡。

 

相对于后台服务,推荐服务是一种较特殊的软件服务, 那么对于推荐服务是否可以很容易做到上面5点呢?会面临哪些挑战呢?

 

设计推荐服务面临的挑战

 

 

相对于其他后台系统来说,推荐系统有很多不一样的地方。

 

对于个性化推荐来说,给每个用户的推荐都是个性化的,所以生成的推荐结果都是不一样的,这些推荐结果需要事先存储下来,方便用户请求时快速反馈给用户,因此需要大规模的数据存储系统来支撑。

 

特别是随着短视频、新闻APP的火爆,在这些产品中用户消耗单个标的物的时长较短, 因此为用户提供近实时的推荐服务,并跟紧用户兴趣的变化,试图占用用户的碎片化时间是这类产品设计中非常关键的要素,也是产品是否具备核心竞争力的先决条件。

 

具体来说,构建优质的推荐服务,会面临如下挑战:

 

01

需要存储的数据量大

 

个性化推荐为每个用户存一份推荐数据,数据量随着用户线性增长。

 

一般toC互联网产品都是通过规模效应盈利的,所以发展用户是互联网公司最重要的事情之一,做得好的产品用户规模一定会在一定时期内爆发增长,因此数据存储也会急速增长,需要更多的软硬件资源来容纳新增的大量数据。

 

当用户量大到一定程度时,一台服务器无法装下所有用户的推荐结果,一台服务器也无法为用户提供web接口服务,这时就需要采用分布式技术,需要数据库及web服务系统具备很好的伸缩能力。

 

02

需要快速响应用户请求

 

随着新闻、短视频等消费用户碎片化时间的应用层出不穷,越来越多的推荐系统采用近实时的推荐策略,以提升用户体验,同时让用户沉浸其中,增加自己产品的使用时长,方便更好地拉投资或者做变现。

 

实时给用户提供个性化推荐,这个过程中需要实时学习用户的短期兴趣,并基于用户的短期兴趣实时更新用户的推荐列表,这为整个推荐系统业务设计开发带来极大压力和挑战。

 

03

接口访问并发量大

 

个性化推荐由于每个用户推荐结果都不一样,很难利用现代CDN技术来对推荐结果加速(主要是命中率太低),用户的请求一般都会回源,对后端系统产生较大的访问压力。

 

总的说来,有可能在极短的时间产生流量风暴。特别是对有些产品,由于产品自身的属性,在特定时段访问流量极大,比如视频类应用,一般是晚上6-9点是访问高峰,这时的流量可能会暴涨50%以上。

 

04

业务相对复杂

 

推荐业务为了给用户提供好的体验,需要涉及到很多方面。

 

比如,需要具备根据一定业务规则做运营的能力。需要为用户过滤掉已经看过的或者曝光过的内容,需要对在推荐结果中下线某个标的物(如视频中某个节目下线,电商中某个商品下线),需要实时根据用户行为更新用户兴趣推荐。这些较复杂的逻辑,对设计优质服务也是一种挑战。

 

既然推荐服务的设计有上面这么多挑战,那我们要怎么设计好的推荐服务呢?是否有一些一般的原则可借鉴呢?回答是肯定的。

 

构建优质服务的一般原则

 

   

在讲具体的方法和策略之前,我们先简单介绍一下做到优质服务需要了解的一般思路和原则,这些原则是帮助我们构建优质服务的指导思想。

 

01

模块化(SOA)

 

SOA(Service Oriented Architecture)即面向服务的架构,主要目的在于服务重用,通过将服务解耦,提升整个系统的可维护性。

 

在设计系统时, 尽量减少系统的耦合,将功能相对独立的部分抽提出来,通过数据交互协议或者接口与外界交互。这样设计的主要目的是减少系统的复杂度,方便独立对某个模块优化和升级,同时,当系统出现问题时也可以快速定位。

   

最近几年很火的微服务是对SOA思想的延伸,是一种轻量级的SOA解决方案,将服务拆解为更细粒度的单元,更易于系统维护和拓展。

 

02

数据存储

 

互联网行业有所谓空间换时间的说法, 意思是通过将需要的结果预先计算好并存储下来,等用户请求时就可以直接返回给用户而不需要再去计算,虽然占用了存储空间,但是大大加快了查询速度。

 

而数据缓存就是一种空间换时间的做法,先将用户需要的数据(对推荐系统来说,就是返回给用户的最终推荐结果)事先计算好在数据库中存起来。当用户请求时,可以直接给到用户。

   

涉及到缓存,缓存命中率就必须要关注了,如果一个查询不会经常查到,缓存下来其实是没有太多好处的,因为以后也不会经常用到了。

 

个性化推荐产品每个用户的推荐结果都不一样,做缓存的价值是没有那么大的。但是对于关联推荐,每个标的物关联的标的物列表在短期(可能是一天)是不变的,这时就可以充分利用缓存的优势了。

 

03

负载均衡

 

负载均衡(Load Balance),就是将请求均匀分担到多个节点上执行,每个节点分担一部分任务,整个系统的处理能力跟节点的数量成线性相关,通过增加节点可以大大提升整个系统的处理能力。推荐接口会大量采用负载均衡技术。

 

04

异步调用

 

举个简单的例子,你去银行办业务,拿到号后需要排队,如果你一直看着屏幕等待你的号出现,这就是同步。如果你在等待的同时用手机处理工作邮件,等轮到你的号了银行语音提示你去办理业务就是异步。

 

从这个简单例子可以看到,异步可以提升系统(这个例子就是你的大脑)的处理效率,而不必在一件事情上浪费时间。

   

在推荐服务中可以大量采用异步的思路,比如将推荐结果插入数据库时,可以采用异步插入,提升插入的效率,响应接口请求时也可以采用异步处理。

 

由于异步不需要双向确认,大大提升了效率,但是也可能由于没有确认,导致部分处理请求失败(比如某个用户的推荐结果由于各种未知原因未插入数据库)。

 

后面会讲到推荐业务是可以容忍一定的错误的(不像涉及钱的会员等业务必须准确无误),同时推荐业务需要处理大规模的数据(如T+1的个性化推荐,在一两个小时内需要为每个活跃用户更新推荐结果,如果用户规模很大,这个过程是很耗时的), 所以采用异步可以大大提升效率。

 

05

分布式及去中心化

 

分布式网络存储技术是将数据分散地存储于多台独立的机器上。

 

分布式网络存储系统采用可扩展的系统架构,利用多台存储服务器分担存储负荷,利用位置服务器定位存储信息,不但解决了传统集中式存储系统中单存储服务器的瓶颈问题,还提高了系统的可靠性、可用性和扩展性,这种组织方式能有效提升信息的传递效率。

 

通过将系统、数据或者服务分布于多台机器上,首先可以增强整个系统的处理能力,同时也可以降低整个系统的风险。

 

去中心化是互联网发展过程中形成的一种内容或服务组织形态, 是相对于“中心化”而言的新型网络内容的生产过程。在计算机技术领域,去中心化结构使用分布式核算和存储,不存在中心化的节点,任意节点的权利和义务都是均等的, 系统中的数据块由整个系统中具有维护功能的节点来共同维护,任一节点停止工作都不会影响系统整体的运作。

 

推荐系统的web服务和数据存储都可以采用分布式和去中心化的思想利用相关开源系统构建,如CouchBase数据库就是分布式去中心化的数据库。

 

06

分层思想

 

分层跟模块化思想类似,最大的区别是各个层之间是有直接的依赖关系的,分层一般也是根据逻辑结构、数据流、业务流等来分,即使是同一层内,也是可以做更细粒度模块化的。

 

分层的目的是让系统逻辑结构更清晰,便于理解、排查问题。推荐系统根据数据流就可以简单分为数据生成层、数据存储层、数据服务层,后面会详细介绍。

 

讲完了设计优质服务的一般思想,那我们就来详细讲解一下具体有哪些策略可以帮助我们设计优质的推荐服务。

 

 

可行策略

 

 

我们在第一节中对推荐服务的范围做了简单限定,在第二节对优质服务的5个维度做了简要说明,结合第四节的基本原则,我们在本节来详细说明怎么设计优质的推荐服务,有哪些具体的策略和方法。

 

设计优质推荐服务的目的是希望更好的服务于用户, 提升整个系统的效能,最终提升用户体验。我们还是从高性能、高可用、可伸缩、可拓展、安全性5个维度来展开介绍。

  

高性能

 

为了能够提供高性能推荐服务,我们可以从如下维度来优化推荐服务模块,以提升推荐服务的响应速度,给用户更好的交互体验。

 

01

CDN缓存

 

CDN(Content Delivery Network,即内容分发网络)是一个非常成熟的技术,通过部署在各地的边缘服务器来对内容进行加速。我们也可以利用该技术来加速推荐服务。

 

对于非个性化推荐(如排行榜、关联推荐等),每个用户返回结果都一样,所以命中率极高,完全可以采用CDN来加速,以提升推荐接口的性能。

 

对于首页上的T+1个性化推荐,由于用户进入(是必经路径,可能会经常回退到首页)的概率较大,特别是很多APP,用户一天多次登录,也可以采用CDN做缓存(命中率可能没有非个性化推荐大)。但是对于实时个性化推荐,每次刷新,推荐结果都不一样,基本无法利用CDN的缓存能力。

 

CDN缓存虽然可以加速,但是利用CDN缓存也需要注意,如果某个请求出错了,刚好被CDN缓存了,会对后来访问的用户产生负面影响(后来的用户会返回这个被CDN缓存了的出错的结果)。我们需要定期清理缓存,或者跟CDN厂商沟通,采用特殊的缓存策略(如返回的接口为空或者不合法时不做缓存),最大利用CDN的优势,避免不必要的问题。

 

02

Nginx层或接口层的缓存

 

除了CDN层的缓存,我们可以在Nginx层及接口web服务层增加缓存,采用多级缓存的策略能够更好的避免请求击穿缓存, 从而更快速的为用户提供推荐服务。

 

03

数据压缩

 

如果某个推荐产品形态给用户推荐的数据量比较大(比如,我们公司在做个性化重排序时,可能有几百上千个视频,用户是通过分页来请求的,数据量大,见下面图3战争风云这个tab,会根据用户的兴趣做个性化重排,用户通过下滑遥控器按键分页请求数据),可以对存储于数据库中的推荐结果进行压缩(比如采用protobuf + base64进行编码),这样数据量就会少很多,减少网络数据传输,提升接口性能。

 

640?wx_fmt=png

图3:基于用户兴趣的列表个性化重排序

 

04

接口做压力测试

 

我们不光要验证接口的功能是否正确(功能测试),还需要事先对接口的性能有所了解,知道接口的性能极限,这样才可以知道在高峰期间,所有推荐接口服务器是否能够抗住压力。

 

了解接口性能的最好方式是通过压力测试。

 

通过压力测试就可以知道接口在一定并发量下的吞吐率、响应速度、能够承受多大的QPS。特别是个性化推荐接口,访问量非常大,每次接口做升级或者开发新的推荐产品形态时,都需要做打压测试。

 

我们基于打压测试及在高峰时段用户访问情况, 才可以确定到底需要多少台接口服务器可以支撑现有的服务。

 

05

服务质量评估

 

推荐接口性能怎么样?是否有延迟,我们需要收集相关的数据来评估接口响应情况,总响应时间分为两个部分(见下面图4)T1和T2,用户的总响应时间T等于这两部分之和(T=T1+T2)。

 

其中T1是网络传输时间,衡量网络情况,这部分时间基本是我们很难控制的(当然可以通过CDN加速, 提升出口带宽来适当缓解)。

 

T2即是我们推荐接口响应时长,这部分时间包括从推荐库中获取用户的推荐结果,并将结果组装成前端展示需要的形式(拿视频推荐来说,我们需要组装出节目标题、演职员、详情、评分、海报等前端展示时必要的信息)。

 

640?wx_fmt=png

图4:推荐服务响应用户请求链路及时间花费

 

对于T2,我们可以在Nginx侧记录每次请求的响应时间,并将相关日志收集到数据中心做分析,这样就知道各个推荐业务接口响应情况。

 

下面图5是我们自己的推荐业务相关接口性能统计情况(为了隐私,隐藏了具体业务名称、QPS及请求次数)。

 

从下图可以看到很多接口99%的调用响应时长低于50ms,性能是很不错的,但有些性能不是很好,如第四行的,只有81%的请求控制在200ms之内,这些业务都是非常老的版本的业务了,基本不再维护了。

 

从这张图中,我们可以非常清楚地看到各个业务接口的性能情况, 这样我们可以针对业务的重要性和当前性能情况做接口优化。

 

640?wx_fmt=png

图5:推荐接口性能统计

 

对于总时长T,我们也可以在前端通过日志埋点记录下来,同样通过数据分析可以知道一个推荐业务平均耗时多少,总时间减去T2,就是T1的平均耗时,即网络传输时间。

 

通过对服务质量评估,就可以有针对性的对上述的T1,T2做优化,从而提升接口性能。

 

06

采用高性能的web服务器

 

采用高性能的web服务器可以极大提升推荐服务的性能,推荐服务业务逻辑相对简单,可以采用轻量级的web服务器,比如Vert.x(基于java语言的高性能web服务器)、Spray(基于Scala语言的高性能web服务器)、gin(基于Go语言的高性能web服务器)、cowboy(基于Erlang语言的高性能web服务器)等,这样不仅可以满足开发推荐接口的需求,开发速度快,并且性能也很好。传统的web服务器如Tomcat等太重了,不太适合推荐api接口的开发。

 

07

采用基于内存的NoSQL数据库

 

一般来说内存的访问速度比磁盘快好几个数量级, 采用基于内存的数据库来存储推荐结果会提升整个接口获取推荐结果的速度,现在有很多开源的这类数据库可供我们选择,比如Redis、CouchBase等。

 

即使不用基于内存的数据库,也要将数据存放到SSD中,获取速度也会快很多。

 

高可用

 

构建高可用系统是一个比较有挑战的事情,具体可以从如下方面来考虑:

 

01

接口层保护

 

即使有很多的防护策略,我们也不能保证推荐接口永远也不出错

 

为了应对这种在极端情况下可能存在的问题, 给用户更好的体验,我们可以在前端(即APP侧)做一层接口保护。

 

具体做法可以是提供一组默认推荐接口,前端在启动时加载该接口,将数据存储在终端,当推荐服务无响应或者响应超时时,可以用默认推荐结果顶替。默认推荐虽然推荐的标的物没有原来的精准,但是不至于“开天窗”,对用户体验也算是一个不错的补救措施。

 

02

多可用区(多活)

 

对于创业中期或者成熟的公司,最好需要在多个可用区(同城多活,异地多活)部署推荐服务,避免由于自然灾害(如工程建造挖断光缆、爆炸、水灾、火灾、地震等)等导致服务无法使用。

 

构建多可用区需要投入非常多的资源, 成本较大, 对于初创公司建议不要考虑采用这种方式。

 

03

服务监控与自动拉起

 

服务监控的目的是保证在服务出现异常的时候第一时间通知运维或者相关负责人,在问题还没有引起灾难时尽快扩容服务器,或者有重大问题时,相关人员可以第一时间知道,快速解决问题。

 

有了自动监控,当服务出问题或者挂掉后,可以通过监控脚本自动将服务拉起。一般来说,重启可以解决80%的故障问题。

 

04

灰度发布

 

灰度发布是互联网公司常用的发布策略,目的是通过先发布少量的用户,看新功能点是否异常,如果有异常及时修复,不至于对所有用户产生不好的影响。

 

对于推荐服务,我们也建议采用灰度发布的方式,减少由于未发现的未知问题对用户产生的伤害。

 

05

超时、限流、降级与熔断

 

当推荐接口服务在一定时间(比如2s)无返回时,可以告知用户访问超时,避免一直等待导致的资源紧缺。

 

在极端情况下,当接口并发请求太大时(比如今年的春晚百度红包), 可以对访问请求做限制,让部分请求立即执行,其他请求在队列中等待。同时可以对同一IP的多次请求(可能是正常请求,也可能是恶意攻击)做限制,减缓对接口的冲击。还可以限制并发数、网络连接数、网络流量、CPU负载等各种限制措施来对访问进行控制。

 

熔断可以类比为电表的保险丝,当电流过大时(家里太多电器同时用或者短路)保险丝熔断,停止供电,避免出现意外事故。当请求推荐的服务有大量超时,这时新来的请求无法获得响应,只会无谓的消耗系统资源,这时整个服务可能出现了异常,熔断是较好的策略。

 

所谓降级,就是当服务不可用(比如熔断后)时,采用效果更差的服务替代,虽然效果没那么好,但是至少比什么都没有强。上面提到的接口层保护就是一种降级策略。

 

采用超时、限流、降级、甚至是熔断策略,主要是从系统高可用性角度考虑而采取的策略,目的是为了防止系统整体缓慢甚至崩溃。

 

可伸缩

 

构建可伸缩的推荐服务,对于应对大规模的用户请求非常必要,我们可以从如下方面来增强系统的可伸缩性。

 

01

利用NoSQL数据库作为数据存储

 

由于推荐系统产生的数据量线性依赖于活跃用户量,而互联网产品DAU一般会很大(百万级、千万级、甚至亿级),所以需要存储大量的用户推荐数据,并且这些数据是会频繁更新的(对于T+1推荐每天更新一次,对于近实时推荐,可能会秒级更新), 所以采用一般的关系型数据库是很不合适的。推荐的结果一般是为一个用户推荐一个标的物的列表,用关系型数据库也不是特别合适,推荐的数据结构一般可以采用list,json等格式存储。

   

基于上面的说明,这非常适合用现在的NoSQL数据库做推荐结果存储,现在很多NoSQL数据支持Json等复杂的数据格式,并且具备横向扩容的能力。如常用的Redis,就支持String,Hash,List,Set,Sorted_Set等多种数据格式。

   

在我们公司的业务中,我们主要采用了CouchBase和Redis两种NoSQL数据库,CouchBase是一个文档型分布式数据库,热数据会放到内存中,冷数据会放到磁盘中,并且在水平拓展、监控、稳定性等方面做的非常好。我们将个性化推荐存储在CouchBase中,非个性化推荐(如排行榜、关联推荐等)存储在Redis中。据我所知,在爱奇艺的推荐业务中也大量采用CouchBase。

 

02

接口web服务可横向拓展

 

现在一般互联网公司会利用Nginx的高性能特性做反向代理,通过Nginx代理推荐的web服务。

   

接口web服务最好做到无状态,这样就方便做横向扩展。在我们公司实践中,我们用Go语言的Beego框架和Gin框架来开发推荐接口,开发效率高,稳定,并且性能相当不错,目前Go的生态圈非常完善,是一个不错的选择。

 

03

自动伸缩

 

推荐服务的可伸缩性要求我们可以非常容易地在负载高的时候做服务的扩容,结合现在的Docker容器技术及K8S编排系统及对接口服务的监控,制定一些伸缩的规则是可以做到自动伸缩的,当负载高时自动扩容服务器,当负载低时自动缩容。

 

这样的好处是减少人工干预的时间, 及时伸缩也能更好的节省开支, 让资源得到充分利用。当然,要想基于开源技术自己构建一套好用稳定的可自动伸缩的服务体系还是很有挑战的,幸好现在很多云计算厂商可以直接提供基于k8s、docker的云服务,让构建这样一套系统变得容易起来。

 

可拓展

 

可拓展性衡量的是推荐系统应对需求变化的能力, 我们可以通过如下一些策略和思路让推荐服务可以更好的拓展。

 

01

利用消息列队减少系统耦合

 

在上面图1, 我们通过一个Kafka管道的模块来将推荐算法平台与推荐数据存储解耦合,而不是在推荐系统推断阶段直接将推荐结果插入推荐数据库。这样做的好处是减少系统依赖,便于问题排查。同时Kafka起到了对大规模推荐数据做备份和缓冲的作用。

 

02

利用解耦及庸才数据交互协议

 

将推荐系统服务尽量解耦,采用微服务架构,Nginx层、接口Web层、数据层等尽量独立,采用符合业务规范(基于公司自己的业务特性及技术选型)的方式交互(比如利用http,thrift,protobuf等协议做数据交换)。这样,对系统进行升级、维护、功能拓展、或者排查问题都非常方便。

 

现在业内有很多开源的微服务框架供大家选择,如dubbo、Spring cloud等。也可以根据自己公司需要,自行开发满足自己业务需求的微服务组件。

 

03

分层思想

 

我们可以简单将推荐系统分为三层,接口服务层处理用户的请求,数据层存储用户的推荐结果,算法模型层构建推荐模型并为用户生成推荐结果(见下面图6)。通过分层,让整个系统更有层次感,更易于理解、升级、维护,也更方便排查问题。

 

640?wx_fmt=png

图6:推荐业务的分层模型

 

04

可适当容错及服务降级

 

推荐服务跟涉及到钱的业务(如会员购买,广告投放等)是不一样的,推荐结果不够精准最多是用户体验不好,不会有非常严重的投诉问题或者法律风险,所以推荐系统的容错性相对要大一些。

 

基于推荐系统可容错的特性及CAP理论(指的是在一个分布式系统中,Consistency(一致性)、 Availability(可用性)、Partition tolerance(分区容错性),三者不可兼得),推荐服务对一致性的要求也没有这么高,对于推荐系统选择的分布式存储数据库,不需要强一致性,往往达到最终一致性就足够了,但是我们最好需要保证系统是满足可用性的,这样才可以时时刻刻为用户提供推荐服务。

 

随着产品的迭代,极大部分用户可能会升级到相对较新的版本中,很老的版本用户数肯定是较少的(相对于总用户),对于这部分用户,我们建议产品通过各种运营或者技术手段让用户升级上去,对于不升级的用户,我们可以采用有损服务的形式为它们提供推荐服务。具体方法主要有对这部分用户关闭推荐服务和只为这部分用户提供默认推荐服务两种方式,这样做的目的主要是减少对推荐产品的维护成本。

 

所以,针对推荐系统可适当容错及对低版本用户可提供有损服务的特点,可以优化整个推荐系统的服务,让部分服务简化,间接提升了系统的可拓展性。

 

安全性

 

对于企业级服务,安全无小事,对于推荐系统同样存在安全隐患,提升推荐服务的安全性可以从如下几个维度来考虑。

 

01

接口安全

 

推荐服务可能由于受到攻击或者可能存在的软件bug导致对某个推荐服务的大规模请求。我们需要对推荐接口做保护,可以对同一IP地址的频繁访问做限制,或者对用户鉴权,防止系统受到恶意攻击。

 

对接口中涉及的隐私或者机密信息需要做加密处理。

 

同时,接口设计也要具备鲁棒性,对获取的推荐数据中可能存在的错误做异常保护,避免开发插入不符合规范的数据格式、数据类型等错误导致接口挂掉。

 

02

域名分流

 

对于用户量较大的APP,我们可以通过域名分流的形式对推荐接口分流,当某个域名出问题,可以快速切换到另外的域名, 提供对接口更好的保护功能。

 

03

https

 

采用https协议而不是http,可以大大提升整个推荐接口的安全性,防止用户信息泄露。https性能可能会有一定损失,但是相对安全性的提升是可以忽略的。但是采用https对开发及资金成本都有更高的要求。

 

04

现网验证

 

当一个已有推荐业务做调整(接口调整、算法逻辑调整)或者新的业务上线后,一定要创造条件在现网验证一下是否正常,确保接口可以正常返回数据,并且前端看到的数据跟接口返回的数据及数据库中推荐的数据要保持一致。我们曾经出现过升级后未做验证,发现前端数据不正常的情况。

 

写在最后

 

 

本文从高性能、高可用、可伸缩、可拓展、安全性等5个方面对怎么设计优质的推荐服务做了详细讲解,提供了一些思路和策略,希望为设计推荐服务的读者提供一些指导。

查看全文
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

相关文章

  1. 单调栈 求解下一个更高温度问题,简单易懂

    本文大部分转载自 https://blog.csdn.net/weixin_42784951/article/details/88963758只是对答案进行了描述说明==============================================适用问题:要知道单调栈的适用于解决什么样的问题,我们首先需要知道单调栈的作用。单调栈分为单调递增栈和单调递减…...

    2024/4/10 13:43:15
  2. JDK、JRE、JVM的联系

    一、jdk结构图二、通过Java8的目录结构直观解释 1、jdk:Java开发工具包。bin:存放jdk各种工具的命令,即jdk工具的可执行二进制文件,包括编译器,调试器等,例如:java,javac,javap等。 db: 存放安装java DB的路径,Derby是java自带的数据库 include: 存放java调用C或者C+…...

    2024/4/8 22:58:08
  3. dubbo 源码分析-1

    前一篇springCloud 篇幅较长,看起来比较累。这一篇dubbo源码分析,将拆分3篇来分析。 1.版本这里源码是从git 上拉下来的,现在注解用的多,这也是一篇分析注解版本的。 2.入口这是spring 容器启动,回加载ProviderConfiguration.class,这个类的 @EnableDubbo 是dubbo 启动的入…...

    2024/4/8 22:58:05
  4. 百度大脑助力中拓医废追溯云平台实现“智能化”

    价值成果1、山东中拓作为国内首家将人工智能技术引入医疗废物管理信息化追溯的公司,利用百度大脑OCR仪器仪表盘读数识别、数字识别、人脸识别等技术,率先搭建了“中拓医废追溯云平台”,通过采集科室人员人脸档案,实现刷脸匹配相关科室信息、以及在医疗废物存储、收集过程中…...

    2024/4/10 19:59:47
  5. 通过echarts 使用china.js时出现南沙诸岛乱码问题

    如图别的都正常显示,就南海诸岛乱码。然后打算隐藏南海诸岛,找个各种方法,1、通过geo直接隐藏,使用后发现没反应。geo: {map: "china",roam: true,zoom:1, //默认显示级别 scaleLimit:{min:0,max:3}, // 缩放级别regions: [{name: "南海诸岛",valu…...

    2024/4/8 22:58:03
  6. leetcode 35.搜索插入位置

    原题 35.搜索插入位置 2020年7月17日 每日一题题解 方法一 暴力法。由于是排过序的数组,那么我们就可以遍历数组,当找到第一个不小于target的值的数时,说明此处是插入的位置。而如果所有遍历完之后,都没有发现不小于target的数,说明应该插入到最后面,也即是nums.length的…...

    2024/4/8 22:58:02
  7. Logback 使用备忘

    清单+ 同一个包按级别输出到不同文件附件常用 Filter + 同一个包按级别输出到不同文件在 appender 中增加Filter<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender"><encoder><pattern>${CONSOLE_LOG_PATTERN}</p…...

    2024/4/16 14:00:59
  8. 用JPEXS软件实现swf反编译-逆向调试方法

    最近对某文档网站的一个PageViewer.swf文件进行逆向工程,学习了一些swf文件反编译的方法。第一部分 配置 安装firefox debug版的的flash:flash日志输出配置: 在c:\Us…...

    2024/4/10 20:06:44
  9. ESP32-ADC学习

    概述 ESP32集成了两个12位SAR(逐次逼近寄存器:Successive Approximation Register)ADC,总共支持18个测量通道(支持模拟的引脚)。 ADC驱动器API支持ADC1(8个通道,连接到GPIO 32-39)和ADC2(10个通道,连接到GPIO 0、2、4、12-15和25-27)。但是,ADC2的使用对应用程序有…...

    2024/4/8 22:58:00
  10. IDEA maven spring-boot-maven-plugin报错

    环境:IDEA spring maven背景:官网下载的仓库 报错:pom.xml中的spring-boot-maven-plugin ** 解决方法: ** 在maven/conf/setting.xml文件中的标签下插入<mirror><id>nexus-aliyun</id><mirrorOf>*</mirrorOf><name>Nexus aliyun</n…...

    2024/4/8 23:06:19
  11. SOLIDWORKS Composer 圆周运动小技巧

    SOLIDWORKS Composer 是 SOLIDWORKS 整体解决方案中的一款基于 3D CAD 数据来创建清晰的、有效的产品说明文档的软件,它可以极大地来丰富企业的产品展示、说明的形式。SOLIDWORKS Composer 具有优秀的交互式动画制作能力,它可以呈现出复杂的产品动态图形内容。本期所要介绍的…...

    2024/4/8 23:06:18
  12. mysql大量脏页未刷盘关闭实例非常缓慢

    异常现象由于业务需求,需要重启msyql从库,但是发现关闭非常慢,超过60秒,由于历史原因,启动脚本设置了如果60秒未关闭就会强制kill -9,数据库关闭后再进行重启时报启动失败,由于当时比较紧急,没有查看报错日志,没有留下失败的原因。不过从这次关闭时间太长发现这台机器的…...

    2024/4/10 10:52:48
  13. Linux 使用笔记:YUM

    文章目录YUM简介常用命令换源本地源其他问题 YUM简介 Yum(全称为 Yellow dog Updater, Modified)是一个在Fedora和RedHat以及CentOS中的Shell前端软件包管理器。基于RPM包管理,能够从指定的服务器自动下载RPM包并且安装,可以自动处理依赖性关系,并且一次安装所有依赖的软件…...

    2024/4/8 23:06:16
  14. HIVE列出两个日期之间的所有日期

    select tmp.*, t.*, date_add(start_date, pos) as mid_date from(select 1 as uid,2020-07-01 as start_date, 2020-07-17 as end_date )tmp lateral view posexplode( split( space( datediff( end_date, start_date ) ), ) ) t as pos, val ;...

    2024/4/10 5:20:27
  15. Python 与 Office 办公软件专栏目录:14 篇博客从基础到实例,助力你的自动化办公梦

    Python 与 Office 办公软件专栏目录前言:Python 与 Excel文章一:用 xlwt 将数据写入Excel文件简介文章二:xlwt 工作表对象常用设置文章三:xlwt 设置表内单元格格式文章四:xlwt 自写方法,实现按行写入多组数据功能文章五:xlrd 读取 Excel 表格数据方法文章六:xlrd 获取E…...

    2024/4/8 23:06:14
  16. 1+N圆桌论坛

    1+N 圆桌论坛 近年,互联网行业保持高速增长态势。无论是中国网民的复合增长率还是互联网企业的增长率,都是站在世界的最前端的。但随着互联网产业2C的流量市场与商业机会接近天花板,同时伴随着AI、区块链、大数据、云计算等技术的发展与突破,技术之间的相互取长补短实现了…...

    2024/4/16 0:32:41
  17. Mysql json类型字段Java+Mybatis数据字典功能实践

    目录前言应用场景介绍数据字典案例实践表结构实体类关系映射效果展示总结 前言本文为博主原创,转载请注明出处,原文地址:https://blog.csdn.net/qq_38688267/article/details/107386138JSON类型是MySQL5.7.8中新加入的一种数据类型,并在后续版本尤其是MySQL8.0中得到了大幅…...

    2024/4/8 23:06:12
  18. 使用正则表达式,校验输入的字符串,是否是浮点数的校验

    import redef isNumber(num):# 判断输入的字符串是否是正(负)数,且只能输入两位小数pattern = re.compile(r"^[-+]?[-1-9]\d*(\\[.]\d{1,2})?$|[-+]?\.?[1-9]\d*([.][0-9]{1,2})?$")result = pattern.match(num)if result:return Trueelse:print("只能输…...

    2024/4/8 23:06:11
  19. HTML+CSS:鼠标悬停

    跟着up主码小渣学习(无改动) 效果HTML: <!doctypehtml> <html><head><meta charset="utf-8"><meta name="viewport" content="width=device-width,initial-scale=1.0"><title>mousedown!</title>&…...

    2024/4/8 23:06:11
  20. mybatis.mapper-locations 包含jar包文件配置多个mapper路径

    在一次的公司项目微服务化的时候,遇到一个问题:项目A中带有mapper.xml文件,项目B中也有其他的mapper.xml。这个时候项目A在某些场景的情况下需要把B打成JAR包引入到A,那么这个时候两个项目的包路径不一致,,mapper.xml的路径也不一样,这个时候就需要引入多个路径。项目A:m…...

    2024/4/8 23:06:09

最新文章

  1. SQLAIchemy 异步DBManager封装-01入门理解

    前言 SQLAlchemy 是一个强大的 Python SQL 工具包和对象关系映射&#xff08;ORM&#xff09;系统&#xff0c;是业内比较流行的ORM&#xff0c;设计非常优雅。随着其2.0版本的发布&#xff0c;SQLAlchemy 引入了原生的异步支持&#xff0c;这极大地增强了其在处理高并发和异步…...

    2024/4/20 18:11:03
  2. 梯度消失和梯度爆炸的一些处理方法

    在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言&#xff0c;在此感激不尽。 权重和梯度的更新公式如下&#xff1a; w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...

    2024/3/20 10:50:27
  3. 4.docker 容器的数据卷

    docker 容器的数据卷 配置数据卷 创建启动容器时&#xff0c;使用-v参数 设置数据卷。 docker run -it --nameXXX -v /root/data:/root/data_container centos:7 /bin/bash XXX : 名称 /root/data &#xff1a; 宿主机目录&#xff08;文件&#xff09; /root/data_contai…...

    2024/4/18 23:22:03
  4. vscode安装通义灵码

    作为vscode的插件&#xff0c;直接使用 通义灵码-灵动指间&#xff0c;快码加编&#xff0c;你的智能编码助手 通义灵码&#xff0c;是一款基于通义大模型的智能编码辅助工具&#xff0c;提供行级/函数级实时续写、自然语言生成代码、单元测试生成、代码注释生成、代码解释、研…...

    2024/4/17 11:39:55
  5. 面试算法-140-接雨水

    题目 给定 n 个非负整数表示每个宽度为 1 的柱子的高度图&#xff0c;计算按此排列的柱子&#xff0c;下雨之后能接多少雨水。 示例 1&#xff1a; 输入&#xff1a;height [0,1,0,2,1,0,1,3,2,1,2,1] 输出&#xff1a;6 解释&#xff1a;上面是由数组 [0,1,0,2,1,0,1,3,2…...

    2024/4/19 11:00:11
  6. 416. 分割等和子集问题(动态规划)

    题目 题解 class Solution:def canPartition(self, nums: List[int]) -> bool:# badcaseif not nums:return True# 不能被2整除if sum(nums) % 2 ! 0:return False# 状态定义&#xff1a;dp[i][j]表示当背包容量为j&#xff0c;用前i个物品是否正好可以将背包填满&#xff…...

    2024/4/19 19:02:10
  7. 【Java】ExcelWriter自适应宽度工具类(支持中文)

    工具类 import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.CellType; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.ss.usermodel.Sheet;/*** Excel工具类** author xiaoming* date 2023/11/17 10:40*/ public class ExcelUti…...

    2024/4/20 15:00:23
  8. Spring cloud负载均衡@LoadBalanced LoadBalancerClient

    LoadBalance vs Ribbon 由于Spring cloud2020之后移除了Ribbon&#xff0c;直接使用Spring Cloud LoadBalancer作为客户端负载均衡组件&#xff0c;我们讨论Spring负载均衡以Spring Cloud2020之后版本为主&#xff0c;学习Spring Cloud LoadBalance&#xff0c;暂不讨论Ribbon…...

    2024/4/19 11:33:34
  9. TSINGSEE青犀AI智能分析+视频监控工业园区周界安全防范方案

    一、背景需求分析 在工业产业园、化工园或生产制造园区中&#xff0c;周界防范意义重大&#xff0c;对园区的安全起到重要的作用。常规的安防方式是采用人员巡查&#xff0c;人力投入成本大而且效率低。周界一旦被破坏或入侵&#xff0c;会影响园区人员和资产安全&#xff0c;…...

    2024/4/19 11:52:08
  10. VB.net WebBrowser网页元素抓取分析方法

    在用WebBrowser编程实现网页操作自动化时&#xff0c;常要分析网页Html&#xff0c;例如网页在加载数据时&#xff0c;常会显示“系统处理中&#xff0c;请稍候..”&#xff0c;我们需要在数据加载完成后才能继续下一步操作&#xff0c;如何抓取这个信息的网页html元素变化&…...

    2024/4/20 9:42:32
  11. 【Objective-C】Objective-C汇总

    方法定义 参考&#xff1a;https://www.yiibai.com/objective_c/objective_c_functions.html Objective-C编程语言中方法定义的一般形式如下 - (return_type) method_name:( argumentType1 )argumentName1 joiningArgument2:( argumentType2 )argumentName2 ... joiningArgu…...

    2024/4/20 7:01:14
  12. 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】

    &#x1f468;‍&#x1f4bb;博客主页&#xff1a;花无缺 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! 本文由 花无缺 原创 收录于专栏 【洛谷算法题】 文章目录 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】&#x1f30f;题目描述&#x1f30f;输入格…...

    2024/4/19 11:52:49
  13. 【ES6.0】- 扩展运算符(...)

    【ES6.0】- 扩展运算符... 文章目录 【ES6.0】- 扩展运算符...一、概述二、拷贝数组对象三、合并操作四、参数传递五、数组去重六、字符串转字符数组七、NodeList转数组八、解构变量九、打印日志十、总结 一、概述 **扩展运算符(...)**允许一个表达式在期望多个参数&#xff0…...

    2024/4/19 18:52:15
  14. 摩根看好的前智能硬件头部品牌双11交易数据极度异常!——是模式创新还是饮鸩止渴?

    文 | 螳螂观察 作者 | 李燃 双11狂欢已落下帷幕&#xff0c;各大品牌纷纷晒出优异的成绩单&#xff0c;摩根士丹利投资的智能硬件头部品牌凯迪仕也不例外。然而有爆料称&#xff0c;在自媒体平台发布霸榜各大榜单喜讯的凯迪仕智能锁&#xff0c;多个平台数据都表现出极度异常…...

    2024/4/19 23:08:02
  15. Go语言常用命令详解(二)

    文章目录 前言常用命令go bug示例参数说明 go doc示例参数说明 go env示例 go fix示例 go fmt示例 go generate示例 总结写在最后 前言 接着上一篇继续介绍Go语言的常用命令 常用命令 以下是一些常用的Go命令&#xff0c;这些命令可以帮助您在Go开发中进行编译、测试、运行和…...

    2024/4/20 0:22:23
  16. 用欧拉路径判断图同构推出reverse合法性:1116T4

    http://cplusoj.com/d/senior/p/SS231116D 假设我们要把 a a a 变成 b b b&#xff0c;我们在 a i a_i ai​ 和 a i 1 a_{i1} ai1​ 之间连边&#xff0c; b b b 同理&#xff0c;则 a a a 能变成 b b b 的充要条件是两图 A , B A,B A,B 同构。 必要性显然&#xff0…...

    2024/4/19 23:04:54
  17. 【NGINX--1】基础知识

    1、在 Debian/Ubuntu 上安装 NGINX 在 Debian 或 Ubuntu 机器上安装 NGINX 开源版。 更新已配置源的软件包信息&#xff0c;并安装一些有助于配置官方 NGINX 软件包仓库的软件包&#xff1a; apt-get update apt install -y curl gnupg2 ca-certificates lsb-release debian-…...

    2024/4/20 1:12:38
  18. Hive默认分割符、存储格式与数据压缩

    目录 1、Hive默认分割符2、Hive存储格式3、Hive数据压缩 1、Hive默认分割符 Hive创建表时指定的行受限&#xff08;ROW FORMAT&#xff09;配置标准HQL为&#xff1a; ... ROW FORMAT DELIMITED FIELDS TERMINATED BY \u0001 COLLECTION ITEMS TERMINATED BY , MAP KEYS TERMI…...

    2024/4/19 3:53:57
  19. 【论文阅读】MAG:一种用于航天器遥测数据中有效异常检测的新方法

    文章目录 摘要1 引言2 问题描述3 拟议框架4 所提出方法的细节A.数据预处理B.变量相关分析C.MAG模型D.异常分数 5 实验A.数据集和性能指标B.实验设置与平台C.结果和比较 6 结论 摘要 异常检测是保证航天器稳定性的关键。在航天器运行过程中&#xff0c;传感器和控制器产生大量周…...

    2024/4/19 19:50:16
  20. --max-old-space-size=8192报错

    vue项目运行时&#xff0c;如果经常运行慢&#xff0c;崩溃停止服务&#xff0c;报如下错误 FATAL ERROR: CALL_AND_RETRY_LAST Allocation failed - JavaScript heap out of memory 因为在 Node 中&#xff0c;通过JavaScript使用内存时只能使用部分内存&#xff08;64位系统&…...

    2024/4/20 1:43:00
  21. 基于深度学习的恶意软件检测

    恶意软件是指恶意软件犯罪者用来感染个人计算机或整个组织的网络的软件。 它利用目标系统漏洞&#xff0c;例如可以被劫持的合法软件&#xff08;例如浏览器或 Web 应用程序插件&#xff09;中的错误。 恶意软件渗透可能会造成灾难性的后果&#xff0c;包括数据被盗、勒索或网…...

    2024/4/20 13:55:02
  22. JS原型对象prototype

    让我简单的为大家介绍一下原型对象prototype吧&#xff01; 使用原型实现方法共享 1.构造函数通过原型分配的函数是所有对象所 共享的。 2.JavaScript 规定&#xff0c;每一个构造函数都有一个 prototype 属性&#xff0c;指向另一个对象&#xff0c;所以我们也称为原型对象…...

    2024/4/19 23:35:17
  23. C++中只能有一个实例的单例类

    C中只能有一个实例的单例类 前面讨论的 President 类很不错&#xff0c;但存在一个缺陷&#xff1a;无法禁止通过实例化多个对象来创建多名总统&#xff1a; President One, Two, Three; 由于复制构造函数是私有的&#xff0c;其中每个对象都是不可复制的&#xff0c;但您的目…...

    2024/4/19 10:00:05
  24. python django 小程序图书借阅源码

    开发工具&#xff1a; PyCharm&#xff0c;mysql5.7&#xff0c;微信开发者工具 技术说明&#xff1a; python django html 小程序 功能介绍&#xff1a; 用户端&#xff1a; 登录注册&#xff08;含授权登录&#xff09; 首页显示搜索图书&#xff0c;轮播图&#xff0…...

    2024/4/20 6:45:17
  25. 电子学会C/C++编程等级考试2022年03月(一级)真题解析

    C/C++等级考试(1~8级)全部真题・点这里 第1题:双精度浮点数的输入输出 输入一个双精度浮点数,保留8位小数,输出这个浮点数。 时间限制:1000 内存限制:65536输入 只有一行,一个双精度浮点数。输出 一行,保留8位小数的浮点数。样例输入 3.1415926535798932样例输出 3.1…...

    2024/4/20 3:28:04
  26. 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...

    解析如下&#xff1a;1、长按电脑电源键直至关机&#xff0c;然后再按一次电源健重启电脑&#xff0c;按F8健进入安全模式2、安全模式下进入Windows系统桌面后&#xff0c;按住“winR”打开运行窗口&#xff0c;输入“services.msc”打开服务设置3、在服务界面&#xff0c;选中…...

    2022/11/19 21:17:18
  27. 错误使用 reshape要执行 RESHAPE,请勿更改元素数目。

    %读入6幅图像&#xff08;每一幅图像的大小是564*564&#xff09; f1 imread(WashingtonDC_Band1_564.tif); subplot(3,2,1),imshow(f1); f2 imread(WashingtonDC_Band2_564.tif); subplot(3,2,2),imshow(f2); f3 imread(WashingtonDC_Band3_564.tif); subplot(3,2,3),imsho…...

    2022/11/19 21:17:16
  28. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...

    win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面&#xff0c;在等待界面中我们需要等待操作结束才能关机&#xff0c;虽然这比较麻烦&#xff0c;但是对系统进行配置和升级…...

    2022/11/19 21:17:15
  29. 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...

    有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows&#xff0c;请勿关闭计算机”的提示&#xff0c;要过很久才能进入系统&#xff0c;有的用户甚至几个小时也无法进入&#xff0c;下面就教大家这个问题的解决方法。第一种方法&#xff1a;我们首先在左下角的“开始…...

    2022/11/19 21:17:14
  30. win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...

    置信有很多用户都跟小编一样遇到过这样的问题&#xff0c;电脑时发现开机屏幕显现“正在配置Windows Update&#xff0c;请勿关机”(如下图所示)&#xff0c;而且还需求等大约5分钟才干进入系统。这是怎样回事呢&#xff1f;一切都是正常操作的&#xff0c;为什么开时机呈现“正…...

    2022/11/19 21:17:13
  31. 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...

    Win7系统开机启动时总是出现“配置Windows请勿关机”的提示&#xff0c;没过几秒后电脑自动重启&#xff0c;每次开机都这样无法进入系统&#xff0c;此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一&#xff1a;开机按下F8&#xff0c;在出现的Windows高级启动选…...

    2022/11/19 21:17:12
  32. 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...

    有不少windows10系统用户反映说碰到这样一个情况&#xff0c;就是电脑提示正在准备windows请勿关闭计算机&#xff0c;碰到这样的问题该怎么解决呢&#xff0c;现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法&#xff1a;1、2、依次…...

    2022/11/19 21:17:11
  33. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...

    今天和大家分享一下win7系统重装了Win7旗舰版系统后&#xff0c;每次关机的时候桌面上都会显示一个“配置Windows Update的界面&#xff0c;提示请勿关闭计算机”&#xff0c;每次停留好几分钟才能正常关机&#xff0c;导致什么情况引起的呢&#xff1f;出现配置Windows Update…...

    2022/11/19 21:17:10
  34. 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...

    只能是等着&#xff0c;别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚&#xff0c;只能是考虑备份数据后重装系统了。解决来方案一&#xff1a;管理员运行cmd&#xff1a;net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...

    2022/11/19 21:17:09
  35. 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?

    原标题&#xff1a;电脑提示“配置Windows Update请勿关闭计算机”怎么办&#xff1f;win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢&#xff1f;一般的方…...

    2022/11/19 21:17:08
  36. 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...

    关机提示 windows7 正在配置windows 请勿关闭计算机 &#xff0c;然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;关机提示 windows7 正在配…...

    2022/11/19 21:17:05
  37. 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...

    钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...

    2022/11/19 21:17:05
  38. 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...

    前几天班里有位学生电脑(windows 7系统)出问题了&#xff0c;具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面&#xff0c;长时间没反应&#xff0c;无法进入系统。这个问题原来帮其他同学也解决过&#xff0c;网上搜了不少资料&#x…...

    2022/11/19 21:17:04
  39. 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...

    本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法&#xff0c;并在最后教给你1种保护系统安全的好方法&#xff0c;一起来看看&#xff01;电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中&#xff0c;添加了1个新功能在“磁…...

    2022/11/19 21:17:03
  40. 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...

    许多用户在长期不使用电脑的时候&#xff0c;开启电脑发现电脑显示&#xff1a;配置windows更新失败&#xff0c;正在还原更改&#xff0c;请勿关闭计算机。。.这要怎么办呢&#xff1f;下面小编就带着大家一起看看吧&#xff01;如果能够正常进入系统&#xff0c;建议您暂时移…...

    2022/11/19 21:17:02
  41. 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...

    配置windows update失败 还原更改 请勿关闭计算机&#xff0c;电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;配置windows update失败 还原更改 请勿关闭计算机&#x…...

    2022/11/19 21:17:01
  42. 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...

    不知道大家有没有遇到过这样的一个问题&#xff0c;就是我们的win7系统在关机的时候&#xff0c;总是喜欢显示“准备配置windows&#xff0c;请勿关机”这样的一个页面&#xff0c;没有什么大碍&#xff0c;但是如果一直等着的话就要两个小时甚至更久都关不了机&#xff0c;非常…...

    2022/11/19 21:17:00
  43. 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...

    当电脑出现正在准备配置windows请勿关闭计算机时&#xff0c;一般是您正对windows进行升级&#xff0c;但是这个要是长时间没有反应&#xff0c;我们不能再傻等下去了。可能是电脑出了别的问题了&#xff0c;来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...

    2022/11/19 21:16:59
  44. 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...

    我们使用电脑的过程中有时会遇到这种情况&#xff0c;当我们打开电脑之后&#xff0c;发现一直停留在一个界面&#xff1a;“配置Windows Update失败&#xff0c;还原更改请勿关闭计算机”&#xff0c;等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢&#xff0…...

    2022/11/19 21:16:58
  45. 如何在iPhone上关闭“请勿打扰”

    Apple’s “Do Not Disturb While Driving” is a potentially lifesaving iPhone feature, but it doesn’t always turn on automatically at the appropriate time. For example, you might be a passenger in a moving car, but your iPhone may think you’re the one dri…...

    2022/11/19 21:16:57