Cookbook: Langserve 集成(SDK v2)
Langserve(Python)
LangServe 帮助开发者将 LangChain runnable 和 chain 部署为 REST API。
该库与 FastAPI 集成,并使用 pydantic 进行数据校验。
此外,它还提供了一个客户端,可用于调用部署在服务器上的 runnable。LangChain.js 提供了对应的 JavaScript 客户端。
本 cookbook 演示如何使用 Litefuse 对通过 Langserve 部署的应用进行 trace(使用 LangChain 集成)。我们将在本 notebook 中同时运行服务端和客户端。
设置
注意: 本指南使用我们的 Python SDK v2。我们已经推出了基于 OpenTelemetry 的全新改进版 SDK,请查看 SDK v3,体验更强大、更易用的 SDK。
!pip install fastapi sse_starlette httpx langserve "langfuse<3.0.0" langchain-openai langchainimport os
# 从项目设置页面获取你的项目密钥
# https://litefuse.cloud
os.environ["LANGFUSE_PUBLIC_KEY"] = ""
os.environ["LANGFUSE_SECRET_KEY"] = ""
os.environ["LANGFUSE_HOST"] = "https://litefuse.cloud"
# 你的 openai key
os.environ["OPENAI_API_KEY"] = ""简单 LLM 调用示例
初始化 Langfuse 客户端,并将 Litefuse 配置为 LLM 的 callback handler。然后通过 Langserve 的 add_routes() 添加到 FastAPI。
from langchain_openai import ChatOpenAI
from langchain_core.runnables.config import RunnableConfig
from langfuse import Langfuse
from langfuse.callback import CallbackHandler
from fastapi import FastAPI
from langserve import add_routes
langfuse_handler = CallbackHandler()
# Tests the SDK connection with the server
langfuse_handler.auth_check()
llm = ChatOpenAI()
config = RunnableConfig(callbacks=[langfuse_handler])
llm_with_langfuse = llm.with_config(config)
# Setup server
app = FastAPI()
# Add Langserve route
add_routes(
app,
llm_with_langfuse,
path="/test-simple-llm-call",
)注意:本例使用 TestClient,以便在 notebook 中运行服务端
from fastapi.testclient import TestClient
# Initialize TestClient
client = TestClient(app)
# Test simple route
response = client.post("/test-simple-llm-call/invoke", json={"input": "Tell me a joke?"})示例 trace:https://litefuse.cloud/project/cloramnkj0002jz088vzn1ja4/traces/5f32e2e7-9508-4280-b47b-e0356bc3c81e

LCEL 示例
from langchain.prompts import ChatPromptTemplate
from langchain.schema import StrOutputParser
from langserve import add_routes
# Create Chain
prompt = ChatPromptTemplate.from_template("Tell me a joke about {topic}")
chain = prompt | llm | StrOutputParser()
# Add new route
add_routes(
app,
chain.with_config(config),
path="/test-chain",
)
# Test chain route
response = client.post("/test-chain/invoke", json={"input": {"topic": "Berlin"}})示例 trace:https://litefuse.cloud/project/cloramnkj0002jz088vzn1ja4/traces/261d1006-74ff-4b67-8baf-afdfc827aee2

Agent 示例
from langchain_core.tools import tool
from langchain_core.utils.function_calling import convert_to_openai_tool
from langchain.agents.format_scratchpad.openai_tools import (
format_to_openai_tool_messages,
)
from langchain.agents import AgentExecutor
from langchain.agents.output_parsers.openai_tools import OpenAIToolsAgentOutputParser
from langserve.pydantic_v1 import BaseModel
from langchain_core.prompts import MessagesPlaceholder
class Input(BaseModel):
input: str
prompt = ChatPromptTemplate.from_messages(
[
("system", "You are a helpful assistant."),
("user", "{input}"),
MessagesPlaceholder(variable_name="agent_scratchpad"),
]
)
@tool
def word_length(word: str) -> int:
"""Returns a counter word"""
return len(word)
tools = [word_length]
llm_with_tools = llm.bind(tools=[convert_to_openai_tool(tool) for tool in tools])
agent = (
{
"input": lambda x: x["input"],
"agent_scratchpad": lambda x: format_to_openai_tool_messages(
x["intermediate_steps"]
),
}
| prompt
| llm_with_tools
| OpenAIToolsAgentOutputParser()
)
agent_executor = AgentExecutor(agent=agent, tools=tools)
agent_config = RunnableConfig({"run_name": "agent"}, callbacks=[langfuse_handler])
add_routes(
app,
agent_executor.with_types(input_type=Input).with_config(
agent_config
),
path="/test-agent",
)
response = client.post("/test-agent/invoke", json={"input": {"input": "How long is Leonardo DiCaprios last name?"}})示例 trace:https://litefuse.cloud/project/cloramnkj0002jz088vzn1ja4/traces/ed1d57f9-2f35-4e72-8150-b061f21840a7
