Debian安装PostgreSQL16及其plpython3u扩展

PostgreSQL16安装

官方文档:https://www.postgresql.org/download/linux/

可通过 uname -a 命令查看系统信息:

也可通过 hostnamectl 命令获取 Linux 操作系统信息

我这里是aarch64架构(新版64位 arm 程序统称 aarch64)的Debian系统。

CPU架构详解参考:https://blog.csdn.net/be_racle/article/details/134764629

由于使用 apt install postgresql 安装的不是PostgreSQL16版本,所以这里使用PostgreSQL存储库进行安装,步骤如下:

# 更新 APT 包索引
sudo apt update -y
# 安装所需的软件包
sudo apt install gnupg2 wget -y
# 添加 PostgreSQL 存储库
sudo sh -c 'echo "deb https://apt.postgresql.org/pub/repos/apt $(lsb_release -cs)-pgdg main" > /etc/apt/sources.list.d/pgdg.list'
# 下载存储库的密钥签名:
curl -fsSL https://www.postgresql.org/media/keys/ACCC4CF8.asc|sudo gpg --dearmor -o /etc/apt/trusted.gpg.d/postgresql.gpg
# 再次更新 APT 包
sudo apt update -y
# 安装 PostgreSQL 16
sudo apt install postgresql-16 -y

启动服务并设置系统启动时自动启动postgresql服务:

# 启动服务
sudo systemctl start postgresql
# 系统启动时自动运行服务
sudo systemctl enable postgresql
# 查看服务状态
sudo systemctl status postgresql
# 停止服务
sudo systemctl stop postgresql
# 重启服务
sudo systemctl restart postgresql

使用命令 psql --version 查看版本信息:

PostgreSQL安装和配置详情参考:https://cn.linux-console.net/?p=22460

plpython3u扩展安装

在后续操作时请先确保服务器中已存在python解释器环境。

使用whereis python命令查看python路径。

下载 plpython3u扩展:

sudo apt install -y postgresql-plpython3-16

登录到 PostgreSQL 数据库:

sudo -u postgres psql

创建 plpython3u 语言,会安装plpython3u 扩展:

# 创建扩展
CREATE EXTENSION IF NOT EXISTS plpython3u;

# 删除扩展
DROP EXTENSION plpython3u;

创建时若报错: plpython3u.control": 没有那个文件或目录.

则执行上述 sudo apt install -y postgresql-plpython3-16 命令后再重新创建。

输入命令 \dx 列出所有已安装的扩展信息:

编写匿名函数查看plpython3u依赖的python版本

DO $$
import sys
plpy.notice(sys.version)
$$ LANGUAGE plpython3u;

退出PostgreSQL交互界面:

exit

至此,plpython3u扩展安装完成,若想在plpython3u中使用第三方库,则直接在服务器的python环境中pip安装对应库名即可。

  • 9
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值