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

新网站建设代理商dw中做网站的步骤

新网站建设代理商,dw中做网站的步骤,南京seo外包,长沙排名优化公司以下是一个基于Python实现的缓存淘汰替换策略算法,该算法将缓存分区,并根据不同分区的优先级进行淘汰,同时会自适应地调整缓存汰换的时机和力度,还会与GPTCache自带的LRU和FIFO策略进行对比。 import time from gptcache.manager…

以下是一个基于Python实现的缓存淘汰替换策略算法,该算法将缓存分区,并根据不同分区的优先级进行淘汰,同时会自适应地调整缓存汰换的时机和力度,还会与GPTCache自带的LRU和FIFO策略进行对比。

import time
from gptcache.manager import CacheBase, VectorBase, get_data_manager
from gptcache.processor.pre import get_prompt
from gptcache.adapter.api import init_similar_cache
from gptcache.strategy import LRUCacheStrategy, FIFOCacheStrategy# 定义缓存类
class CustomCache:def __init__(self, capacity):self.capacity = capacityself.high_priority = {}self.hot_window = {}self.medium_priority = {}self.other_cache = {}self.total_count = 0def add(self, key, value, category):# 初始化缓存项字段cache_item = {'value': value,'freshness': 1.0,'activity': 1,'timestamp': time.time(),'eviction_rate': 0.0,'category': category}self.total_count += 1# 根据类别分配到不同分区if category == 'high':self.high_priority[key] = cache_itemelif category == 'hot':self.hot_window[key] = cache_itemelif category == 'medium':self.medium_priority[key] = cache_itemelse:self.other_cache[key] = cache_item# 检查是否需要淘汰if self.total_count > self.capacity:self.evict()def get(self, key):for cache in [self.high_priority, self.hot_window, self.medium_priority, self.other_cache]:if key in cache:cache[key]['activity'] += 1cache[key]['timestamp'] = time.time()cache[key]['freshness'] = 1.0return cache[key]['value']return Nonedef evict(self):# 自适应调整淘汰时机和力度# 这里简单模拟根据当前时间进行调整,实际可根据季节性或周期性数据调整current_time = time.time()if current_time % 3600 < 1800:  # 假设每小时前半段淘汰力度大eviction_count = 2else:eviction_count = 1while self.total_count > self.capacity and eviction_count > 0:if self.other_cache:key = next(iter(self.other_cache))del self.other_cache[key]elif self.medium_priority:key = next(iter(self.medium_priority))del self.medium_priority[key]elif self.hot_window:# 淘汰热点窗口中活跃度最低的项min_activity_key = min(self.hot_window, key=lambda k: self.hot_window[k]['activity'])del self.hot_window[min_activity_key]elif self.high_priority:# 淘汰高优先级中最旧的项oldest_key = min(self.high_priority, key=lambda k: self.high_priority[k]['timestamp'])del self.high_priority[oldest_key]self.total_count -= 1eviction_count -= 1# 对比测试函数
def compare_strategies():capacity = 10# 自定义策略custom_cache = CustomCache(capacity)# LRU策略lru_strategy = LRUCacheStrategy(capacity)lru_cache_base = CacheBase('sqlite')lru_vector_base = VectorBase('faiss', dimension=128)lru_data_manager = get_data_manager(lru_cache_base, lru_vector_base, lru_strategy)init_similar_cache(data_manager=lru_data_manager, pre_embedding_func=get_prompt)# FIFO策略fifo_strategy = FIFOCacheStrategy(capacity)fifo_cache_base = CacheBase('sqlite')fifo_vector_base = VectorBase('faiss', dimension=128)fifo_data_manager = get_data_manager(fifo_cache_base, fifo_vector_base, fifo_strategy)init_similar_cache(data_manager=fifo_data_manager, pre_embedding_func=get_prompt)# 模拟数据访问data = [(i, f"value_{i}", 'high' if i < 3 else 'medium' if i < 6 else 'hot' if i < 8 else 'other') for i in range(20)]custom_hits = 0lru_hits = 0fifo_hits = 0for key, value, category in data:# 自定义策略if custom_cache.get(key) is None:custom_cache.add(key, value, category)else:custom_hits += 1# LRU策略if lru_data_manager.get_data(key, None) is None:lru_data_manager.save(key, value, None, None)else:lru_hits += 1# FIFO策略if fifo_data_manager.get_data(key, None) is None:fifo_data_manager.save(key, value, None, None)else:fifo_hits += 1print(f"Custom Cache Hits: {custom_hits}")print(f"LRU Cache Hits: {lru_hits}")print(f"FIFO Cache Hits: {fifo_hits}")if __name__ == "__main__":compare_strategies()

代码说明:

  1. CustomCache类

    • __init__:初始化缓存分区和容量。
    • add:将缓存项添加到相应的分区,并在需要时调用evict方法进行淘汰。
    • get:根据键查找缓存项,并更新其活跃度、时间戳和新鲜度。
    • evict:根据分区优先级进行淘汰,同时自适应地调整淘汰的时机和力度。
  2. compare_strategies函数

    • 初始化自定义缓存、LRU缓存和FIFO缓存。
    • 模拟数据访问,记录每个缓存的命中次数。
    • 输出每个缓存的命中次数。

注意事项:

  • 代码中使用了GPTCache库,需要确保已经安装了该库。
  • 自适应调整淘汰时机和力度的逻辑可以根据实际需求进行修改,这里只是简单模拟了每小时前半段淘汰力度大的情况。

文章转载自:

http://RuUUSBWu.skmpj.cn
http://7hM54tRR.skmpj.cn
http://ZiHRtXPn.skmpj.cn
http://XxmVzogi.skmpj.cn
http://ZPDe4fRj.skmpj.cn
http://5xEsD8Yv.skmpj.cn
http://GZ3bgWu2.skmpj.cn
http://cjkuzf2a.skmpj.cn
http://dMd7FIEj.skmpj.cn
http://YTNoIUFk.skmpj.cn
http://rgyUcMYU.skmpj.cn
http://DW6XYrZJ.skmpj.cn
http://CRSYS4nM.skmpj.cn
http://60Kidxg9.skmpj.cn
http://WEkBkHbJ.skmpj.cn
http://lwqspGKP.skmpj.cn
http://Geui2QDy.skmpj.cn
http://Ii8AEE9P.skmpj.cn
http://URYEi8vU.skmpj.cn
http://1dfJFZFC.skmpj.cn
http://jKYDmWPK.skmpj.cn
http://bfaWSSj4.skmpj.cn
http://3sEGD1Hf.skmpj.cn
http://gNGfVlSR.skmpj.cn
http://VUSBR1Xj.skmpj.cn
http://DahFHxlR.skmpj.cn
http://czFykQ2o.skmpj.cn
http://rhMWpwah.skmpj.cn
http://KGfFB8sx.skmpj.cn
http://aA3cnXWq.skmpj.cn
http://www.dtcms.com/wzjs/599969.html

相关文章:

  • 网站建设项目概况网站首页布局设计模板
  • 网站做建筑三维图多多鱼网页设计代码
  • 随州网站seo诊断国外网站空间租用费用
  • 企业做的网站推广方案的步骤静态网站没有后台
  • 网站建设空白栏目整改报告谷歌排名推广
  • 蓝海基业做的网站好吗如何用.net做网站
  • 网站开发招标文件范本开源cms下载
  • 住建部城乡建设网站鄂州建设网站
  • 做网站优化要多少钱莱芜金点子最新招聘平台
  • 成都网站建设工资免费企业网站模板html
  • 郑州做的比较好网站公司江苏宜安建设有限公司网站
  • 国内外设计网站商城网站开发需求分析
  • 肇庆 网站建设 骏域网站南宁如何做百度的网站推广
  • wordpress网站做h5分类零售管理系统哪个软件好
  • 响应网站和模板网站北京网站设计合理刻
  • 网站建设氺首选金手指14ec网站域名
  • 银川如何做百度的网站专业的扬州网站建设
  • 网站建设模板后台新建的网站 找不到
  • 个人网站如何加入百度联盟软件界面设计的标准是什么
  • 网站建设手机apphtml自我介绍代码
  • 教研室网站建设大美互助app
  • 大淘客构建自己的网站网上交易系统
  • 做网站出路哪家公司建网站好
  • 网站html模板下载深圳网站建设公司哪家好
  • 做美食直播哪个网站最好免费空间最大的网盘
  • 网站建设 合同网页编辑岗位职责
  • 网站后台编辑技巧溧阳市城乡建设局网站
  • 阿里建站平台官网图片上传 网站建设教学视频教程
  • 柒零叁网站建设网上商城如何做起来
  • 商务网站的建设与管理wordpress mysql 配置