1)主备切换为维护操作,确保 openGauss 状态正常,所有业务结束后,再进行切换操作。
2)在开启极致 RTO 时,不支持级联备机。因为在极致 RTO 开启情况下,备机不支持连接,所以无法与级联备机同步数据。
3)对于同一数据库,上一次主备切换未完成,不能执行下一次切换。当业务正在操作时,发起 switchover,可能主机的线程无法停止导致 switchover 显示超时,实际后台仍然在运行,等主机线程停止后,switchover 即可完成。比如在主机删除一个大的分区表时,可能无法响应 switchover 发起的信号。
4、第四组:openGauss 备份与还原(数据导出 / 导入) 场景:
数据备份主要是从两方面考虑,一是数据库系统备份,二是数据本身的备份。其主要是为了预防一些意外,例如:数据库系统的硬件故障,人为错误的操作等情况造成的数据丢失。下面从数据本身出发,简单罗列一下 openGauss 数据库的数据导出导入操作。
copy 数据导出
切换到默认 omm 用户下
postgres=> \c - omm
使用 copy 命令进行导出
`postgres=# copy customer_t1 to '/gaussdb/backup/copy_cost.txt' delimiter '^';
COPY 4
postgres=# \q`
查看导出文件
`[omm@opengauss ~]$ cd /gaussdb/backup/
[omm@opengauss backup]$ ll
total 4.0K -rw------- 1 omm dbgrp 80 Jun 17 14:39 copy_cost.txt
[omm@opengauss backup]$ more copy_cost.txt
3769^hello^\N^\N
6885^maps ^Joes ^\N
4321^tpcds^Lily ^\N
9527^world^James ^\N`
gs_dump 数据导出
使用 gs_dump 命令将 postgres 数据库导出,导出为纯文本格式。
gs_dump 部分重要指令解释:
-f:将导出文件发送至指定目录文件夹。
-F:选择导出文件格式。-F 参数值如下: p:纯文本格式 c:自定义归档 d:目录归档格式 t:tar 归档格式
-n:只导出与模式名称匹配的模式,此选项包括模式本身和所有它包含的对象。
-t:指定导出的表(或视图、序列、外表),可以使用多个 - t 选项来选择多个表,也可以使用 通配符指定多个表对象。
-T:不转储的表(或视图、或序列、或外表)对象列表,可以使用多个 - T 选项来选择多个 表,也可以使用通配符指定多个表对象。
`[omm@opengauss backup]$ gs_dump -U omm -W Bigdata@123 -f /gaussdb/backup/gsdump_post.sql - p 26000 postgres -F p
gs_dump[port='26000'][postgres][2022-10-16 14:45:16]: The total objects number is 391. gs_dump[port='26000'][postgres][2022-10-16 14:45:16]: [100.00%] 391 objects have been dumped.
gs_dump[port='26000'][postgres][2022-10-16 14:45:16]: dump database postgres successfully
gs_dump[port='26000'][postgres][2022-10-16 14:45:16]: total time: 254 ms`
查看导出文件
`[omm@opengauss backup]$ cd /gaussdb/backup/
[omm@opengauss backup]$ ll
total 8.0K
-rw------- 1 omm dbgrp 80 Oct 16 14:39 copy_cost.txt
-rw------- 1 omm dbgrp 1.8K Oct 16 14:45 gsdump_post.sql`
使用 gs_dump,导出 postgres 数据库,导出为 tar 格式
`[omm@opengauss backup]$ gs_dump -U omm -W Bigdata@123 -f /gaussdb/backup/gsdump_post.tar - p 26000 postgres -F t
gs_dump[port='26000'][postgres][2022-10-16 14:56:50]: The total objects number is 391. gs_dump[port='26000'][postgres][2022-10-16 14:56:50]: [100.00%] 391 objects have been dumped.
gs_dump[port='26000'][postgres][2022-10-16 14:56:50]: dump database postgres successfully
gs_dump[port='26000'][postgres][2022-10-16 14:56:50]: total time: 219 ms`