Amazon Neptune 与 Cypher
Amazon Neptune 是高性能图分析和无服务器数据库,具有卓越的可扩展性和可用性。
此示例展示了 QA 链,该链使用
openCypher
查询Neptune
图数据库,并返回人类可读的响应。Cypher 是一种声明式图查询语言,允许在属性图中进行富有表现力且高效的数据查询。
openCypher 是 Cypher 的开源实现。# Neptune Open Cypher QA 链 此 QA 链使用 openCypher 查询 Amazon Neptune 并返回人类可读的响应
LangChain 同时支持 Neptune 数据库 和 Neptune Analytics 与 create_neptune_opencypher_qa_chain
。
Neptune 数据库是为实现最佳可扩展性和可用性而设计的无服务器图数据库。它为需要扩展到每秒 100,000 次查询的图数据库工作负载、多可用区高可用性和多区域部署提供了解决方案。您可以将 Neptune 数据库用于社交网络、欺诈警报和 Customer 360 应用程序。
Neptune Analytics 是一种分析数据库引擎,可以快速分析内存中的大量图数据,以获得洞察力和发现趋势。Neptune Analytics 是一种用于快速分析现有图数据库或存储在数据湖中的图数据集的解决方案。它使用流行的图分析算法和低延迟分析查询。
使用 Neptune 数据库
from langchain_aws.graphs import NeptuneGraph
host = "<neptune-host>"
port = 8182
use_https = True
graph = NeptuneGraph(host=host, port=port, use_https=use_https)
使用 Neptune Analytics
from langchain_aws.graphs import NeptuneAnalyticsGraph
graph = NeptuneAnalyticsGraph(graph_identifier="<neptune-analytics-graph-id>")
使用 Neptune openCypher QA 链
此 QA 链使用 openCypher 查询 Neptune 图数据库,并返回人类可读的响应。
from langchain_aws import ChatBedrockConverse
from langchain_aws.chains import create_neptune_opencypher_qa_chain
MODEL_ID = "anthropic.claude-3-5-sonnet-20241022-v2:0"
llm = ChatBedrockConverse(
model=MODEL_ID,
temperature=0,
)
chain = create_neptune_opencypher_qa_chain(llm=llm, graph=graph)
result = chain.invoke("How many outgoing routes does the Austin airport have?")
print(result["result"].content)
Austin airport has 98 outgoing routes.
添加消息历史记录
Neptune openCypher QA 链能够被 RunnableWithMessageHistory
包装。这会将消息历史记录添加到链中,使我们能够创建一个聊天机器人,该机器人可以在多次调用中保留对话状态。
首先,我们需要一种存储和加载消息历史记录的方法。为此,每个线程都将创建为 InMemoryChatMessageHistory
的实例,并存储到字典中以便重复访问。
(另请参阅:https://python.langchain.ac.cn/docs/versions/migrating_memory/chat_history/#chatmessagehistory)
from langchain_core.chat_history import InMemoryChatMessageHistory
chats_by_session_id = {}
def get_chat_history(session_id: str) -> InMemoryChatMessageHistory:
chat_history = chats_by_session_id.get(session_id)
if chat_history is None:
chat_history = InMemoryChatMessageHistory()
chats_by_session_id[session_id] = chat_history
return chat_history
现在,QA 链和消息历史记录存储可用于创建新的 RunnableWithMessageHistory
。请注意,我们必须将 query
设置为输入键,以匹配基础链期望的格式。
from langchain_core.runnables.history import RunnableWithMessageHistory
runnable_with_history = RunnableWithMessageHistory(
chain,
get_chat_history,
input_messages_key="query",
)
在调用链之前,需要为新的 InMemoryChatMessageHistory
将记住的对话生成唯一的 session_id
。
import uuid
session_id = uuid.uuid4()
最后,使用 session_id
调用启用消息历史记录的链。
result = runnable_with_history.invoke(
{"query": "How many destinations can I fly to directly from Austin airport?"},
config={"configurable": {"session_id": session_id}},
)
print(result["result"].content)
You can fly directly to 98 destinations from Austin airport.
当使用相同的 session_id
继续调用链时,响应将在对话中先前查询的上下文中返回。
result = runnable_with_history.invoke(
{"query": "Out of those destinations, how many are in Europe?"},
config={"configurable": {"session_id": session_id}},
)
print(result["result"].content)
You can fly directly to 4 destinations in Europe from Austin airport.
result = runnable_with_history.invoke(
{"query": "Give me the codes and names of those airports."},
config={"configurable": {"session_id": session_id}},
)
print(result["result"].content)
The four European destinations you can fly to directly from Austin airport are:
- AMS (Amsterdam Airport Schiphol)
- FRA (Frankfurt am Main)
- LGW (London Gatwick)
- LHR (London Heathrow)