引言
随着AI和数据库技术的发展,Astra DB以其无服务器的架构和便捷的JSON API正在获得越来越多的关注。本文将探讨如何使用Astra DB存储聊天历史记录,并提供一个实用的代码示例来帮助你开始。
主要内容
什么是Astra DB?
Astra DB是基于Apache Cassandra构建的无服务器数据库。它支持向量操作,并通过容易使用的JSON API使得开发者可以轻松访问和操作数据库。
配置Astra DB
在开始之前,你需要一个正在运行的Astra DB实例。可以通过Astra管理面板获取连接密钥。你的API端点通常会是如下格式:
https://01234567-89ab-cdef-0123-456789abcdef-us-east1.apps.astra.datastax.com
而你的Token会类似于:
AstraCS:6gBhNmsk135...
首先,你需要安装必要的库:
%pip install --upgrade --quiet "astrapy>=0.7.1 langchain-community"
然后,设置数据库连接参数和密钥:
import getpass
ASTRA_DB_API_ENDPOINT = input("ASTRA_DB_API_ENDPOINT = ")
ASTRA_DB_APPLICATION_TOKEN = getpass.getpass("ASTRA_DB_APPLICATION_TOKEN = ")
创建数据库会话对象
根据你的数据库位置(本地或云端),创建相应的数据库连接“Session”对象。
from langchain_community.chat_message_histories import AstraDBChatMessageHistory
message_history = AstraDBChatMessageHistory(
session_id="test-session",
api_endpoint=ASTRA_DB_API_ENDPOINT,
token=ASTRA_DB_APPLICATION_TOKEN,
)
# 添加用户消息和AI消息
message_history.add_user_message("hi!")
message_history.add_ai_message("whats up?")
代码示例
以下是完整的代码实现:
import getpass
from langchain_community.chat_message_histories import AstraDBChatMessageHistory
ASTRA_DB_API_ENDPOINT = input("ASTRA_DB_API_ENDPOINT = ") # 使用API代理服务提高访问稳定性
ASTRA_DB_APPLICATION_TOKEN = getpass.getpass("ASTRA_DB_APPLICATION_TOKEN = ")
message_history = AstraDBChatMessageHistory(
session_id="test-session",
api_endpoint=ASTRA_DB_API_ENDPOINT,
token=ASTRA_DB_APPLICATION_TOKEN,
)
message_history.add_user_message("hi!")
message_history.add_ai_message("whats up?")
# 查看历史记录
print(message_history.messages)
常见问题和解决方案
-
网络访问问题:由于某些地区的网络限制,使用API时可能会遇到访问问题。此时,可以考虑使用API代理服务来提高访问稳定性。
-
Token失效:确保Token未过期,必要时可在Astra管理面板重新获取。
总结和进一步学习资源
使用Astra DB可以方便地存储和管理聊天历史记录,这为聊天AI应用带来了极大的便利。如果你想深入了解Astra DB和Cassandra,可以参考以下资源:
参考资料
如果这篇文章对你有帮助,欢迎点赞并关注我的博客。您的支持是我持续创作的动力!
—END—