PostgreSQL 12.2 版本升级到 16.4 版本

2024-09-03 05:52

本文主要是介绍PostgreSQL 12.2 版本升级到 16.4 版本,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

将 PostgreSQL 从 12.2 版本升级到 16.4 版本是一个相对较大的跳跃,因为 PostgreSQL 的主要版本之间(如从 12 到 16)可能会引入不兼容的更改、新特性以及性能改进。以下是一个基本的步骤指南,帮助你完成从 PostgreSQL 12.2 到 16.4 的升级过程。请注意,这个过程可能需要根据你的具体环境(如操作系统、数据库大小、配置等)进行调整。

1. 备份数据库

在升级之前,最重要的一步是备份你的数据库。这样,如果升级过程中出现问题,你可以恢复到原始状态。

pg_dumpall -U postgres > all_databases.sql

或者,如果你只想备份特定的数据库:

pg_dump -U postgres your_database_name > your_database_name.sql

2. 安装 PostgreSQL 16.4

在升级之前,你需要先安装 PostgreSQL 16.4。这通常涉及到下载新版本的 PostgreSQL 并按照你的操作系统的指导进行安装。确保在安装过程中不要覆盖或删除旧版本的 PostgreSQL,因为稍后你可能需要访问它。

2.1、创建目录并授权

mkdir -p /postgresql/pgsql16.4
mkdir -p /postgresql/pgdata16.4
chown -R pgsql:pgsql /postgresql/pgsql16.4
chown -R pgsql:pgsql /postgresql/pgdata16.4
chmod -R 775 /postgresql/pgsql16.4
chmod -R 775 /postgresql/pgdata16.4

2.2、解压编译postgresql-16.4及初始化配置

su - pgsql
cd /postgresql/soft
tar zxvf postgresql-16.4.tar.gz
cd postgresql-16.4
./configure --prefix=/postgresql/pgsql16.4 --without-readline
make 
make install
-- 初始化
/postgresql/pgsql16.4/bin/initdb -D /postgresql/pgdata16.4 -E UTF8 --locale=en_US.utf8 -U postgres-- 配置postgresql.conf
vi /postgresql/pgdata16.4/postgresql.conflisten_addresses = '*'
port = 5432        
max_connections = 1000   #logging_collector = off ===>>logging_collector = on
#log_directory = 'log' ===>>log_directory = 'pg_log'
#log_truncate_on_rotation = off ===>> log_truncate_on_rotation = on
#log_filename = 'postgresql-%Y-%m-%d_%H%M%S.log' ===>> log_filename = 'postgresql-%Y-%m-%d_%H%M%S.log'
shared_buffers = 128MB  ===>> shared_buffers = 1024MB 
max_wal_size = 1GB
min_wal_size = 80MB-- 配置pg_hba.conf
vi /postgresql/pgdata16.4/pg_hba.conf
host    all      all     0.0.0.0/0      md5

3. 停止 PostgreSQL 12.2 服务

在升级过程中,确保 PostgreSQL 12.2 的服务是停止的,以避免任何潜在的冲突。

# pg_ctl来停止数据库服务
pg_ctl stop# 对于 Linux 系统,使用 systemctl 或 service 命令
sudo systemctl stop postgresql-12
# 或者
sudo service postgresql-12 stop

4. 迁移数据

有几种方法可以迁移数据从 PostgreSQL 12.2 到 16.4:

  • 使用 pg_upgrade:这是 PostgreSQL 官方推荐的升级工具,可以最小化停机时间。但是,它要求旧版本的服务必须运行,并且新版本必须安装在不同的数据目录中。

    /postgresql/pgsql16.4/bin/pg_upgrade --old-datadir /postgresql/pgdata --new-datadir /postgresql/pgdata16.4 --old-bindir /postgresql/pgsql12/bin --new-bindir /postgresql/pgsql16.4/bin -U postgres
    -- OR 
    pg_upgrade -b /postgresql/pgsql12/bin -B /postgresql/pgsql16.4/bin -d /postgresql/pgdata -D /postgresql/pgdata16.4 -U postgres-- 编辑环境变量 vi ~/.bash_profileexport LANG=en_US.UTF8
    export PS1="[`whoami`@`hostname`:"'$PWD]$'
    export PGPORT=5432  
    export PGDATA=/postgresql/pgdata16.4
    export PGHOME=/postgresql/pgsql16.4
    export LD_LIBRARY_PATH=$PGHOME/lib:/lib64:/usr/lib64:/usr/local/lib64:/lib:/usr/lib:/usr/local/lib:$LD_LIBRARY_PATH  
    export PATH=$PGHOME/bin:$PATH:.  
    export DATE=`date +"%Y%m%d%H%M"`  
    export MANPATH=$PGHOME/share/man:$MANPATH  
    export PGHOST=$PGDATA  
    export PGUSER=postgres  
    export PGDATABASE=postgres-- 启动数据库
    pg_ctl start
    -- OR
    /postgresql/pgsql16.4/bin/pg_ctl -D /postgresql/pgdata16.4 start-- 数据库状态
    pg_ctl status-- 停止数据库
    pg_ctl stop
    注意:你需要根据你的实际安装路径调整 `-b` 和 `-B` 参数。
    
  • 使用 pg_dump 和 pg_restore:如果你不想使用 pg_upgrade,或者你的环境不允许这样做,你可以使用 pg_dump 导出旧数据库,然后使用 pg_restore 将其导入到新版本的 PostgreSQL 中。这种方法可能需要更长的停机时间,因为它涉及到导出和导入整个数据库。

5. 验证和测试

升级完成后,验证新数据库的功能和性能。检查所有应用程序是否都能正常工作,以及是否有任何性能问题。

psql -Vpsql -h 127.0.0.1 -p 5432

6. 更新应用程序配置

更新任何指向旧 PostgreSQL 实例的数据库连接字符串和配置。

7. 清理旧版本

一旦你确认新版本运行正常,并且所有应用程序都已更新,你可以安全地卸载或删除旧版本的 PostgreSQL。

注意事项

  • 在升级之前,请仔细阅读 PostgreSQL 的官方升级文档,了解可能的不兼容更改和注意事项。
  • 考虑在测试环境中先进行升级,以确保一切按预期工作。
  • 升级过程中可能会遇到特定于你数据库的问题,因此请准备好解决这些问题。

希望这个指南能帮助你成功地将 PostgreSQL 从 12.2 升级到 16.4!

这篇关于PostgreSQL 12.2 版本升级到 16.4 版本的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/1132211

相关文章

Ubuntu如何升级Python版本

《Ubuntu如何升级Python版本》Ubuntu22.04Docker中,安装Python3.11后,使用update-alternatives设置为默认版本,最后用python3-V验证... 目China编程录问题描述前提环境解决方法总结问题描述Ubuntu22.04系统自带python3.10,想升级

PostgreSQL简介及实战应用

《PostgreSQL简介及实战应用》PostgreSQL是一种功能强大的开源关系型数据库管理系统,以其稳定性、高性能、扩展性和复杂查询能力在众多项目中得到广泛应用,本文将从基础概念讲起,逐步深入到高... 目录前言1. PostgreSQL基础1.1 PostgreSQL简介1.2 基础语法1.3 数据库

更改linux系统的默认Python版本方式

《更改linux系统的默认Python版本方式》通过删除原Python软链接并创建指向python3.6的新链接,可切换系统默认Python版本,需注意版本冲突、环境混乱及维护问题,建议使用pyenv... 目录更改系统的默认python版本软链接软链接的特点创建软链接的命令使用场景注意事项总结更改系统的默

Linux升级或者切换python版本实现方式

《Linux升级或者切换python版本实现方式》本文介绍在Ubuntu/Debian系统升级Python至3.11或更高版本的方法,通过查看版本列表并选择新版本进行全局修改,需注意自动与手动模式的选... 目录升级系统python版本 (适用于全局修改)对于Ubuntu/Debian系统安装后,验证Pyt

MySQL 升级到8.4版本的完整流程及操作方法

《MySQL升级到8.4版本的完整流程及操作方法》本文详细说明了MySQL升级至8.4的完整流程,涵盖升级前准备(备份、兼容性检查)、支持路径(原地、逻辑导出、复制)、关键变更(空间索引、保留关键字... 目录一、升级前准备 (3.1 Before You Begin)二、升级路径 (3.2 Upgrade

Oracle迁移PostgreSQL隐式类型转换配置指南

《Oracle迁移PostgreSQL隐式类型转换配置指南》Oracle迁移PostgreSQL时因类型差异易引发错误,需通过显式/隐式类型转换、转换关系管理及冲突处理解决,并配合验证测试确保数据一致... 目录一、问题背景二、解决方案1. 显式类型转换2. 隐式转换配置三、维护操作1. 转换关系管理2.

Nginx进行平滑升级的实战指南(不中断服务版本更新)

《Nginx进行平滑升级的实战指南(不中断服务版本更新)》Nginx的平滑升级(也称为热升级)是一种在不停止服务的情况下更新Nginx版本或添加模块的方法,这种升级方式确保了服务的高可用性,避免了因升... 目录一.下载并编译新版Nginx1.下载解压2.编译二.替换可执行文件,并平滑升级1.替换可执行文件

在macOS上安装jenv管理JDK版本的详细步骤

《在macOS上安装jenv管理JDK版本的详细步骤》jEnv是一个命令行工具,正如它的官网所宣称的那样,它是来让你忘记怎么配置JAVA_HOME环境变量的神队友,:本文主要介绍在macOS上安装... 目录前言安装 jenv添加 JDK 版本到 jenv切换 JDK 版本总结前言China编程在开发 Java

postgresql使用UUID函数的方法

《postgresql使用UUID函数的方法》本文给大家介绍postgresql使用UUID函数的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录PostgreSQL有两种生成uuid的方法。可以先通过sql查看是否已安装扩展函数,和可以安装的扩展函数

PostgreSQL中rank()窗口函数实用指南与示例

《PostgreSQL中rank()窗口函数实用指南与示例》在数据分析和数据库管理中,经常需要对数据进行排名操作,PostgreSQL提供了强大的窗口函数rank(),可以方便地对结果集中的行进行排名... 目录一、rank()函数简介二、基础示例:部门内员工薪资排名示例数据排名查询三、高级应用示例1. 每