多路召回之-PGSQL的关键词检索分词插件安装

RAG检索增强应用中,往往需要使用多路召回文档,传统的词向量语义相似和关键词检索是常用的组合,spring-ai默认实现了语义相似的召回,postgresql中可直接创建向量插件,但RAG关键词检索我们自己实现时可能需要补充基于分词的召回方案,意味着需要额外安装分词插件。除部分云数据库外,自部署pgsql往往不能直接create extension创建分词插件。本文介绍两种常用的分词插件的编译安装方式。

推荐首选jieba分词,针对新词感知和领域分词更加准确。

注:下文分词部署都是基于centos系列的系统(作为数据基础设施不推荐docker部署),使用linux安装源安装好pgsql后,编译部署流程如下。

公共依赖

安装好pgsql后,执行源码编译依赖安装

复制代码
sudo yum install boost-devel

结巴分词部署方案

由于云服务器一般有github访问限制,所以使用支持访问的代码库,部署方案参考:https://www.modb.pro/db/616771

创建目录和源码下载,生成build文件

复制代码
mkdir /opt/wwwroot/pgsql/jieba

cd /opt/wwwroot/pgsql/jieba

git clone https://gitee.com/shawnyan/pg_jieba --depth=1

git clone https://gitee.com/shawnyan/cppjieba --depth=1 pg_jieba/libjieba

git clone https://gitee.com/shawnyan/limonp --depth=1 pg_jieba/libjieba/deps/limonp

cd pg_jieba

mkdir build
cd build

查找pgsql中的extension 和 tsearch_data 路径

基于centos的路径一般默认为 /usr/share/pgsql/

查找pgsql的log和postgresql.conf目录

基于centos的路径一般默认为 /var/lib/pgsql/data

查找pgsql的lib,即so文件防止位置目录

#通过指令查询

复制代码
pg_config --pkglibdir
#得到如下路径
/usr/lib64/pgsql

确定lib路径后生成编译引导,注意使用cmake3指令,需检查安装支持

复制代码
#执行生成器
cmake3 -DCMAKE_PREFIX_PATH=/usr/lib64/pgsql/ ..
#执行编译运行
make

忽略warning级别提示,如无报错,即完成编译,可以将程序和配置拷贝到pgsql指定目录中

复制代码
# 拷贝程序库文件
cp /opt/wwwroot/pgsql/jieba/pg_jieba/build/pg_jieba.so /usr/lib64/pgsql

拷贝词典配置

复制代码
cp /opt/wwwroot/pgsql/jieba/pg_jieba/libjieba/dict/jieba.dict.utf8 /usr/share/pgsql/tsearch_data/jieba_base.dict
cp /opt/wwwroot/pgsql/jieba/pg_jieba/libjieba/dict/user.dict.utf8 /usr/share/pgsql/tsearch_data/jieba_user.dict
cp /opt/wwwroot/pgsql/jieba/pg_jieba/libjieba/dict/hmm_model.utf8 /usr/share/pgsql/tsearch_data/jieba_hmm.model
cp /opt/wwwroot/pgsql/jieba/pg_jieba/libjieba/dict/stop_words.utf8 /usr/share/pgsql/tsearch_data/jieba.stop
cp /opt/wwwroot/pgsql/jieba/pg_jieba/pg_jieba.control /usr/share/pgsql/extension/pg_jieba.control
cp /opt/wwwroot/pgsql/jieba/pg_jieba/pg_jieba.sql /usr/share/pgsql/extension/pg_jieba--1.1.1.sql

进入pgsql程序conf目录 添加配置

复制代码
cd /var/lib/pgsql/data
vim postgresql.conf
shared_preload_libraries = 'pg_jieba'

重启pgsql

复制代码
systemctl restart postgresql

sql终端测试

复制代码
DROP EXTENSION IF EXISTS pg_jieba CASCADE;
create extension pg_jieba;

-- 查看是否存在jieba分词配置
select * from pg_ts_parser;
SELECT * from pg_ts_config;

-- 重新载入词典或分词配置
SELECT jieba_reload_dict();
SELECT pg_reload_conf();

-- 验证分词
select * from to_tsvector('jiebacfg', '这里是测试分词');
SELECT * FROM ts_debug('jiebacfg', '这里是测试分词');

-- 如报错,可定位log查看日志,日志调为debug模式
ALTER SYSTEM SET log_min_messages = 'DEBUG1';

zhparser分词部署方案

源码库参考https://github.com/amutu/zhparser

创建目录和源码下载,云环境可使用镜像地址或本地上传文件后编译,完成指令流程如下

复制代码
# 编译源码下载
cd /opt/wwwroot/pgsql
git clone https://github.com/amutu/zhparser.git
cd zhparser

# 其他依赖scws安装
mkdir scws
cd scws
wget http://www.xunsearch.com/scws/down/scws-1.2.3.tar.bz2

# 如不支持bz2的解压,需下载bzip2解压工具
sudo yum install -y bzip2

# 解压scws
tar xvjf scws-1.2.3.tar.bz2
cd scws-1.2.3
./configure

# 校验编译安装
## 编译安装scws
make

## 校验程序库文件
ls /usr/local/lib/libscws.so
## 检查scws是否可自行 提示参数报错正常
/usr/local/bin/scws -h

编译zhparser

复制代码
# 返回上层开始编译zhparser
cd ..
-- 编译,如果提示报错需要查看文件编码 cat -A Makefile
SCWS_HOME=/usr/local make && sudo make install
-- 自动加载配置
ldconfig

sql终端测试

复制代码
CREATE EXTENSION zhparser;

SELECT * FROM ts_parse('zhparser', 'hello world! 这里是测试分词');

后续将介绍如何实现spring-ai中RAG的 本地文档+pgsql-bm25关键词检索+语义相似度向量检索+云文档的多路召回的实现方案。

相关推荐
bulingg2 小时前
bert常见的变体
人工智能·深度学习·bert
大千AI助手2 小时前
惰性学习:延迟决策的机器学习范式
人工智能·机器学习·大千ai助手·惰性学习·懒惰学习·lazy learning·基于记忆的学习
南极星10052 小时前
OPENCV(python)——初学之路(十三)分水岭算法的图像切割
人工智能·opencv·计算机视觉
Aspect of twilight2 小时前
各种attention的变体:MHA,GQA,MQA,MLA(DeepSeek-V2)详解
人工智能·attention
彼岸花开了吗2 小时前
构建AI智能体:四十五、从专用插件到通用协议:MCP如何重新定义AI工具生态
人工智能·python·mcp
tangdou3690986552 小时前
AI真好玩系列-Three.js手势控制游戏开发教程 | Interactive Game Development with Three.js Hand Con
前端·人工智能·ai编程
StableAndCalm2 小时前
什么是cuda
人工智能
许泽宇的技术分享2 小时前
当AI竞赛遇上云原生:EvalAI如何用450+挑战赛重新定义机器学习评估标准
人工智能·机器学习·云原生
测试人社区—84162 小时前
当AI遇见测试:构建自适应自修复测试框架的开源实践
人工智能