Linux环境下基于Docker安装 PostgreSQL数据库并配置 pgvector
文章目录
- 1 docker-compose 安装 PostgreSQL + 容器内安装 pgvector
- 1.1 基于 docker-compose 安装 PostgreSQL 数据库
- 1.2 容器内配置 pgvector
- 2. docker-compose + Dockerfile 形式直接配置PostgreSQL数据库及 pgvector
- 参考资料
PostgreSQL是一种功能强大的开源关系数据库管理系统,广泛应用于各种应用程序中。PostgresStore 提供持久化存储功能,支持层次命名空间和可选的向量搜索(通过 pgvector 扩展),适合需要长时记忆的 AI 应用,如聊天机器人或自动化工作流。
- PostgreSQL 官网:https://www.postgresql.org/
- pgvector Github项目地址:https://github.com/pgvector/pgvector
1 docker-compose 安装 PostgreSQL + 容器内安装 pgvector
1.1 基于 docker-compose 安装 PostgreSQL 数据库
参考博客:
- https://github.com/NanGePlus/LangGraphChatBot
下面介绍如何以 docker compose
形式启动PostgreSQL服务。
- 安装相关依赖包,推荐使用系统自带的 docker compose:
sudo apt-get update
sudo apt-get install docker-compose-plugin # 新版本
注意: 这里,如果安装的是新版本的 docker-compose-plugin
,后续命令为 docker compose
(没有中间的横线-)
注意事项:
- 不要使用 pip 安装 docker compose,特别是当您使用 Anaconda 环境时。
- 使用系统包管理器(apt/yum)安装 docker compose
这里,笔者之前在 Anaconda 的虚拟环境中 使用
pip install docker-compose
就出现了报错,所以大家最好 使用 系统包管理器(apt/yum)来安装 docker-compose。
- 编写 docker-compose 所需的配置文件。
这里我们的配置文件为docker-compose.yaml
,文件内容为:
services:postgres:image: postgres:15 # 指定具体版本container_name: postgres_dbenvironment:POSTGRES_USER: postgresPOSTGRES_PASSWORD: postgresPOSTGRES_DB: postgresTZ: Asia/Shanghai # 设置时区ports:- "5432:5432"volumes:- pgdata:/var/lib/postgresql/datarestart: unless-stoppedhealthcheck: # 健康检查test: ["CMD", "pg_isready", "-U", "nange"]interval: 10stimeout: 5sretries: 5command: ["postgres", "-c", "max_connections=200"] # 自定义配置volumes:pgdata:
这里,我们配置的容器名称为 postgres_db
。
- 运行下面命令启动PostgreSQL数据库服务:
sudo docker compose up -d
这个命令会:
- 以后台模式 (-d) 启动所有定义的服务
- 如果本地有 postgres:15 镜像,则直接加载使用。若没有 postgres:15 镜像,会自动从镜像仓库拉取。
- 创建名为 pgdata 的持久化卷
- 启动容器并应用所有配置
运行成功的话会出现如下界面:
- 检查容器是否正常运行:
docker compose ps
或查看所有容器状态:
docker ps
- 连接数据库
您可以通过以下方式连接数据库:
方式一:在容器内使用 psql
docker compose exec postgres psql -U postgres
方式二:从外部客户端连接
使用任何 PostgreSQL 客户端工具连接,如Navicat可视化工具。
- 停止服务(当需要时)
docker compose down
如果要同时删除数据卷(慎用,会删除所有数据):
docker compose down --volumes
1.2 容器内配置 pgvector
在容器中按照如下步骤进行操作。
- 进入容器:
docker exec -it postgres_db bash
- 容器内安装依赖
apt update
apt install -y git build-essential postgresql-server-dev-15
这里,笔者运行时出现报错:
W: Failed to fetch http://deb.debian.org/debian/dists/bookworm/InRelease Could not connect to debian.map.fastlydns.net:80 (151.101.90.132)W: Failed to fetch http://apt.postgresql.org/pub/repos/apt/dists/bookworm-pgdg/InRelease Could not connect to apt.postgresql.org:80 (151.101.91.52), connection timed out
需要检查下服务器是否开通了 http://deb.debian.org
和 http://apt.postgresql.org
的访问权限。如果没有权限,可以申请开通,或者使用国内清华或阿里云的镜像源。
- 容器内编译并安装 pgvector
这里主要参考 pgvector 官网:https://github.com/pgvector/pgvector
cd /tmp
git clone https://github.com/pgvector/pgvector.git
cd pgvector
make
make install
- 检查扩展文件是否安装成功
ls -l /usr/share/postgresql/15/extension/vector*
- 启用pgvector扩展
psql -U postgres -d mydatabase
-- 在psql中执行
CREATE EXTENSION vector;
- 验证安装
基于SQL语句验证:
SELECT * FROM pg_extension WHERE extname = 'vector';
2. docker-compose + Dockerfile 形式直接配置PostgreSQL数据库及 pgvector
参考博客:
- docker-compose安装pgsql和pgvector
- 2-PostgreSQL docker compose 安装教程-Pgvector
- 创建 Dockerfile
# 使用 PostgreSQL 15 基础镜像
FROM postgres:15# 安装 pgvector
RUN apt-get update && \apt-get install -y postgresql-16-pgvector && \rm -rf /var/lib/apt/lists/*# 设置启动命令
CMD ["postgres"]
- 创建 docker-compose.yaml
services:postgres:build:context: .dockerfile: Dockerfilecontainer_name: postgres_dbenvironment:POSTGRES_USER: postgresPOSTGRES_PASSWORD: postgresPOSTGRES_DB: postgresTZ: Asia/Shanghai # 设置时区ports:- "5432:5432"volumes:- pgdata:/var/lib/postgresql/datarestart: alwayshealthcheck: # 健康检查test: ["CMD", "pg_isready", "-U", "nange"]interval: 10stimeout: 5sretries: 5command: ["postgres", "-c", "max_connections=200"] # 自定义配置volumes:pgdata:
- 构建Dockerfile
docker compose build
- 运行
docker compose up -d
- 进入postgres容器
docker exec -it postgres psql -U postgres -d postgres
- 判断vector工具是否安装成功
CREATE EXTENSION IF NOT EXISTS vector;
参考资料
- https://github.com/NanGePlus/LangGraphChatBot
- docker-compose安装pgsql和pgvector
- 2-PostgreSQL docker compose 安装教程-Pgvector
相关文章:

Linux环境下基于Docker安装 PostgreSQL数据库并配置 pgvector
文章目录 1 docker-compose 安装 PostgreSQL 容器内安装 pgvector1.1 基于 docker-compose 安装 PostgreSQL 数据库1.2 容器内配置 pgvector 2. docker-compose Dockerfile 形式直接配置PostgreSQL数据库及 pgvector参考资料 PostgreSQL是一种功能强大的开源关系数据库管理系…...

(9)-java+ selenium->元素定位之By name
1.简介 上一篇已经介绍了通过id来定位元素,继续介绍其他剩下的七种定位方法中的通过name来定位元素。本文来介绍Webdriver中元素定位方法之By name,顾名思义,就是我们想要定位的目标元素节点上,有一个name ="value"的属性,这样我们就可以通过name的value直接去…...

深浅拷贝?
一、定义: 浅拷贝:只复制对象的第一层属性,若第一层属性是引用类型(如对象、数组),则复制其内存地址,修改拷贝后的嵌套对象会影响原对象。 深拷贝:递归复制对象的所有层级…...

Beckhoff PLC 功能块 FB_CTRL_ACTUAL_VALUE_FILTER (模拟量滤波)
1. 功能块概览 名称:FB_CTRL_ACTUAL_VALUE_FILTER(实际值滤波控制功能块)。作用:对测量输入值进行合理性检查( plausibility check )和滤波处理,防止异常跳变(如传感器信号突变&…...
Mysql在SQL层面的优化
以下是MySQL在SQL层面的优化方法及详细案例,结合实际场景说明如何通过调整SQL语句提升性能: 1. 确保索引有效使用 案例:订单状态查询优化 问题SQL: SELECT * FROM orders WHERE status shipped AND create_time > 2023-01-…...
JVM规范之栈帧
JVM规范之栈帧 前言正文概述局部变量表操作数栈动态链接 总结参考链接 前言 上一篇文章了解了JVM规范中的运行时数据区: JVM规范之运行时数据区域 其中,栈是JVM线程私有的内存区,栈中存储的单位是帧(frames)ÿ…...

【C++指南】string(四):编码
💓 博客主页:倔强的石头的CSDN主页 📝Gitee主页:倔强的石头的gitee主页 ⏩ 文章专栏:《C指南》 期待您的关注 引言 在 C 编程中,处理字符串是一项极为常见的任务。而理解字符串在底层是如何编码存储的&…...

深度学习之序列建模的核心技术:LSTM架构深度解析与优化策略
LSTM深度解析 一、引言 在深度学习领域,循环神经网络(RNN)在处理序列数据方面具有独特的优势,例如语音识别、自然语言处理等任务。然而,传统的 RNN 在处理长序列数据时面临着严重的梯度消失问题,这使得网…...

AI量化交易是什么?它是如何重塑金融世界的?
第一章:证券交易的进化之路 1.1 从喊价到代码:交易方式的革命性转变 在电子交易普及之前,证券交易依赖于交易所内的公开喊价系统。交易员通过手势、喊话甚至身体语言传递买卖信息,这种模式虽然直观,但效率低下且容易…...

分布式事务处理方案
1. 使用Seata框架解决 1.1 XA 事务 1.1.1 XA整体流程 第一阶段 RM1开启XA事务-> 执行业务SQL -> 上报TC执行结果RM2开启XA事务-> 执行业务SQL -> 上报TC执行结果 第二阶段 TC根据 RM上报结果通知RM一起提交/回滚XA事务 1.1.2 XA特点 XA 模式必须要有数据库的支…...

CVE-2024-36467 Zabbix权限提升
漏洞描述 在Zabbix中,具有API访问权限的已认证用户(例如具有默认用户角色的用户)可以通过调用user.update API接口,将自己添加到任何用户组(如Zabbix管理员组)。然而,用户无法添加到已被禁用或…...

Dify中的自定义模型插件开发例子:以xinference为例
本文使用Dify v1.0.0-beta.1版本。模型插件结构基本是模型供应商(模型公司,比如siliconflow、xinference)- 模型分类(模型类型,比如llm、rerank、speech2text、text_embedding、tts)- 具体模型(…...
crud方法命名示例
以下是基于表名dste_project_indicator(项目指标表)的完整命名示例,覆盖各类增删改查场景: 1. 表名与实体类映射 // 表名:dste_project_indicator // 实体类:DsteProjectIndicatorEntity public class Ds…...

尚硅谷redis7 33-36 redis持久化之RDB优缺点及数据丢失案例
官网说明优点: RDB是Redis数据的一个非常紧凑的单文件时间点表示,RDB文件非常适合备份。例如,您可能希望在最近的24小时内每小时旧档一次RDB文件,并在30天内每天保存一个RDB快照,这使您可以在发生来难时轻松恢复不同版本的数据集。RDB非常适合灾难恢复,它是一个可以…...
No such file or directory: ‘ffprobe‘
目录 详细信息: 解决方法: No such file or directory: ffprobe 详细信息: File "/usr/local/lib/python3.10/dist-packages/framepump/framepump.py", line 168, in get_duration return float(ffmpeg.probe(video_path)[form…...

计算机网络-WebSocket/DNS/Cookie/Session/Token/Jwt/Nginx
文章目录 WebSocketDNS什么是dns域名解析底层协议 cookie/sessionToken/JWTNginx WebSocket 一种网络通信协议,允许在单个 TCP(半双工) 连接上进行全双工通信(客户端和服务器可同时双向传输数据)。 HTTP是基于请求-响…...
功能“递归模式”在 C# 7.3 中不可用,请使用 8.0 或更高的语言版本的一种兼容处理方案
原程序: internal class ControllerParameterCreator : IParameterCreator {private Controller controller;public ControllerParameterCreator(Controller controller){this.controller controller;}public Parameter CreateSystem(string name, int unused){re…...
第4章-操作系统知识
存储管理 固定分区:一种静态分区方式请求分页存储管理覆盖技术:覆盖技术是指让作业中不同时运行的程序模块共同使用同一主存区域。...

将网页带格式转化为PDF
# 一、安装插件 SingleFile | 将完整的页面保存到一个 HTML 文件中 – 下载 🦊 Firefox 扩展(zh-CN) 打开火狐浏览器,安装上面的插件 # 二、下载html单文件 打开对应的网页,点击插件下载对应的html文件 # 三、打开…...

【ArcGIS】ArcGIS AI 助手----复现
github地址 korporalK/Archer-GIS-AI-Assitant:Archer 在 ArcGIS Pro 中将自然语言命令转换为自动化 GIS 工作流。它使用代理框架(计划-验证-执行)构建并由 LLM 提供支持,可简化空间分析、减少手动工作并使 GIS 更易于访问。Arch…...
使用 FFmpeg 将视频转换为高质量 GIF(保留原始尺寸和帧率)
在制作教程动图、产品展示、前端 UI 演示等场景中,我们经常需要将视频转换为体积合适且清晰的 GIF 动图。本文将详细介绍如何使用 FFmpeg 工具将视频转为高质量 GIF,包括: ✅ 保留原视频尺寸或自定义缩放✅ 保留原始帧率或自定义帧率✅ 使用调色板优化色彩质量✅ 降低体积同…...
《Java vs Go vs C++ vs C:四门编程语言的深度对比》
引言 从底层硬件操作到云端分布式系统,Java、Go、C 和 C 四门语言各自占据不同生态位。本文从设计哲学、语法范式、性能特性、应用场景等维度进行对比,为开发者提供技术选型参考。 一、设计哲学与历史定位…...

充电枪IEC62196/EN 62196测试内容
充电枪IEC62196/EN 62196测试内容 一、机械性能测试 插拔力测试 交流充电接口的插入/拔出力需≤100N,直流接口≤140N。若使用助力装置,操作力仍需满足上述要求。 测试方法:通过弹簧秤或专用试验机(如Sun-CB设备)测…...
有效的字母异位符--LeetCode
题目 给定两个字符串 s 和 t ,编写一个函数来判断 t 是否是 s 的 字母异位词。 示例 1: 输入: s "anagram", t "nagaram" 输出: true示例 2: 输入: s "rat", t "car" 输出: false 思路一:排序 t 是 s …...

SAP ERP 系统拆分的七大挑战
在企业变革或管理运营风险时,剥离IT系统能带来显著效益,但SAP ERP系统的复杂性使得这项工作充满挑战。如果管理不当,可能会导致数据不一致、运营中断、合规风险和意外成本。由于SAP ERP系统深度集成于企业核心业务流程中,其拆分工…...

AcrelEMS 3.0智慧能源管理平台:构建企业微电网数智化中枢
安科瑞电气顾强 在"双碳"目标驱动下,企业能源管理正从粗放式运营向精细化、智能化转型。AcrelEMS 3.0智慧能源管理平台以微电网为核心载体,通过"感知-分析-决策-控制"的全链路数字化能力,助力工商企业、医疗机构、教育机…...
【HTML-12】HTML表格常用属性详解:从基础到高级应用
表格是HTML中最强大且常用的元素之一,它能够以结构化的方式展示数据。本文将全面介绍HTML表格的常用属性,帮助您创建美观、响应式且语义化的数据表格。 1. HTML表格基础结构 在深入了解属性之前,我们先回顾一下HTML表格的基本结构ÿ…...

Word转PDF--自动生成目录
1-Word文档中已经包含自动生成的目录; 2-选择“文件”; 3-另存为,PDF; 4-选择“选项”按钮,在弹出的窗口中,勾选“创建书签时使用标题”。...
MySQL组合索引优化策略
优化MySQL组合索引需要综合考虑查询模式、索引结构及数据库特性。以下是关键优化策略及示例: 1. 遵循最左前缀原则 策略:确保查询条件包含组合索引最左侧列。示例:索引(a,b,c)生效场景:WHERE a1 AND b2 -- ✔️ 使用a和b W…...
Spring MVC 的的核心原理与实践指南
一、Spring MVC 概述 Spring MVC 是 Spring 框架中的一个重要模块,用于构建基于 Java 的 Web 应用程序。它遵循模型-视图-控制器(MVC)设计模式,提供了一种结构化的方式来开发灵活、松耦合的 Web 应用。 Spring MVC 的特点…...