Python缓存利器:cachetools库详解

news/2024/7/8 2:20:19 标签: python, 缓存, cachetools

Python缓存利器:cachetools库详解

    • 1. cachetools简介
    • 2. 安装
    • 3. 基本概念
      • 3.1 LRU Cache (Least Recently Used)
      • 3.2 TTL Cache (Time-To-Live)
      • 3.3 LFU Cache (Least Frequently Used)
    • 4. 使用示例
      • 4.1 使用LRU Cache
      • 4.2 使用TTL Cache
      • 4.3 使用LFU Cache
      • 4.4 缓存装饰器
    • 5. 进阶用法
      • 5.1 自定义键函数
      • 5.2 缓存统计
    • 6. 总结

在开发过程中,我们经常需要使用缓存来提高程序的性能。Python的cachetools库提供了一系列实用的缓存装饰器和缓存类,使得在Python中实现缓存变得简单而高效。本文将详细介绍cachetools库的基本概念和使用方法。

cachetools_4">1. cachetools简介

cachetools是一个Python库,提供了各种内存缓存的实现。它可以用于函数结果缓存、对象缓存等场景,能够有效提升程序性能,减少重复计算。

主要特点:

  • 提供多种缓存策略(LRU, TTL, LFU等)
  • 支持缓存大小限制
  • 线程安全
  • 可用作装饰器,使用简单

2. 安装

使用pip安装cachetools:

pip install cachetools

3. 基本概念

3.1 LRU Cache (Least Recently Used)

LRU缓存会优先淘汰最近最少使用的项目。

3.2 TTL Cache (Time-To-Live)

TTL缓存中的项目在指定时间后过期。

3.3 LFU Cache (Least Frequently Used)

LFU缓存会优先淘汰使用频率最低的项目。

4. 使用示例

4.1 使用LRU Cache

python">from cachetools import LRUCache, cached

# 创建一个最大容量为100的LRU缓存
@cached(cache=LRUCache(maxsize=100))
def fibonacci(n):
    if n < 2:
        return n
    return fibonacci(n-1) + fibonacci(n-2)

# 使用缓存的函数
print(fibonacci(100))

4.2 使用TTL Cache

python">from cachetools import TTLCache, cached
import time

# 创建一个最大容量为100,过期时间为10秒的TTL缓存
cache = TTLCache(maxsize=100, ttl=10)

@cached(cache)
def get_data():
    print("Fetching data...")
    return "Data"

# 第一次调用,会打印"Fetching data..."
print(get_data())

# 立即再次调用,使用缓存,不会打印"Fetching data..."
print(get_data())

# 等待11秒后调用,缓存已过期,会再次打印"Fetching data..."
time.sleep(11)
print(get_data())

4.3 使用LFU Cache

python">from cachetools import LFUCache

# 创建一个最大容量为100的LFU缓存
cache = LFUCache(maxsize=100)

# 添加项目到缓存
cache['key1'] = 'value1'
cache['key2'] = 'value2'

# 访问缓存
print(cache['key1'])

# 当缓存满时,最不常用的项目会被移除

4.4 缓存装饰器

cachetools提供了方便的缓存装饰器:

python">from cachetools import cached, TTLCache
import time

# 使用TTL缓存装饰器
@cached(cache=TTLCache(maxsize=100, ttl=30))
def get_weather(city):
    print(f"Fetching weather for {city}")
    # 模拟API调用
    time.sleep(2)
    return f"Sunny in {city}"

# 第一次调用,会打印"Fetching weather..."
print(get_weather("Beijing"))

# 立即再次调用,使用缓存结果
print(get_weather("Beijing"))

# 不同参数调用,不会使用缓存
print(get_weather("Shanghai"))

5. 进阶用法

5.1 自定义键函数

可以自定义缓存的键生成函数:

python">from cachetools import cached, LRUCache

def make_key(func, *args, **kwargs):
    # 自定义键生成逻辑
    return str(args) + str(kwargs)

@cached(cache=LRUCache(maxsize=100), key=make_key)
def my_function(arg1, arg2):
    return arg1 + arg2

print(my_function(1, 2))
print(my_function(1, 2))  # 使用缓存

5.2 缓存统计

一些缓存类提供了统计信息:

python">from cachetools import LRUCache

cache = LRUCache(maxsize=100)

# 添加一些项目
for i in range(150):
    cache[i] = i * i

print(f"缓存大小: {len(cache)}")
print(f"缓存命中次数: {cache.hits}")
print(f"缓存未命中次数: {cache.misses}")

6. 总结

cachetools库为Python提供了强大而灵活的缓存解决方案。通过使用不同类型的缓存缓存装饰器,我们可以轻松地在程序中实现高效的缓存机制,从而提升程序性能。在处理耗时的计算、频繁的API调用或需要重复访问的数据时,cachetools是一个非常有用的工具。


http://www.niftyadmin.cn/n/5536154.html

相关文章

JavaScript将参数传递给事件处理程序

本篇文件我们将实现导航栏中&#xff0c;选中时候&#xff0c;会将您选中的进行高亮显示&#xff1b; ● 首先我们来获取我们想要的HTML元素 const nav document.querySelector(.nav);● 接着我们来写选中的高亮显示 nav.addEventListener(mouseover, function (e) { //鼠…

5、Redis 缓存设计相关知识点

1. 多级缓存架构 多级缓存架构是一种通过在应用层和数据库层之间添加多个缓存层来提高系统性能和可用性的架构设计。这种设计能够有效减少数据库负载,并提高数据访问速度。常见的多级缓存包括本地缓存、分布式缓存和数据库缓存。 本地缓存:本地缓存位于应用服务器本地,响应…

梧桐数据库:存算分离和存算一体架构的分布式数据库技术分析

摘要&#xff1a; 随着数据量的不断增长和对数据处理性能的要求越来越高&#xff0c;分布式数据库技术成为了数据存储和处理的重要解决方案。存算分离和存算一体是两种常见的分布式数据库架构&#xff0c;它们在数据存储和计算方面有着不同的特点和优势。本文将对存算分离和存算…

bcc python开发示例

文章目录 1. hello_world.py2. hello_fields.py3. sync_timing.py4. disksnoop.py5. hello_perf_output.py6. bitehist.py7. vfsreadlat.py8. urandomread.py9. strlen_count.py10. nodejs_http_server.py11. task_switch.c12. 监视 do_execve 1. hello_world.py from bcc imp…

【Oracle】Oracle常用语句大全

目录 创建/删除数据库创建/删除表其他表操作增加字段修改字段重命名字段删除字段 主键/索引/视图相关数据插入数据更新数据删除字段拼接merge into语法案例素材同时更新和插入记录同步错误 分页查询分组查询/筛选排序连接查询1. 内连接&#xff08;INNER JOIN&#xff09;&…

嵌入式Linux:ARM体系简介

目录 1. 体系结构 2. 指令集 3. 工作状态 4. 工作模式 5. 寄存器 6. 异常与中断 其他 DOS命令 Linux 命令 1. 体系结构 冯-诺依曼体系结构是把数据与指令都 存放在同一存储区域,取数据与取指令利用同一数据总线,结构简单,但速度较慢,取址不能同时取数据。 哈弗结构…

JavaScript如何声明json对象

在JavaScript中&#xff0c;JSON&#xff08;JavaScript Object Notation&#xff09;对象实际上是以JavaScript对象的形式表示的。JSON是一种轻量级的数据交换格式&#xff0c;它基于ECMAScript&#xff08;欧洲计算机协会制定的js规范&#xff09;的一个子集&#xff0c;采用…

vue 组件el-tree添加结构指示线条

效果展示: 注意&#xff1a;组件中需要添加:indent"0" 进行子级缩进处理&#xff0c;否则会出现子级缩进逐级递增 :expand-on-click-node"false" 设置点击箭头图标才会展开或者收起 代码&#xff1a; <el-tree class"tree filter-tree" :da…