首页 iOS网络层设计二-缓存方案深入
文章
取消

iOS网络层设计二-缓存方案深入

1. YYCache分析

 1. 优点:

  1. 内部支持数据库存储、文件存储、或混合存储。

  2. 使用LRU算法,最久未被使用的优先清除,以缓存总个数、缓存总开销、是否过期三个维度进行清理。

 2. 缺点:

  1. 是否过期这个维度不是根据写入时间去做的判断,而是根据访问时间,一次访问将更新刷新缓存时间,依此为基础再重新开始算过期时长

  2. 所以,更加适合的是图片这种只要url一致则图片永远不会发生变更的场景。对于网络层缓存这种场景来说,很可能经常使用的缓存一直不过期,一直无法加载最新网络数据。

2. NSURLCache分析

流程图

 1. 缺点:

  1. 只能缓存get请求,post请求不能缓存。

  2. 不够灵活,只能设置一个缓存总文件夹,不能分别指定每个文件缓存的位置。

  3. 苹果没有公开其内部实现的缓存策略是LRU还是别的,所以在超过缓存大小时哪些缓存会被清理掉是不确定的。

  4. 依赖于云端设置Cache-Control:max-age、ETag、Last-Modified才能实现缓存,如果云端设置为Cache-Control:no-cache、Cache-Control:no-store、ETag没设置、Last-Modified没设置,则客户端无法实现缓存机制。

3. hyperoslo/Cache分析

 1. 磁盘缓存完全根据过期时间进行清理,没有LRU算法。

 2. 内存缓存在根据过期时间进行清理的前提下如果还超了缓存count和cost,则由NSCache来决定其清理策略。

4. 网络层Cache选型

 1. 对比发现,hyperoslo/Cache比较适合用来做网络层缓存,可以支持GET、POST等Method,灵活性高。

 2.其根据过期时间进行清理的方式契合网络层缓存方式。

 3.支持实现Codable协议的可以直接缓存,看出作者考虑到了网络返回Model缓存的场景匹配性。

5. MD5值是否会发生哈希碰撞

 1.两个不同的字符串可以生成相同的MD5哈希码吗?

  md5的冲突率是多少?

  根据这两个链接的说的,MD5的算法被设计为最小化碰撞的可能性,在128位MD5中,两个任意值,碰撞概率只有2^-128.

 2. SDWebImage、YYCache、Cache这些著名三方框架都是使用md5值作为filename去存储的。

 3. 不用md5存的话不确定会不会有其他问题,比如特殊字符、比如超过文件名最大长度。

6. 缓存过期问题,变了之后怎么处理。

 问:

  如果上午发起请求后服务端返回数据给客户端,客户端缓存到了本地,下午再次发起请求时服务端实际已经变了,但是取的客户端缓存,还是老数据,这种情况怎么处理?

 答:

  1. 我认为这个需要根据时效性要求来定,如果有很高的时效性要求,就不能使用缓存,而是使用remote来请求。

  2.或者根据具体场景选择是否使用localThenRemote。

  3.而localOrRemote需要谨慎使用,在时效性要求不高的场景来使用,依赖客户端的过期时长,过期后再次从服务器拉取。

  4.还可以这样,比如在一级页面请求remote刷新缓存,二级以上页面使用localOrRemote。

7,增加缓存版本

 在DiskCache的name字段中增加缓存版本,以app版本为缓存版本,升级版本后删除之前的缓存文件。

8,按照业务设置不同的基类去配置不同的缓存过期时长。

 按照业务去配置不同的缓存过期时长。

9. 参考文章:

YYCache 源码解析 - 掘金

iOS网络缓存扫盲篇–使用两行代码就能完成80%的缓存需求

NSURLCache

10. 有任何问题欢迎评论区留言进行探讨。

本文由作者按照 CC BY 4.0 进行授权

iOS网络层设计一-架构设计

iOS IAP内购全流程解析