跳转到主要内容

标签(标签)

资源精选(342) Go开发(108) Go语言(103) Go(99) angular(83) LLM(79) 大语言模型(63) 人工智能(53) 前端开发(50) LangChain(43) golang(43) 机器学习(39) Go工程师(38) Go程序员(38) Go开发者(36) React(34) Go基础(29) Python(24) Vue(23) Web开发(20) Web技术(19) 精选资源(19) 深度学习(19) Java(18) ChatGTP(17) Cookie(16) android(16) 前端框架(13) JavaScript(13) Next.js(12) 安卓(11) 聊天机器人(10) typescript(10) 资料精选(10) NLP(10) 第三方Cookie(9) Redwoodjs(9) ChatGPT(9) LLMOps(9) Go语言中级开发(9) 自然语言处理(9) PostgreSQL(9) 区块链(9) mlops(9) 安全(9) 全栈开发(8) OpenAI(8) Linux(8) AI(8) GraphQL(8) iOS(8) 软件架构(7) RAG(7) Go语言高级开发(7) AWS(7) C++(7) 数据科学(7) 智能体(6) whisper(6) Prisma(6) 隐私保护(6) JSON(6) DevOps(6) 数据可视化(6) wasm(6) 计算机视觉(6) 算法(6) Rust(6) 微服务(6) 隐私沙盒(5) FedCM(5) 语音识别(5) Angular开发(5) 快速应用开发(5) 提示工程(5) Agent(5) LLaMA(5) 低代码开发(5) Go测试(5) gorm(5) REST API(5) kafka(5) 推荐系统(5) WebAssembly(5) GameDev(5) CMS(5) CSS(5) machine-learning(5) 机器人(5) 游戏开发(5) Blockchain(5) Web安全(5) nextjs(5) Kotlin(5) 低代码平台(5) 机器学习资源(5) Go资源(5) Nodejs(5) PHP(5) Swift(5) RAG架构(4) devin(4) Blitz(4) javascript框架(4) Redwood(4) GDPR(4) 生成式人工智能(4) Angular16(4) Alpaca(4) 编程语言(4) SAML(4) JWT(4) JSON处理(4) Go并发(4) 移动开发(4) 移动应用(4) security(4) 隐私(4) spring-boot(4) 物联网(4) 网络安全(4) API(4) Ruby(4) 信息安全(4) flutter(4) 专家智能体(3) Chrome(3) CHIPS(3) 3PC(3) SSE(3) 人工智能软件工程师(3) LLM Agent(3) Remix(3) Ubuntu(3) GPT4All(3) 软件开发(3) 问答系统(3) 开发工具(3) 最佳实践(3) RxJS(3) SSR(3) Node.js(3) Dolly(3) 移动应用开发(3) 低代码(3) IAM(3) Web框架(3) CORS(3) 基准测试(3) Go语言数据库开发(3) Oauth2(3) 并发(3) 主题(3) Theme(3) earth(3) nginx(3) 软件工程(3) azure(3) keycloak(3) 生产力工具(3) gpt3(3) 工作流(3) C(3) jupyter(3) 认证(3) prometheus(3) GAN(3) Spring(3) 逆向工程(3) 应用安全(3) Docker(3) Django(3) R(3) .NET(3) 大数据(3) Hacking(3) 渗透测试(3) C++资源(3) Mac(3) 微信小程序(3) Python资源(3) JHipster(3) 语言模型(2) 可穿戴设备(2) JDK(2) SQL(2) Apache(2) Hashicorp Vault(2) Spring Cloud Vault(2) Go语言Web开发(2) Go测试工程师(2) WebSocket(2) 容器化(2) AES(2) 加密(2) 输入验证(2) ORM(2) Fiber(2) Postgres(2) Gorilla Mux(2) Go数据库开发(2) 模块(2) 泛型(2) 指针(2) HTTP(2) PostgreSQL开发(2) Vault(2) K8s(2) Spring boot(2) R语言(2) 深度学习资源(2) 半监督学习(2) semi-supervised-learning(2) architecture(2) 普罗米修斯(2) 嵌入模型(2) productivity(2) 编码(2) Qt(2) 前端(2) Rust语言(2) NeRF(2) 神经辐射场(2) 元宇宙(2) CPP(2) 数据分析(2) spark(2) 流处理(2) Ionic(2) 人体姿势估计(2) human-pose-estimation(2) 视频处理(2) deep-learning(2) kotlin语言(2) kotlin开发(2) burp(2) Chatbot(2) npm(2) quantum(2) OCR(2) 游戏(2) game(2) 内容管理系统(2) MySQL(2) python-books(2) pentest(2) opengl(2) IDE(2) 漏洞赏金(2) Web(2) 知识图谱(2) PyTorch(2) 数据库(2) reverse-engineering(2) 数据工程(2) swift开发(2) rest(2) robotics(2) ios-animation(2) 知识蒸馏(2) 安卓开发(2) nestjs(2) solidity(2) 爬虫(2) 面试(2) 容器(2) C++精选(2) 人工智能资源(2) Machine Learning(2) 备忘单(2) 编程书籍(2) angular资源(2) 速查表(2) cheatsheets(2) SecOps(2) mlops资源(2) R资源(2) DDD(2) 架构设计模式(2) 量化(2) Hacking资源(2) 强化学习(2) flask(2) 设计(2) 性能(2) Sysadmin(2) 系统管理员(2) Java资源(2) 机器学习精选(2) android资源(2) android-UI(2) Mac资源(2) iOS资源(2) Vue资源(2) flutter资源(2) JavaScript精选(2) JavaScript资源(2) Rust开发(2) deeplearning(2) RAD(2)

TLDR:我们宣布支持在浏览器、Cloudflare Workers、Vercel/Next.js、Deno、Supadase Edge Functions中运行LangChain.js,同时支持Node.js ESM和CJS。请参阅安装/升级文档和中断更改列表。

上下文

最初,我们将LangChain.js设计为在Node.js中运行,Node.js是长期存在的服务器端JavaScript运行时。早在二月份(时间过得很快!),我们就开始从社区收集关于我们应该支持哪些其他JS运行时的反馈,并从那时起收到了大量关于让LangChain在浏览器、Deno、Cloudflare Workers、Vercel/Next.JS、Vite、Supadase Edge Functions等上运行的请求。

更改以启用多个环境

从那以后,我们一直在与社区贡献者一起,为尽可能多的JS环境提供支持,这一过程中有一些亮点

  • 在这里将我们的代码库转换为ESM(CJS用户不必担心,我们也提供CJS构建)
  • 在可能的情况下删除了仅节点API的使用
  • 转换流式处理和批处理OpenAI请求以在此处和此处使用fetch
  • 与Replicate的人员合作,将他们的SDK转换为使用fetch
  • 创建了在我们支持的所有运行时中测试导入LangChain的包,请参阅此处
  • 最后,我们更新了导出,以更好地支持可选的依赖项并生成更小的捆绑包,如下所示

一开始,我们设计了这个库,这样你就可以这样使用它了

import { LLMChain } from "langchain/chains";
import { PromptTemplate } from "langchain/prompts";
import { OpenAI } from "langchain/llms";
import { SupabaseVectorStore } from "langchain/vectorstores";
import { CohereEmbeddings } from "langchain/embeddings";
import { GithubRepoLoader } from "langchain/document_loaders";

老办法

但当在Node.js之外运行时,这带来了一些问题

  • 为了支持不断增长的人工智能生态系统,我们一直在添加新的集成,但我们不希望库的安装规模无限增长。因此,我们将第三方SDK作为langchain的可选依赖项。虽然这在Node.js、浏览器和其他捆绑代码的环境中运行良好,但最终的体验相当糟糕,因为许多捆绑器中的一些需要用户进行一些自定义配置,或者要求用户安装所有可选的依赖项。
  • 当代码被捆绑时,开发人员对捆绑包大小的担忧是正确的,并且由于并非所有捆绑器都支持开箱即用的树摇动,LangChain的用户最终会得到比他们预期的更大的代码捆绑包。

不再!我们重新设计了公开第三方集成的方式,上面的代码现在变成了

import { LLMChain } from "langchain/chains";
import { PromptTemplate } from "langchain/prompts";
import { OpenAI } from "langchain/llms/openai";
import { SupabaseVectorStore } from "langchain/vectorstores/supabase";
import { CohereEmbeddings } from "langchain/embeddings/openai";
import { GithubRepoLoader } from "langchain/document_loaders/web/github";

这确保了您不会引入未使用的代码,也不会像以前那样捆绑器阻塞可选的依赖关系。不包含第三方集成的模块(如链和提示)与以前一样。

有关如何升级的详细信息,请查看安装文档。

中断性更改

为了支持多个环境,我们不得不做出一些突破性的更改。这些仅限于:

  • import { Calculator } from "langchain/tools"; moved to import { Calculator } from "langchain/tools/calculator";
  • import { loadLLM } from "langchain/llms"; moved to import { loadLLM } from "langchain/llms/load";对于所有其他负载*功能也是如此

Deprecations

我们现在需要对所有第三方集成进行更精细的导入 import {OpenAI} from "langchain/llms"; 更改为import {OpenAI} from "langchain/llms/openai"。然而,旧的导入仍然保留,但已被弃用。请尽快转换您的代码以使用新的导入,因为我们计划逐步淘汰旧的导入!

测试

最后,介绍一下我们如何测试这一点,以确保将来不会破坏与任何环境的兼容性。对于我们想要支持的每一个新环境

  • 在我们的monorepo中创建了一个测试导出-*包,其中包含一个使用该环境的工具创建的启动项目。例如,对于带有npx的Next.jscreate-next-app@latest
  • 在该测试包中添加了一些LangChain的示例用法
  • 设置包,使其同时包含构建脚本和测试脚本
  • 添加到CI中在隔离docker容器中测试的包列表中。
  • 最终解决出现的任何问题,确保不会破坏任何其他环境

如果我们还没有使用您最喜欢的环境进行测试,我们对添加更多待测试环境的PR持开放态度。如果您在特定环境中运行LangChain.js时遇到任何问题,请告诉我们——我们很乐意提供帮助!