当前位置: 首页 > article >正文

保姆级教程:在宝塔面板的PostgreSQL 14/15上,手动编译安装pgvector插件(含常见make错误解决)

从零到一在宝塔面板的PostgreSQL中手动编译安装pgvector插件全指南当你需要在PostgreSQL中实现高效的向量相似性搜索时pgvector插件无疑是最佳选择之一。不同于简单的apt-get或yum安装手动编译安装能让你更深入地理解插件与数据库的交互机制特别是在宝塔面板这种定制化环境中。本教程将带你一步步完成从源码编译到最终验证的全过程特别针对那些在make环节频频碰壁的开发者。1. 环境准备与前期检查在开始编译之前确保你的系统环境已经就绪。使用宝塔面板的用户通常已经安装了PostgreSQL但版本和路径可能与标准安装有所不同。首先通过以下命令检查PostgreSQL的版本psql --version对于pgvector插件你需要确认PostgreSQL的开发包是否安装。在基于Debian的系统上可以运行sudo apt-get install postgresql-server-dev-14 # 根据你的PostgreSQL版本调整常见问题很多用户在宝塔环境中遇到pg_config not found错误这是因为宝塔将PostgreSQL安装在非标准路径。解决方法是通过find命令定位pg_configfind / -name pg_config 2/dev/null典型的宝塔安装路径可能是/www/server/pgsql/bin/pg_config记下这个路径后续会频繁用到。2. 获取pgvector源码与版本匹配pgvector的版本需要与PostgreSQL主版本严格匹配。访问pgvector GitHub仓库查看release页面获取正确的版本PostgreSQL版本pgvector版本14.x0.5.x15.x0.6.x下载并解压源码包wget https://github.com/pgvector/pgvector/archive/refs/tags/v0.5.0.tar.gz # 根据版本调整 tar -zxvf v0.5.0.tar.gz cd pgvector-0.5.0关键点不要直接使用master分支的代码除非你明确知道自己在做什么。稳定版本才能保证与特定PostgreSQL版本的兼容性。3. 解决编译环境配置问题这是大多数开发者遇到困难的关键环节。当你在pgvector目录直接运行make时很可能会看到如下错误make: *** No rule to make target /usr/lib/postgresql/16/lib/pgxs/src/makefiles/pgxs.mk. Stop.这个错误表明make系统无法定位PostgreSQL的安装路径。解决方法是通过pg_config设置正确的环境变量。首先找到之前记录的pg_config路径然后执行export PATH/www/server/pgsql/bin:$PATH # 替换为你的实际路径为了让这个设置在每次登录时自动生效将其添加到bash配置文件中echo export PATH/www/server/pgsql/bin:$PATH ~/.bashrc source ~/.bashrc验证配置是否生效which pg_config这个命令应该返回你设置的路径而不是/usr/bin/pg_config这样的系统默认路径。4. 编译安装与错误排查现在可以开始正式的编译安装过程了make clean # 如果之前尝试过编译先清理 make sudo make install常见编译错误及解决方案缺少头文件如果遇到postgres.h not found之类的错误说明PostgreSQL开发包没有正确安装。确保你已经安装了对应版本的postgresql-server-dev包。权限问题在make install阶段如果出现权限拒绝需要在命令前加sudo或者将当前用户加入postgres组sudo usermod -aG postgres $(whoami)版本不匹配如果看到函数未定义的错误很可能是pgvector版本与PostgreSQL版本不兼容。重新检查版本对应关系。内存不足在小内存VPS上编译可能会失败可以尝试添加swap空间sudo fallocate -l 2G /swapfile sudo chmod 600 /swapfile sudo mkswap /swapfile sudo swapon /swapfile5. 数据库配置与插件启用编译安装完成后需要在PostgreSQL中启用插件。首先连接到数据库psql -U postgres # 使用postgres超级用户在psql命令行中执行CREATE EXTENSION vector;重要提示必须使用postgres超级用户或具有CREATEROLE权限的用户某些宝塔面板安装的PostgreSQL可能需要先修改pg_hba.conf文件允许本地信任连接如果遇到extension already exists错误可以先执行DROP EXTENSION vector;验证插件是否安装成功SELECT * FROM pg_available_extensions WHERE name vector;6. 实际应用创建向量表与基本操作现在你已经成功安装了pgvector插件可以开始使用向量功能了。下面是一个完整的文档分片表示例CREATE TABLE document_chunk ( id VARCHAR(64) PRIMARY KEY, document_id VARCHAR(64), chunk TEXT, chunk_index INT, embedding vector(1024) -- 1024维向量 ); -- 添加注释 COMMENT ON TABLE document_chunk IS 文档分片表; COMMENT ON COLUMN document_chunk.id IS 主键id; COMMENT ON COLUMN document_chunk.document_id IS 所属文档id; COMMENT ON COLUMN document_chunk.chunk IS 文档分片内容; COMMENT ON COLUMN document_chunk.chunk_index IS 分片索引; COMMENT ON COLUMN document_chunk.embedding IS 文本嵌入向量; -- 插入示例数据 INSERT INTO document_chunk VALUES ( chunk_001, doc_001, 这是第一个文档分片的内容示例, 0, [0.1, 0.2, 0.3, ..., 0.5]::vector -- 实际使用时替换为真实向量 ); -- 向量相似度查询 SELECT id, chunk, embedding - [0.2, 0.3, 0.4, ..., 0.6]::vector AS distance FROM document_chunk ORDER BY distance LIMIT 5;性能提示对于大规模向量搜索建议创建适当的索引CREATE INDEX ON document_chunk USING ivfflat (embedding vector_l2_ops) WITH (lists 100); -- 根据数据量调整lists参数7. 维护与升级注意事项当你需要升级pgvector插件时流程略有不同备份数据库中所有包含向量列的表删除旧版插件DROP EXTENSION vector;按照前述步骤编译安装新版本重新创建扩展CREATE EXTENSION vector;恢复数据重要提醒pgvector的某些版本升级可能需要重建向量索引建议在低峰期进行操作。对于生产环境定期监控向量索引的性能SELECT tablename, indexname, idx_scan, idx_tup_read, idx_tup_fetch FROM pg_stat_user_indexes WHERE indexname LIKE %vector%;如果发现索引效率下降idx_tup_read远大于idx_tup_fetch可能需要重新构建索引REINDEX INDEX document_chunk_embedding_idx;

相关文章:

保姆级教程:在宝塔面板的PostgreSQL 14/15上,手动编译安装pgvector插件(含常见make错误解决)

从零到一:在宝塔面板的PostgreSQL中手动编译安装pgvector插件全指南 当你需要在PostgreSQL中实现高效的向量相似性搜索时,pgvector插件无疑是最佳选择之一。不同于简单的apt-get或yum安装,手动编译安装能让你更深入地理解插件与数据库的交互…...

Vivado 中 Xilinx DDR4 MIG 的实战配置与性能调优

1. DDR4 MIG IP核基础配置 在Vivado中配置DDR4 MIG(Memory Interface Generator)IP核是搭建高速存储系统的第一步。我最近在一个数据采集项目中就遇到了这个需求,当时需要处理每秒超过5GB的传感器数据流。下面分享我的实战经验,帮…...

Linux共享内存实战:一个生产环境内存泄漏排查案例,教你正确使用shmctl清理残留

Linux共享内存泄漏排查实战:从故障定位到根治方案 凌晨三点,服务器监控突然告警——某核心服务的共享内存使用量异常激增。作为值班工程师,我迅速登录系统,发现ipcs -m命令输出的共享内存段数量比平时多出十几倍。更棘手的是&…...

大麦网抢票脚本终极指南:告别手速限制,轻松抢到心仪演唱会门票

大麦网抢票脚本终极指南:告别手速限制,轻松抢到心仪演唱会门票 【免费下载链接】Automatic_ticket_purchase 大麦网抢票脚本 项目地址: https://gitcode.com/GitHub_Trending/au/Automatic_ticket_purchase 还在为抢不到周杰伦、五月天等热门演唱…...

VC LP低功耗验证全阶段指南:从RTL到GDSII,不同阶段该关注什么?

VC LP低功耗验证全流程实战:分阶段策略与关键检查项解析 在当今芯片设计领域,低功耗已成为与性能、面积同等重要的设计指标。随着工艺节点不断演进,静态功耗在总功耗中的占比显著提升,多电压域设计成为降低功耗的主流方法。然而&…...

别再只盯着Vgs和Id了!用这5个常被忽略的MOS管参数,帮你搞定电源开关电路设计

电源开关电路设计中5个常被忽视的MOS管参数实战解析 当你在设计一个Buck降压电路时,明明已经按照手册选择了足够大电流规格的MOS管,但实际工作中管子却异常发热;或者在做电机驱动时,PWM频率明明不高,MOS管却总是响应迟…...

从“神奇开关”到“智能控制”:用Arduino+双向可控硅(BTA16)DIY一个智能调光台灯

从“神奇开关”到“智能控制”:用Arduino双向可控硅(BTA16)DIY一个智能调光台灯 在智能家居日益普及的今天,调光功能已成为现代照明系统的标配。但对于电子爱好者和创客来说,亲手打造一个可调光台灯不仅能满足个性化需…...

如何用个人AI数据训练守护你的数字记忆:WeChatMsg数据主权完整指南

如何用个人AI数据训练守护你的数字记忆:WeChatMsg数据主权完整指南 【免费下载链接】WeChatMsg 提取微信聊天记录,将其导出成HTML、Word、CSV文档永久保存,对聊天记录进行分析生成年度聊天报告 项目地址: https://gitcode.com/GitHub_Trend…...

CoolProp开源热力学计算库:工程师必备的120+流体物性数据解决方案

CoolProp开源热力学计算库:工程师必备的120流体物性数据解决方案 【免费下载链接】CoolProp Thermophysical properties for the masses 项目地址: https://gitcode.com/gh_mirrors/co/CoolProp 在现代工程设计和科学研究中,热力学物性数据的准确…...

Applite:macOS软件管理的终极图形化解决方案,告别命令行烦恼

Applite:macOS软件管理的终极图形化解决方案,告别命令行烦恼 【免费下载链接】Applite User-friendly GUI macOS application for Homebrew Casks 项目地址: https://gitcode.com/gh_mirrors/ap/Applite 你是否曾经因为要在macOS上安装软件而感到…...

哪些独立站外链策略最有效? 每天多拿50个询盘的绝招

外链(Backlinks)不是单纯的代码堆砌,它在谷歌算法里占据了约30%以上的权重排名信号。想要把每天的询盘量从个位数提升到50个以上,不能靠那种5美金买1000条的垃圾链接。那些链接只会让网站在48小时内被封禁。真实的增长来自于同行没…...

VisionMaster多相机定位实战:手把手教你搞定800mm大物料抓取(附完整标定流程)

VisionMaster多相机定位实战:800mm大物料抓取全流程解析 在工业自动化领域,大尺寸物料的高精度定位一直是视觉工程师面临的棘手挑战。当物料尺寸超过单相机视野范围时,如何实现毫米级定位精度?本文将基于800600mm面板物料抓取场景…...

海康ISAPI接口调优笔记:如何正确设置NET_DVR_STDXMLConfig的超时与缓冲区,避免数据截断和线程卡死

海康ISAPI接口调优实战:NET_DVR_STDXMLConfig参数配置与高并发优化策略 在工业级监控系统与智慧园区解决方案中,海康威视设备的ISAPI接口集成往往是核心环节。许多开发者在使用NET_DVR_STDXMLConfig进行透传调用时,常会遇到数据截断、线程阻塞…...

植物大战僵尸终极修改器:PVZ Toolkit完整使用教程

植物大战僵尸终极修改器:PVZ Toolkit完整使用教程 【免费下载链接】pvztoolkit 植物大战僵尸 PC 版综合修改器 项目地址: https://gitcode.com/gh_mirrors/pv/pvztoolkit 植物大战僵尸PVZ Toolkit是一款专为经典塔防游戏《植物大战僵尸》PC版设计的综合辅助工…...

KMS_VL_ALL_AIO:Windows系统免费激活终极解决方案

KMS_VL_ALL_AIO:Windows系统免费激活终极解决方案 【免费下载链接】KMS_VL_ALL_AIO Smart Activation Script 项目地址: https://gitcode.com/gh_mirrors/km/KMS_VL_ALL_AIO 还在为Windows激活烦恼吗?想象一下这个场景:新电脑到手&…...

【开源项目】tinyprintf:为资源受限MCU定制的极简格式化输出库

1. 为什么嵌入式开发者需要tinyprintf? 在开发STM32、AVR这类资源受限的MCU时,标准库的printf往往会成为项目中的"内存杀手"。我曾经在一个基于STM32F030的项目中,仅仅因为使用了标准printf,编译后的代码体积就暴涨了2…...

NCJ29D5芯片——从射频前端到基带处理的UWB系统架构剖析

1. NCJ29D5芯片的核心定位与应用场景 NCJ29D5是NXP专为汽车电子领域设计的全集成UWB芯片,它的出现让厘米级精度的无线测距变得像使用蓝牙一样简单。我第一次接触这款芯片是在一个汽车数字钥匙项目中,当时客户要求实现"手机靠近车门自动解锁"的…...

告别掏钥匙!一文搞懂汽车无钥匙进入(PKE/RKE)背后的工作原理与安全机制

汽车无钥匙进入系统:从便捷体验到安全防御的技术全景 清晨出门时,裤袋里的钥匙扣从未被掏出,车门却在你触碰把手的瞬间悄然解锁——这种近乎魔法的体验,已经成为现代车主的日常。但少有人思考,当手指划过门把手凹槽的刹…...

抖音批量下载工具完整指南:轻松保存视频、合集与直播内容

抖音批量下载工具完整指南:轻松保存视频、合集与直播内容 【免费下载链接】douyin-downloader A practical Douyin downloader for both single-item and profile batch downloads, with progress display, retries, SQLite deduplication, and browser fallback su…...

SteamCleaner终极指南:3步快速释放游戏缓存,轻松回收硬盘空间

SteamCleaner终极指南:3步快速释放游戏缓存,轻松回收硬盘空间 【免费下载链接】SteamCleaner :us: A PC utility for restoring disk space from various game clients like Origin, Steam, Uplay, Battle.net, GoG and Nexon :us: 项目地址: https://…...

保姆级教程:用ADB给海信电视LED55N3000U做‘瘦身手术’,安全卸载预装软件

海信电视LED55N3000U系统优化实战:ADB安全卸载预装应用指南 当智能电视用久了,系统卡顿、存储空间不足的问题总会不期而至。特别是像海信LED55N3000U这样的机型,VIDAA系统预装的各种应用不仅占用宝贵存储,还可能后台运行消耗资源。…...

用51单片机+DAC0832做个简易信号发生器:手把手教你生成方波、三角波和锯齿波(附完整汇编代码)

51单片机与DAC0832实战:三波形信号发生器的设计与实现 在电子工程和嵌入式系统开发中,信号发生器是一个基础但极其重要的工具。无论是用于电路测试、教学演示还是原型验证,一个可靠的信号源都能大大提升工作效率。本文将带你从零开始&#xf…...

Davinci Configurator实战:利用Supplier Notification机制为你的UDS诊断服务加一把“安全锁”

Davinci Configurator实战:利用Supplier Notification机制构建UDS诊断安全防线 当ECU诊断服务暴露在复杂的车载网络环境中时,未经授权的访问就像未受监控的港口入口,随时可能引发系统性风险。传统DCM模块的标准校验逻辑往往难以应对灵活多变的…...

别再凭感觉调CAN采样点了!手把手教你用VH6501精准测量(附500Kbps实测波形)

精准测量CAN采样点的工程实践指南 在汽车电子开发领域,CAN总线通信的可靠性直接影响着整车系统的稳定性。许多工程师习惯凭借经验设置采样点参数,却常常忽视精确测量的重要性。本文将分享一套基于VH6501干扰仪的标准化测量流程,帮助您摆脱经验…...

RK3588驱动编译踩坑记:手把手教你解决‘-Werror’导致的‘all warnings being treated as errors’

RK3588驱动编译实战:从-Werror报错到内核构建优化的完整指南 当你在深夜的调试灯光下,面对RK3588开发板驱动编译失败的红字报错,那种挫败感每个嵌入式开发者都深有体会。特别是当错误提示"cc1: all warnings being treated as errors&qu…...

EPLAN进阶实战:基于STEP模型的智能箱柜定义与高效拼柜流程详解

1. STEP模型导入与基础检查 第一次接触STEP格式的箱柜模型时,我和很多电气工程师一样犯过不少低级错误。记得有次项目赶进度,直接导入模型就开始操作,结果后面发现根本没法用,白白浪费了两天时间。现在我把这些经验教训总结成一套…...

ComfyUI-Impact-Pack终极指南:掌握AI图像精细化处理的5大核心技巧

ComfyUI-Impact-Pack终极指南:掌握AI图像精细化处理的5大核心技巧 【免费下载链接】ComfyUI-Impact-Pack Custom nodes pack for ComfyUI This custom node helps to conveniently enhance images through Detector, Detailer, Upscaler, Pipe, and more. 项目地址…...

告别单机!用FinalShell和朋友联机玩DNF台服,完整配置与授权文件生成指南

告别单机!用FinalShell和朋友联机玩DNF台服,完整配置与授权文件生成指南 和朋友一起重温DNF台服的经典版本,是许多老玩家的共同愿望。与单机版相比,联机玩法能带来更丰富的社交体验和团队协作乐趣。本文将详细介绍如何从零开始搭建…...

BM3D降噪算法:从原理到多语言实现实战

1. BM3D算法核心思想解析 第一次接触BM3D算法时,我和大多数人一样感到困惑。这个算法名字里的"3D"特别容易让人误解,实际上它指的是将二维图像块堆叠成的三维数组。想象一下,就像把一堆相似的乐高积木块整齐地叠放在一起&#xff0…...

KMS_VL_ALL_AIO:Windows系统与Office套件的一站式智能激活解决方案

KMS_VL_ALL_AIO:Windows系统与Office套件的一站式智能激活解决方案 【免费下载链接】KMS_VL_ALL_AIO Smart Activation Script 项目地址: https://gitcode.com/gh_mirrors/km/KMS_VL_ALL_AIO 在Windows系统管理与软件部署领域,激活问题始终是技术…...