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

【langchain学习】使用缓存优化langchain中的LLM调用性能:内存、SQLite与Redis的对比

在处理语言模型(LLM)调用时,特别是在需要多次执行相同请求的情况下,缓存机制能够显著提升系统的性能。本文通过对比内存缓存(InMemoryCache)、SQLite缓存(SQLiteCache)和Redis缓存(RedisCache),探讨了如何在Langchain中使用这些缓存机制来优化LLM调用的性能。

代码实现与性能测试

我们在Python中实现了三种缓存机制,并测试了它们的性能。以下是完整的代码实现及其对应的执行结果。

内存缓存(InMemoryCache)

内存缓存是最简单的缓存机制,它将数据存储在内存中,具有极高的访问速度,但缺点是数据不会持久化,程序重启后缓存数据会丢失。

from langchain.globals import set_llm_cache
from config import llm
from langchain.cache import InMemoryCache
import time# 开始计时
start_time = time.time()# 设置内存缓存
set_llm_cache(InMemoryCache())# 第一次调用,由于缓存中没有内容,因此可能会较慢
llm.invoke("介绍一下2023年环法冠军温格高")# 结束计时
end_time = time.time()# 打印执行时间
print(f"Execution first time: {end_time - start_time
http://www.lryc.cn/news/420418.html

相关文章:

  • spring boot 集成EasyExcel
  • 获取对象中第一个存在的值
  • Python学习笔记----集合与字典
  • c# 排序、强转枚举
  • “华为杯”第十六届中国研究生数学建模竞赛-C题:视觉情报信息分析
  • html+css+js网页设计 找法网2个页面(带js)ui还原度百分之90
  • 018 | backtrader回测反转策略
  • 《图解HTTP》全篇目录
  • 基于VS2019(Release_x64)+Qt的软件开发—环境配置
  • 【书生大模型实战营(暑假场)闯关材料】入门岛:第1关 Linux 基础知识
  • 240810-Gradio通过HTML组件打开本地文件+防止网页跳转到about:blank
  • go在linux上安装
  • 算法日记day 35(动归之分割等和子集|最后一块石头的重量2)
  • FPGA使用sv生成虚拟单音数据
  • Linux shell编程:监控进程CPU使用率并使用 perf 抓取高CPU进程信息
  • Linux网络编程的套接字分析(其一,基本知识)
  • 后端Web开发之Maven
  • 前端创新实践:用JavaScript打造网页扫码新体验
  • AWS CLI命令行
  • 领导力培养的底层逻辑
  • 【MATLAB第107期】基于MATLAB的Morris局部敏感性分析模型(无目标函数)
  • Tomcat搭建JSPServlet
  • 32位定点数和32/64位浮点数的二进制生成方法
  • STM32利用arm-dsp库进行FIR低通滤波【详细】
  • Efficient-KAN 源码详解
  • Jlink commander使用方法(附指令大全)
  • Java SpringBoot实现PDF转图片
  • elasticsearch SQL:在Elasticsearch中启用和使用SQL功能
  • Java 并发编程:线程变量 ThreadLocal
  • 【OpenHarmony4.1 之 U-Boot 2024.07源码深度解析】018 - init_sequence_f 各函数源码分析(二)