CategoryResourceRepost/极客时间专栏/深度学习推荐系统实战/线上服务篇/答疑 | 线上服务篇留言问题详解.md
louzefeng d3828a7aee mod
2024-07-11 05:50:32 +00:00

110 lines
13 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<audio id="audio" title="答疑 | 线上服务篇留言问题详解" controls="" preload="none"><source id="mp3" src="https://static001.geekbang.org/resource/audio/b9/cb/b9b773d5c6892244568f7b615dee96cb.mp3"></audio>
你好,我是王喆。
今天是专栏的第二次答疑加餐时间,第一次答疑我已经对基础篇和特征工程篇中常见的问题进行了解答,所以这节课我们重点来看看线上服务篇中很有代表性的课后思考题和留言问题,我会对它们进行一些补充回答,希望对你有帮助。
## 关于项目的开源精神
在开始回答问题之前我想先跟你聊一聊我们SparrowRecsys项目的开源精神。在课程一开始我就说过SparrowRecsys这个项目是我们的一个种子项目它肯定不完美但我希望它是一个工业级推荐系统的雏形。在学习的过程中我希望能够跟你一起完善它让它的羽翼逐渐丰满起来。
让我很高兴的是已经有不少同学投身到改进SparrowRecsys的队伍中来比如GitHub ID叫[dxzmpk](https://github.com/dxzmpk)的同学添加了[Node2vec模型的代码](https://github.com/wzhe06/SparrowRecSys/pull/14)还有GitHub ID叫jason-wang1的同学添加了[多路召回多线程版本的代码](https://github.com/wzhe06/SparrowRecSys/pull/13)还有更多的同学修改了项目中的Bug优化了一些实现感谢你们的投入
我是开源精神的坚定拥护者我也相信在我们的共同努力下SparrowRecsys未来能够发展成为在业界有影响力的开源项目。所以在这里我呼吁同学们能够多参与进来多提Pull Request让我们共同成为项目的第一批原作者。
好,下面我们进入问题解答的环节。
## [《03深度学习基础你打牢深度学习知识的地基了吗》](https://time.geekbang.org/column/article/291245)
**思考题1哪些因素影响着深度学习网络的结构深度学习模型是越深越好吗**
这两个问题我们分开来看,先看看影响深度学习网络结构的因素。在业界的应用中,影响深度学习网络结构的因素非常多。不过,我认为可以总结出二类最主要的因素。
第一类:业务场景中用户行为的特点。很多模型结构的实现是为了模拟用户行为的特点,比如注意力机制的引入是用来模拟用户的注意力行为特点,序列模型是用来模拟用户兴趣变迁,特征交叉层是为了让用户和物品的相关特征进行交叉等等。
第二类:数据规模、算力的制约。这一点“一天”同学回答得非常有价值,在实际的业界应用中,数据规模大起来之后,我们往往不能够随意选择复杂模型,而是要在数据规模,平台算力的制约下,尽量选择效果最优的模型结构。
我们再来看第二个问题,深度学习模型是越深越好吗?
这个答案是否定的。深度学习模型变深之后,并不总是能够提高模型效果,有时候深度的增加对模型效果的贡献是微乎其微的。而且模型复杂之后的负面影响也非常多,比如训练时间加长,收敛所需数据和训练轮数增加,模型不一定稳定收敛,模型过拟合的风险增加等等。所以在模型深度的选择上,我们要在尽量保证效果的前提下,选择结构较简单的方案。
借助这道思考题,我希望能帮助你更好地理解深度学习的特点,以及实际应用中的一些经验。
## [《09线上服务如何在线上提供高并发的推荐服务》](https://time.geekbang.org/column/article/299155)
思考题2在一个高并发的推荐服务集群中负载均衡服务器的作用至关重要如果你是负载均衡服务器的策略设计师你会怎么实现这个“工头”的调度策略让它能够公平又高效地完成调度任务呢比如是按每个节点的能力分配还是按照请求本身的什么特点来分配如何知道什么时候应该扩展节点什么时候应该关闭节点
负载均衡的策略其实有多种选择比如“smjccj”同学的回答就很专业他说可以进行源地址哈希或根据服务器计算能力加权随机分配。这是一个很好的答案这里我再补充一下。通常来说常用的负载均衡的策略有三种分别是轮询调度、哈希调度和一致性哈希调度。我们一一来看。
轮询调度就是以轮询的方式依次把请求调度到不同的服务器。在服务器的算力等硬件配置不同的时候,我们还可以为每个服务器设定权重,按权重比例为能力强的服务器分配更多的请求。
而哈希调度指的是通过某个哈希函数把key分配给某个桶这里key可以是请求中的用户ID物品ID等ID型信息桶的总数就是服务器的总数。这样一来我们就可以把某个用户的请求分配给某个服务器处理。这么做的好处是可以让一个key落在固定的服务器节点上有利于节约服务器内部缓存的使用。
哈希方式的缺点在于无法高效处理故障点一旦某个点有故障需要减少桶的数量或者在QPS增大时需要增加服务器整个分配过程就被完全打乱。因此一致性哈希调度就是更好的解决方案简单来说就是使用哈希环来解决计算节点的增加和减少的问题具体的实现我推荐你参考[《一致性哈希算法的理解与实践》](%E4%B8%80%E8%87%B4%E6%80%A7%E5%93%88%E5%B8%8C%E7%AE%97%E6%B3%95%E7%9A%84%E7%90%86%E8%A7%A3%E4%B8%8E%E5%AE%9E%E8%B7%B5/)这篇文章。
留言问题1在一个成熟的工业级推荐系统中每个用户请求的时间、地点、context都不一样缓存策略是怎么工作的才能把这些数据大部分都缓存起来
<img src="https://static001.geekbang.org/resource/image/a8/y7/a896f3ee7258d3b1ec5e6178b9da0yy7.jpg" alt="">
这里,同学们一定要理解缓存的意义。如果请求中的变量每次都不一样,那我们确实就没有必要进行缓存了,因为每次返回的结果都是不同的。但真实情况往往不是这样,我们其实可以在具体的业务场景中挖掘出巨大的优化空间。
比如,电商网站存在着大量没有购买记录的新用户,我们其实可以根据这些新用户有限的特征把他们分成少量的几个类别,对一个类别内的用户展示同样的推荐结果。这样,我们就没必要每次都请求复杂的推荐模型了。
再比如,同一个用户有可能多次请求同一个页面,如果推荐系统对这些操作进行了缓存,就不用对每次重复的请求重复计算推荐结果了,在处理完首次请求之后,面对之后的重复请求,推荐系统直接返回缓存结果就可以了。当然,推荐系统具体能存储多少用户缓存,也取决于硬件配置,也取决于缓存的过期时间,这些都需要我们灵活进行配置。
留言问题2推荐系统中的冷启动策略指的是什么
<img src="https://static001.geekbang.org/resource/image/c1/18/c19dc90720b21f317450aa7c94b66d18.jpeg" alt="">
冷启动是推荐系统一定要考虑的问题。它是指推荐系统在没有可用信息,或者可用信息很少的情形下怎么做推荐的问题,冷启动可以分为用户冷启动和物品冷启动两类。
用户冷启动是指用户没有可用的行为历史情况下的推荐问题。一般来说我们需要清楚在没有推荐历史的情况下还有什么用户特征可以使用比如注册时的信息访问APP时可以获得的地点、时间信息等等根据这些有限的信息我们可以为用户做一个聚类为每类冷启动用户返回合适的推荐列表。当然我们也可以利用可用的冷启动特征来构建一个较简单的冷启动推荐模型去解决冷启动问题。
对于物品冷启动来说主要处理的是新加入系统的物品它们没有跟用户的交互信息。所以针对物品冷启动我们除了用类似用户冷启动的方式解决它以外还可以通过物品分类等信息找到一些相似物品如果这些相似物品已经具有了预训练的Embedding我们也可以采用相似物品Embedding平均的方式来快速确定冷启动物品的Embedding让它们通过Embedding的方式参与推荐过程。
## [《11召回层如何快速又准确地筛选掉不相关物品》](https://time.geekbang.org/column/article/299494)
留言问题3用户的多兴趣标签怎么与物品的标签进行最优匹配当物品的标签有多层时如何利用上一层的标签
<img src="https://static001.geekbang.org/resource/image/d7/26/d74e828bee4ddde80a2110b75e852026.jpeg" alt="">
这个问题最简单的做法就是把用户的兴趣标签和物品对应的标签都转换成Multi-hot向量然后我们就可以计算出用户和物品的相似度了。
除此之外,我们也可以进一步计算每个兴趣标签的[TF-IDF值](https://baike.baidu.com/item/tf-idf/8816134?fr=aladdin)为标签分配权重后再把它们转换成Multi-hot向量这样我们也可以计算出用户和物品的相似度。
如果标签有多层我们也可以把多层标签全部放到Multi-hot向量中再把高层标签的权重适当降低这也是可行的思路之一。
留言问题4在电商领域下如何解决EGES训练非常慢的问题
<img src="https://static001.geekbang.org/resource/image/7b/d8/7b6f322d2d0cb95c730a33e08a9d86d8.jpeg" alt="">
这是一个非常好的业界实践问题。这里我先给同学们解释一下什么是EGES。EGES指的是阿里提出的一种Graph Embedidng方法全称是Enhanced Graph Embedding with Side Information补充信息增强图Embedding。它是一种融合了经典的Deep Walk Graph Embedding结果和其他特征的Embedding方法。
针对EGES的训练比较慢的问题我这里有两条建议可供同学们参考。
第一条是我们可以把商品Embedding进行预训练再跟其他side information特征一起输入EGES不用直接在EGES中加Embedding层进行End2End训练。
第二条是我们可以把商品进行聚类后再输入EGES网络比如非常类似的商品可以用一个商品聚类id替代当作一个商品来处理。事实上这种方法往往可以大幅减少商品数量的量级AirBnb就曾经非常成功地应用了该方法用一些特征的组合来代替一类商品或用户不仅大幅加快训练速度而且推荐效果也没有受到影响。
## [《12局部敏感哈希如何在常数时间内搜索Embedding最近邻》](https://time.geekbang.org/column/article/301739)
留言问题5在用Item2vec等方法生成物品Embedding后用户的Embedding是怎么生成的呢 物品和用户在同一个向量空间,这是怎么保证的呢?
<img src="https://static001.geekbang.org/resource/image/d7/02/d74505c44e579c2aac7f8990b50d8102.jpeg" alt="">
在咱们的项目里用户Embedding的生成方法是很直观的就是对用户评论过的高分电影Embedding取平均值得到的。这相当于说用户Embedding是在物品Embedding向量空间中进行运算得到的那它们肯定是在一个向量空间内我们也就可以使用相似度计算来求取相似度。
因此只要是利用用户历史的Item Embedding生成的用户Embedding都是在一个向量空间内这些生成方式包括average pooling、sum pooling、attention等等。
但是如果用户Embedding和物品Embedding是分别独立生成的或者说是通过一个模型中没有直接关系的两个Embedidng层生成的那么它们就不在一个向量空间内了。注意啦这个时候我们不能直接求用户和物品之间的相似度只能求用户-用户的相似度,和物品-物品的相似度。
留言问题6“在局部敏感哈希的函数中b是0到w间的一个均匀分布随机变量是为了避免分桶边界固化”。这是什么意思呢是说可以通过调整b来形成另外一个个Hash函数
<img src="https://static001.geekbang.org/resource/image/40/db/40559a19901eb73aa9a7871b7cb973db.jpeg" alt="">
首先,我要说这个局部敏感哈希相关的问题非常好,推荐其他同学也关注一下。
说回到这个问题如果我们总是固定分桶的边界很容易让边界两边非常接近的点被分到两个桶里这是我们不想看到的。所以这里我们就可以通过随机调整b的方式来生成多个Hash函数在进行多个Hash函数的分桶之后再采用或的方式对分桶结果进行组合查找最近邻向量就可以一定程度避免这些边界点的问题。
好了这节课的答疑就到这里非常感谢同学们的积极提问和思考。希望在接下来的课程里你也能多多参与进来与我一起完善SparrowRecsys项目的代码共同进步