手把手教你如何进行postgresql数据库迁移 让你成为dba大佬

2年前 (2022) 程序员胖胖胖虎阿
356 0 0

postgresql数据库 迁移方法

    • 记一次 postgresql,TimescaleDB数据库迁移过程)

文章目录

  • postgresql数据库 迁移方法
  • 前言
      • 1.准备工作
      • 2.分析情况
  • 一 业务库 迁移(postgresql数据库)
    • 1.数据备份
      • 1.1 对源数据库进行备份
      • 1.2传输备份文件
    • 2.创建新的数据库
      • 2.1创建新的数据库
      • 2.2 安装数据库插件
    • 3.数据迁移(整库还原)
      • 3.1 pg_restore用法
      • 3.2 还原命令
  • 二 时序库 迁移(TimescaleDB数据库)
    • 1 对源数据库进行处理
        • 1.1 直接传
        • 1.2 压缩传
    • 2.创建新的pg库,并改为TimescaleDB数据库
    • 3.迁移数据
      • 3.1复制新库之前配置的参数文件
      • 3.2 停下数据库TimescaleDB
      • 3.3 把迁移的data文件 移到pg目录下
        • 删除时序库原来的data目录
        • 把新的data文件 移到pg目录下
      • 3.4 还原之前复制的postgresql.conf文件
      • 3.5 启动TimescaleDB数据库

前言

因工作需要 需要对数据库所在的linux服务器 进行迁移 更换到新的服务器

1.准备工作

因本次迁移是需要迁移2个数据库,分别是:
分业务库:postgresql数据库
时序库 :TimescaleDB 数据库

环境:linux CentOS 6
数据库版本:postgresql 11.5

数据量 业务库 80G
时序库 500G

2.分析情况

针对这个情况进行分析 ,我发现可以对业务库采取 备份——还原 的方式进行迁移数据 毕竟数据量不大 ,但是对于时序库却不能采取这个方法 1. 是数据量大,2 .是TimescaleDB数据库含有大量的超表 备份还原是有一定的问题的 ,所有采取直接迁移postgres 下的data 文件 在修改配置的问题


一 业务库 迁移(postgresql数据库)

1.数据备份

源数据库(业务库)
ip:0.0.0.0 端口 5432 用户 postgres 数据库名:cs
新数据库(业务库)
ip:1.1.1.1 端口 5432 用户 postgres 数据库名:cs2

1.1 对源数据库进行备份

pg_dump --file "/u01/pgsql-all.backup" --host "0.0.0.0" --port "5432" --username "postgres" --dbname "cs" --verbose --role "postgres" --format=c --blobs --encoding "UTF8"

关于pg_dump 的用法 可以看这篇文章:链接直达

1.2传输备份文件

首先这俩个服务器之间能够要ping同,这样才能传输文件
通过Lina上的scp 命令 传输

 cd /u01
 scp pgsql-all.backup user@1.1.1.1:/tmp/

2.创建新的数据库

查看1.1.1.1服务器上是否装上postgresql数据库 ,没有的话需要自己装
创建数据库的可以看这篇文章安装 部署 postgresql数据库 搭建主从节点 (业务库)

因为我这个项目1.1.1.1上已经预装了postgresql-11.5的版本了 ,

2.1创建新的数据库

直接用sql创建

CREATE DATABASE cs;

或用使用createdb

createdb -h 1.1.1.1 -p 5432 -e -U postgres cs

createdb 是一个 SQL 命令 CREATE DATABASE 的封装。

createdb 创建一个 PostgreSQL 数据库.

使用方法:
  createdb [选项]... [数据库名称] [描述]

选项:
  -D, --tablespace=TABLESPACE  数据库默认表空间
  -e, --echo                   显示发送到服务端的命令
  -E, --encoding=ENCODING      数据库编码
  -l, --locale=LOCALE          数据库的本地化设置
      --lc-collate=LOCALE      数据库的LC_COLLATE设置
      --lc-ctype=LOCALE        数据库的LC_CTYPE设置
  -O, --owner=OWNER            新数据库的所属用户
  -T, --template=TEMPLATE      要拷贝的数据库模板
  -V, --version                输出版本信息, 然后退出
  -?, --help                   显示此帮助, 然后退出

联接选项:
  -h, --host=HOSTNAME          数据库服务器所在机器的主机名或套接字目录
  -p, --port=PORT              数据库服务器端口号
  -U, --username=USERNAME      联接的用户名
  -w, --no-password            永远不提示输入口令
  -W, --password               强制提示输入口令
  --maintenance-db=DBNAME      更改维护数据库

默认情况下, 以当前用户的用户名创建数据库.

2.2 安装数据库插件

一般根据工作需要需要安装不同的postgres 插件
我这里只大体举个例子:

CREATE EXTENSION "postgres_fdw";
Create extension "postgis";
Create extension "uuid-ossp"

由于我们之前是全量备份整个库 它会自动帮你安装 如果只备份单模式或者备份部分的是需要安装插件的,需要保持新旧库一致的,要不之后的还原会报错的

3.数据迁移(整库还原)

这里使用pg_restore来还原备份做数据库迁移的

3.1 pg_restore用法

用法:
  pg_restore [选项]... [文件名]

一般选项:
  -d, --dbname=名字        连接数据库名字
  -f, --file=文件名        输出文件名
  -F, --format=c|d|t       备份文件格式(应该自动进行)
  -l, --list               打印归档文件的 TOC 概述
  -v, --verbose            详细模式
  -V, --version            输出版本信息, 然后退出
  -?, --help               显示此帮助, 然后退出

恢复控制选项:
  -a, --data-only              只恢复数据, 不包括模式
  -c, --clean                  在重新创建之前,先清除(删除)数据库对象
  -C, --create                 创建目标数据库
  -e, --exit-on-error          发生错误退出, 默认为继续
  -I, --index=NAME             恢复指定名称的索引
  -j, --jobs=NUM               执行多个并行任务进行恢复工作
  -L, --use-list=FILENAME      从这个文件中使用指定的内容表排序
                               输出
  -n, --schema=NAME            在这个模式中只恢复对象
  -N, --exclude-schema=NAME    不恢复此模式中的对象
  -O, --no-owner               不恢复对象所属者
  -P, --function=NAME(args)    恢复指定名字的函数
  -s, --schema-only            只恢复模式, 不包括数据
  -S, --superuser=NAME         使用指定的超级用户来禁用触发器
  -t, --table=NAME             恢复命名关系(表、视图等)
  -T, --trigger=NAME           恢复指定名字的触发器
  -x, --no-privileges          跳过处理权限的恢复 (grant/revoke)
  -1, --single-transaction     作为单个事务恢复
  --disable-triggers           在只恢复数据的过程中禁用触发器
  --enable-row-security        启用行安全性
  --if-exists                  当删除对象时使用IF EXISTS
  --no-comments                不恢复注释
  --no-data-for-failed-tables  对那些无法创建的表不进行
                               数据恢复
  --no-publications            不恢复发行
  --no-security-labels         不恢复安全标签信息
  --no-subscriptions           不恢复订阅
  --no-tablespaces             不恢复表空间的分配信息
  --section=SECTION            恢复命名节 (数据前、数据及数据后)
  --strict-names               要求每个表和()schema包括模式以匹配至少一个实体
  --use-set-session-authorization
                               使用 SESSION AUTHORIZATION 命令代替
                               ALTER OWNER 命令来设置所有权

联接选项:
  -h, --host=主机名        数据库服务器的主机名或套接字目录
  -p, --port=端口号        数据库服务器的端口号
  -U, --username=名字      以指定的数据库用户联接
  -w, --no-password        永远不提示输入口令
  -W, --password           强制口令提示 (自动)
  --role=ROLENAME          在恢复前执行SET ROLE操作

选项 -I, -n, -N, -P, -t, -T, 以及 --section 可以组合使用和指定
多次用于选择多个对象.

如果没有提供输入文件名, 则使用标准输入.

3.2 还原命令

pg_restore  --host "1.1.1.1" --port "5432" --username "postgres"  --role "postgres" --dbname "cs"  --verbose /tmp/pgsql-all.backup

等还原完成后,业务库就已经还原完成了,下面开始迁移时序库


二 时序库 迁移(TimescaleDB数据库)

源数据库(业务库)
ip:0.0.0.2 端口 5432 用户 postgres 数据库名:cst
新数据库(业务库)
ip:1.1.1.2 端口 5432 用户 postgres 数据库名:cst2

由于时序库比较大 无法使用之前的方法,我们采用直接迁移postgres下的数据文件的办法
由于postgresql数据库的特性 我才去迁移pg目录下的data 文件夹的方式

1 对源数据库进行处理

这里有2种方法,一种是直接传,一种是压缩后传

1.1 直接传

同样需要网通
从0.0.0.2服务器进入数据库的目录下,我的是在/u01下
cd /u01/pg11.5

scp -r data user@1.1.1.2:/u01/

1.2 压缩传

[root@0.0.0.2 pgsql]# pwd
/u01/pgsql
[root@0.0.0.2 pgsql]# tar -zcvf data.tar.gz data
[root@0.0.0.2 pgsql]#scp -r data user@1.1.1.2:/u01/

解压
[root@1.1.1.2 ~]# cd /u01/pgsql/
[root@1.1.1.2 pgsql]# tar -zxvf data

2.创建新的pg库,并改为TimescaleDB数据库

详情可以看安装 部署 postgresql数据库 搭建timescaledb数据库 (时序库)这篇文章

3.迁移数据

3.1复制新库之前配置的参数文件

[root@1.1.1.2 data]# cp pg_hba.conf /home/
[root@1.1.1.2 data]# cp postgresql.conf /home/

3.2 停下数据库TimescaleDB

[root@1.1.1.2 ~]# su - postgres
-bash-4.2$ /usr/pgsql-11/bin/pg_ctl -D /u01/pgsql/data/ stop
waiting for server to shut down… done
server stopped

3.3 把迁移的data文件 移到pg目录下

删除时序库原来的data目录

删除时序库原来的data目录
[root@1.1.1.2 ~]# cd /u01/pgsql/
[root@1.1.1.2 pgsql]# ls
data
[root@1.1.1.2 pgsql]# rm -fr data/

如果害怕可以备份一下(或者改个名

把新的data文件 移到pg目录下

[root@1.1.1.2 u01]# mv data /u01/pgsql/

3.4 还原之前复制的postgresql.conf文件

[root@1.1.1.2 data]# cp /home/postgresql.conf .
[root@1.1.1.2 data]# cp /home/pg_hba.conf .

3.5 启动TimescaleDB数据库

[root@1.1.1.2 ~]# su - postgres
-bash-4.2$ /usr/pgsql-11/bin/pg_ctl -D /u01/pgsql/data/ start
如果没有启动systemctl status postgresql-11或者log日志查看具体问题


如果遇到啥问题,请留言

相关文章

暂无评论

暂无评论...