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

拼车网站的建设雨实现医疗器械查询

拼车网站的建设雨实现,医疗器械查询,网页游戏平台返利,深圳有名的做公司网站概念 LRU 是按访问时间排序#xff0c;发生淘汰的时候#xff0c;把访问时间最久的淘汰掉。LFU 是按频次排序#xff0c;一个数据被访问过#xff0c;把它的频次 1#xff0c;发生淘汰的时候#xff0c;把频次低的淘汰掉。 几种LRU策略 以下集中LRU测率网上有很多发生淘汰的时候把访问时间最久的淘汰掉。LFU 是按频次排序一个数据被访问过把它的频次 1发生淘汰的时候把频次低的淘汰掉。 几种LRU策略 以下集中LRU测率网上有很多我自己结合项目加以整理。也可以选择跳过。 1. 普通LRU 一般使用双向链表map实现新数据加入链表表头每当缓存命中时将数据移动到表头链表长度超过设定值将尾部数据淘汰 缺点当热点数据较多时随后来了一次偶发性的操作操作的数据较多容易将热点数据淘汰出去。 2. LRU-K 考虑到传统LRU的缺点改进措施是记录数据的被访问次数。维护两个LRU队列一个数据访问次数队列一个缓存队列。当访问达到预设值K时加入到缓存队列中。对于偶然性的访问非热点数据时命中次数不够不会加入到缓存队列中则不会挤出热点数据。 命中数据后加入访问次数队列中被访问次数1同普通LRU的逻辑。淘汰数据。当访问次数超过预设值从此队列中移除加入到缓存队列中按照访问时间排序。缓存队列中的数据再次被命中按照访问时间顺序排序。淘汰数据。 缺点需要谨慎考虑K值的设定设定过大会导致数据很难被淘汰。整体内存消耗也偏高。同时也要按照访问时间重排序。 3. 2Queue 优化重排序问题。 数据被访问后加入到FIFO队列中。FIFO按照访问时间进行淘汰。当数据再次被访问时则移到LRU队列头部。数据再次被访问移动到头部。LRU队列淘汰。 4. Multi Queue 同2Queue增加了多个FIFO队列按照预设条件从左到右逐级提升等级。随着数据被淘汰从右向左逐级降级。 Redis的LRU/LFU策略 内存淘汰策略配置 maxmemory 指定限制内存大小。默认0表示无限制。maxmemory_policy: 指定的淘汰策略目前有以下几种 noeviction 默认值不处理。allkeys-lru对所有的key都采取LRU淘汰策略。volatile-lru仅对设置了过期时间的key采取LRU淘汰。allkeys-random: 随机回收key。Volatile-random: 随机回收设置了过期时间的key。volatile-ttl仅淘汰设置了过期时间的key并淘汰生存时间更小的key。Volatile-lfu: 对设置了过期时间的key采取LFU策略。Allkeys-lfu: 对全部key采取LFU策略 maxmemory_samples 随机采样精度。官方表示配10更接近真实的LRU策略。 2. Redis的LRU策略 给每个key记录一个lru time。每次访问key的时候更新key的lru time。按照策略配置。在一定范围内找访问时间最早的key将其淘汰。具体看下面的源码分析。 3. Redis的LRU策略的缺陷 //从左到右是时间轴每个波浪线代表一个时间单位 //竖线是当前时间点~~~~~A~~~~~A~~~~~A~~~~A~~~~~A~~~~~A~~| ~~B~~B~~B~~B~~B~~B~~B~~B~~B~~B~~B~~B~| ~~~~~~~~~~C~~~~~~~~~C~~~~~~~~~C~~~~~~| ~~~~~D~~~~~~~~~~D~~~~~~~~~D~~~~~~~~~D|//可以看到如果4个key中非要淘汰一个肉眼看出来一定是淘汰D因为它访问的次数最少。但是由于 //当前时间点D再次被访问它的LRU时间又被更新了导致D不会被淘汰范围淘汰了C。 //这种情况就不合理因此redis4.0版本后引入了LFU策略。4. Redis的LFU策略 struct redisObject {unsigned type:4;unsigned encoding:4;//对于lru而言这里记录了lru time//对于lfu而言高24位记录LRU time低8位记录计数器的值最大可表示255unsigned lru:LRU_BITS; int refcount;void *ptr; };给每个key记录一个计数count。由于只有8位长度最多只能表示255因此采用了一个因子控制count的增长速度。新的key加入进来会设置为预设值LFU_INIT_VAL以免为0直接被淘汰。每当这个key被访问时按照增长逻辑增长count值。每当这个key被放入到淘汰候选池内则会降低count值。 5. 源码分析 当执行命令命中数据时更新数据 //查找缓存数据时最终都会调用此函数 //如 lookupKeyRead(), lookupKeyWrite() robj *lookupKey(redisDb *db, robj *key, int flags) {dictEntry *de dictFind(db-dict,key-ptr);...robj *val dictGetVal(de);if (val) { if (不能在执行子任务的时候 !(flags LOOKUP_NOTOUCH)){if (server.maxmemory_policy MAXMEMORY_FLAG_LFU) {//如果是LFU策略这里就增长LFU计数updateLFU(val);} else {//如果是LRU策略这里就更新lru timeval-lru LRU_CLOCK();}}} else {...}return val; }然后在处理指令时如果发现缓存达到了预设值会触发内存淘汰策略 int processCommand(client *c) { ...if (server.maxmemory !isInsideYieldingLongCommand()) {//达到了预设值了这里开始处理内存淘汰逻辑int out_of_memory (performEvictions() EVICT_FAIL);...}... }//伪代码 int performEvictions(void) {if (如果是LRU或者LFU策略或者volatile-ttl策略{while (memFree memNeedFree) {for (i 0; i server.dbnum; i) {db server.dbi;dict (如果淘汰策略是针对allkeys) ? db-dict : db-expires;if (只要dict里有数据) {evictionPoolPopulate(i, dict, db-dict, 淘汰候选池);}}}}else if (如果是两种随机策略){for (i 0; i server.dbnum; i) {//用一个静态变量next_db这样每次都不会只命中第一个dbj (next_db) % server.dbnum;db server.db j;dict (如果淘汰策略是针对allkeys) ? db-dict : db-expires;bestkey 随机找一个keybreak;}}for (k 淘汰候选池大小-1; k 0; k--) {bestkey 从候选池里逆序找真实存在的key }if (bestkey) {最后在这里回收这个key;memFree 新释放的内存}//while执行太久了break掉if (流逝的时间 eviction_time_limit_us) {break;} }开始处理淘汰策略并将合适的key放入淘汰候选池内这个池是已从左到右从小到大排好序的 void evictionPoolPopulate(int dbid, dict *sampledict, //如果策略是allkey则是db-dict,//如果是volatile则为db-expiresdict *keydict, //db-dictstruct evictionPoolEntry *pool) //这个是候选池 {//这里开始采样//server.maxmemory_samples是一个预设值官方建议设置为10count dictGetSomeKeys(sampledict, samples, server.maxmemory_samples);for (j 0; j count; j) {...if (server.maxmemory_policy MAXMEMORY_FLAG_LRU) {//因为每次key在被loopupKey的时候都会更新它自己的lru时间//这个函数lru当前时间 - 当前这个key的lru时间idle estimateObjectIdleTime(o);} else if (server.maxmemory_policy MAXMEMORY_FLAG_LFU) {//取lfu的计数器的计数这里是255 - 数值因为最小访问次数的要被淘汰//注意这里顺带给它减少了LFU计数idle 255-LFUDecrAndReturn(o);} else if (server.maxmemory_policy MAXMEMORY_VOLATILE_TTL) {//常量 - validle ULLONG_MAX - (long)dictGetVal(de);} else {}...} }
http://www.dnsts.com.cn/news/100805.html

相关文章:

  • 手机网站微信分享代码招聘页面设计
  • 双公示 网站专栏建设高级的网站建设
  • 没建网站 备案设计公司官方网站
  • 企业网站建设中期报告模板darna wordpress
  • 深圳网站建设现苏州市建设中心网站首页
  • 中国建设银行建银购网站做编程的+网站
  • 营销型旅游网站建设wordpress模板如何用
  • 建筑公司宣传册设计样本如何结合搜索检索与seo推广
  • 唐山网站制作网络公司大连html5网站建设
  • 四川建设人才官方网站好看的商城网站
  • 朝阳网站建设 慈云寺上海网站建设app
  • 十大免费ppt模板免费下载网站营销目标分为三个方面
  • wordpress pdf阅读进一步优化
  • 免费网站空间免备案各大企业网站文案
  • 东莞seo网站建设建网站怎么上线
  • 青海住房建设网站4大门户网站
  • 手机网站怎么优化网站配色方法
  • 网站开发小图标兴仁市建设局网站
  • 蚌埠网站建设电话北京正规制作网站公司
  • 七台河建网站国内4a广告公司有哪些
  • 做拍客哪个网站好html代码按钮
  • 服装怎么做网站推广连云港企业网站制作
  • 表白网站生成器app拉新工作室
  • 网站建设的pest分析怎么做蒙文网站
  • 临清网站建设价格网页源代码怎么搜索关键词
  • 北京网站建设模板主题建设网站用户名是什么原因
  • 区域教育联盟网站建设wordpress 股票主题
  • 推广网站的图片怎么做成crm网
  • 重庆律师网站建设网站宣传的优点
  • 模板网站怎么建设优化wordpress 8080端口