导出数据库
GaussDB 200支持使用gs_dump工具导出某个数据库级的内容,包含数据库的数据和所有对象定义。可根据需要自定义导出如下信息:
- 导出数据库全量信息,包含数据和所有对象定义。
使用导出的全量信息可以创建一个与当前库相同的数据库,且库中数据也与当前库相同。
- 仅导出所有对象定义,包括:库定义、函数定义、模式定义、表定义、索引定义和存储过程定义等。
使用导出的对象定义,可以快速创建一个相同的数据库,但是库中并无原数据库的数据。
- 仅导出数据,不包含所有对象定义。
操作步骤
- 以操作系统用户omm登录GaussDB 200集群任一主机。执行source ${BIGDATA_HOME}/mppdb/.mppdbgs_profile命令启动环境变量。
- 使用gs_dump导出postgres数据库。
gs_dump -W Bigdata@123 -U jack -f /home/omm/backup/postgres_backup.tar -p 25308 postgres -F t
表1 常用参数说明 参数
参数说明
举例
-U
连接数据库的用户名。
-U jack
-W
指定用户连接的密码。
- 如果主机的认证策略是trust,则不会对数据库管理员进行密码验证,即无需输入-W选项;
- 如果没有-W选项,并且不是数据库管理员,会提示用户输入密码。
-W Bigdata@123
-f
将导出文件发送至指定目录文件夹。如果这里省略,则使用标准输出。
-f /home/omm/backup/postgres_backup.tar
-p
指定服务器所监听的TCP端口或本地Unix域套接字后缀,以确保连接。
-p 25308
dbname
需要导出的数据库名称
postgres
-F
选择导出文件格式。-F参数值如下:
- p:纯文本格式
- c:自定义归档
- d:目录归档格式
- t:tar归档格式
-F t
其他参数说明请参见gs_dump。
示例
示例一:执行gs_dump,导出postgres数据库全量信息,并对导出文件进行压缩,导出文件格式为sql文本格式。
gs_dump -W Bigdata@123 -f /home/omm/backup/postgres_backup.sql -p 25308 postgres -Z 8 -F p gs_dump[port='25308'][postgres][2017-07-21 15:36:13]: dump database postgres successfully gs_dump[port='25308'][postgres][2017-07-21 15:36:13]: total time: 3793 ms
示例二:执行gs_dump,仅导出postgres数据库中的数据,不包含数据库对象定义,导出文件格式为自定义归档格式。
gs_dump -W Bigdata@123 -f /home/omm/backup/postgres_data_backup.dmp -p 25308 postgres -a -F c gs_dump[port='25308'][postgres][2017-07-21 15:36:13]: dump database postgres successfully gs_dump[port='25308'][postgres][2017-07-21 15:36:13]: total time: 3793 ms
示例三:执行gs_dump,仅导出postgres数据库所有对象的定义,导出文件格式为sql文本格式。
--导出前,表nation有数据 select n_nationkey,n_name,n_regionkey from nation limit 3; n_nationkey | n_name | n_regionkey -------------+---------------------------+------------- 0 | ALGERIA | 0 3 | CANADA | 1 11 | IRAQ | 4 (3 rows) gs_dump -W Bigdata@123 -f /home/omm/backup/postgres_def_backup.sql -p 25308 postgres -s -F p gs_dump[port='25308'][postgres][2017-07-20 15:04:14]: dump database postgres successfully gs_dump[port='25308'][postgres][2017-07-20 15:04:14]: total time: 472 ms
示例四:执行gs_dump,仅导出postgres数据库的所有对象的定义,导出文件格式为文本格式,并对导出文件进行加密。
gs_dump -W Bigdata@123 -f /home/omm/backup/postgres_def_backup.sql -p 25308 postgres --with-encryption AES128 --with-key 1234567812345678 -s -F p gs_dump[port='25308'][postgres][2018-11-14 11:25:18]: dump database postgres successfully gs_dump[port='25308'][postgres][2018-11-14 11:25:18]: total time: 1161 ms
查看更多:华为GaussDB 200 导出单个数据库「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」关注作者【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。评论