Menu

文档

导出所有数据库

openGauss支持使用gs_dumpall工具导出所有数据库的全量信息,包含openGauss中每个数据库信息和公共的全局对象信息。可根据需要自定义导出如下信息:

  • 导出所有数据库全量信息,包含openGauss中每个数据库信息和公共的全局对象信息(包含角色和表空间信息)。

    使用导出的全量信息可以创建与当前主机相同的一个主机环境,拥有相同数据库和公共全局对象,且库中数据也与当前各库相同。

  • 仅导出数据,即导出每个数据库中的数据,且不包含所有对象定义和公共的全局对象信息。

  • 仅导出所有对象定义,包括:表空间、库定义、函数定义、模式定义、表定义、索引定义和存储过程定义等。

    使用导出的对象定义,可以快速创建与当前主机相同的一个主机环境,拥有相同的数据库和表空间,但是库中并无原数据库的数据。

操作步骤

  1. 以操作系统用户omm登录数据库主节点。
  2. 使用gs_dumpall一次导出所有数据库信息。

    gs_dumpall  -U omm -f /home/omm/backup/MPPDB_backup.sql -p 8000 
    Password:
    

表 1 常用参数说明

<a name="zh-cn_topic_0237121173_table1781122816253"></a>
<table><thead align="left"><tr id="zh-cn_topic_0237121173_row10837281257"><th class="cellrowborder" valign="top" width="25%" id="mcps1.2.4.1.1"><p id="zh-cn_topic_0237121173_p48382816258"><a name="zh-cn_topic_0237121173_p48382816258"></a><a name="zh-cn_topic_0237121173_p48382816258"></a>参数</p>
</th>
<th class="cellrowborder" valign="top" width="43.33%" id="mcps1.2.4.1.2"><p id="zh-cn_topic_0237121173_p18332812257"><a name="zh-cn_topic_0237121173_p18332812257"></a><a name="zh-cn_topic_0237121173_p18332812257"></a>参数说明</p>
</th>
<th class="cellrowborder" valign="top" width="31.669999999999998%" id="mcps1.2.4.1.3"><p id="zh-cn_topic_0237121173_p583122816257"><a name="zh-cn_topic_0237121173_p583122816257"></a><a name="zh-cn_topic_0237121173_p583122816257"></a>举例</p>
</th>
</tr>
</thead>
<tbody><tr id="zh-cn_topic_0237121173_row1483528152520"><td class="cellrowborder" valign="top" width="25%" headers="mcps1.2.4.1.1 "><p id="zh-cn_topic_0237121173_p3830287252"><a name="zh-cn_topic_0237121173_p3830287252"></a><a name="zh-cn_topic_0237121173_p3830287252"></a>-U</p>
</td>
<td class="cellrowborder" valign="top" width="43.33%" headers="mcps1.2.4.1.2 "><p id="zh-cn_topic_0237121173_p8232111218592"><a name="zh-cn_topic_0237121173_p8232111218592"></a><a name="zh-cn_topic_0237121173_p8232111218592"></a>连接数据库的用户名,需要是openGauss管理员用户。</p>
</td>
<td class="cellrowborder" valign="top" width="31.669999999999998%" headers="mcps1.2.4.1.3 "><p id="zh-cn_topic_0237121173_p1583152842510"><a name="zh-cn_topic_0237121173_p1583152842510"></a><a name="zh-cn_topic_0237121173_p1583152842510"></a>-U <span id="zh-cn_topic_0237121173_text12918893481"><a name="zh-cn_topic_0237121173_text12918893481"></a><a name="zh-cn_topic_0237121173_text12918893481"></a>omm</span></p>
</td>
</tr>
<tr id="zh-cn_topic_0237121173_row199295855317"><td class="cellrowborder" valign="top" width="25%" headers="mcps1.2.4.1.1 "><p id="zh-cn_topic_0237121173_p89920588539"><a name="zh-cn_topic_0237121173_p89920588539"></a><a name="zh-cn_topic_0237121173_p89920588539"></a>-W</p>
</td>
<td class="cellrowborder" valign="top" width="43.33%" headers="mcps1.2.4.1.2 "><p id="zh-cn_topic_0237121173_p69431335210"><a name="zh-cn_topic_0237121173_p69431335210"></a><a name="zh-cn_topic_0237121173_p69431335210"></a>指定用户连接的密码。</p>
<a name="zh-cn_topic_0237121173_ul194074341627"></a><a name="zh-cn_topic_0237121173_ul194074341627"></a><ul id="zh-cn_topic_0237121173_ul194074341627"><li>如果主机的认证策略是trust,则不会对数据库管理员进行密码验证,即无需输入-W选项;</li><li>如果没有-W选项,并且不是数据库管理员,会提示用户输入密码。</li></ul>
</td>
<td class="cellrowborder" valign="top" width="31.669999999999998%" headers="mcps1.2.4.1.3 "><p id="zh-cn_topic_0237121173_p1898043113581"><a name="zh-cn_topic_0237121173_p1898043113581"></a><a name="zh-cn_topic_0237121173_p1898043113581"></a>-W abcd@123</p>
</td>
</tr>
<tr id="zh-cn_topic_0237121173_row1823810139566"><td class="cellrowborder" valign="top" width="25%" headers="mcps1.2.4.1.1 "><p id="zh-cn_topic_0237121173_p11238171316560"><a name="zh-cn_topic_0237121173_p11238171316560"></a><a name="zh-cn_topic_0237121173_p11238171316560"></a>-f</p>
</td>
<td class="cellrowborder" valign="top" width="43.33%" headers="mcps1.2.4.1.2 "><p id="zh-cn_topic_0237121173_p323861311565"><a name="zh-cn_topic_0237121173_p323861311565"></a><a name="zh-cn_topic_0237121173_p323861311565"></a>将导出文件发送至指定目录文件夹。如果这里省略,则使用标准输出。</p>
</td>
<td class="cellrowborder" valign="top" width="31.669999999999998%" headers="mcps1.2.4.1.3 "><p id="zh-cn_topic_0237121173_p11238513175619"><a name="zh-cn_topic_0237121173_p11238513175619"></a><a name="zh-cn_topic_0237121173_p11238513175619"></a>-f /home/<span id="zh-cn_topic_0237121173_text153463112535"><a name="zh-cn_topic_0237121173_text153463112535"></a><a name="zh-cn_topic_0237121173_text153463112535"></a>omm</span>/backup/MPPDB_backup.sql</p>
</td>
</tr>
<tr id="zh-cn_topic_0237121173_row9411195215519"><td class="cellrowborder" valign="top" width="25%" headers="mcps1.2.4.1.1 "><p id="zh-cn_topic_0237121173_p84119521250"><a name="zh-cn_topic_0237121173_p84119521250"></a><a name="zh-cn_topic_0237121173_p84119521250"></a>-p</p>
</td>
<td class="cellrowborder" valign="top" width="43.33%" headers="mcps1.2.4.1.2 "><p id="zh-cn_topic_0237121173_p14838631464"><a name="zh-cn_topic_0237121173_p14838631464"></a><a name="zh-cn_topic_0237121173_p14838631464"></a>指定服务器所监听的TCP端口或本地Unix域套接字后缀,以确保连接。</p>
</td>
<td class="cellrowborder" valign="top" width="31.669999999999998%" headers="mcps1.2.4.1.3 "><p id="zh-cn_topic_0237121173_p341117521853"><a name="zh-cn_topic_0237121173_p341117521853"></a><a name="zh-cn_topic_0237121173_p341117521853"></a>-p <span id="zh-cn_topic_0237121173_text1275116185515"><a name="zh-cn_topic_0237121173_text1275116185515"></a><a name="zh-cn_topic_0237121173_text1275116185515"></a>8000</span></p>
</td>
</tr>
</tbody>

其他参数说明请参见《工具参考》中“服务端工具 \> gs\_dumpall”章节。

示例

示例一:执行gs_dumpall,导出所有数据库全量信息(omm用户为管理员用户),导出文件为文本格式。执行命令后,会有很长的打印信息,最终出现total time即代表执行成功。示例中将不体现中间的打印信息。

gs_dumpall -U omm -f /home/omm/backup/MPPDB_backup.sql -p 8000 
Password:
gs_dumpall[port='8000'][2017-07-21 15:57:31]: dumpall operation successful
gs_dumpall[port='8000'][2017-07-21 15:57:31]: total time: 9627  ms

示例二:执行gs_dumpall,仅导出所有数据库定义(omm用户为管理员用户),导出文件为文本格式。执行命令后,会有很长的打印信息,最终出现total time即代表执行成功。示例中将不体现中间的打印信息。

gs_dumpall  -U omm -f /home/omm/backup/MPPDB_backup.sql -p 8000 -s 
Password:
gs_dumpall[port='8000'][2018-11-14 11:28:14]: dumpall operation successful
gs_dumpall[port='8000'][2018-11-14 11:28:14]: total time: 4147  ms

示例三:执行gs_dumpall,仅导出所有数据库中数据,并对导出文件进行加密,导出文件为文本格式。执行命令后,会有很长的打印信息,最终出现total time即代表执行成功。示例中将不体现中间的打印信息。

gs_dumpall -f /home/omm/backup/MPPDB_backup.sql -p 8000 -a --with-encryption AES128 --with-key 1234567812345678
gs_dumpall[port='8000'][2018-11-14 11:32:26]: dumpall operation successful
gs_dumpall[port='8000'][2018-11-14 11:23:26]: total time: 4147  ms

本文档遵循知识共享许可协议CC 4.0 (http://creativecommons.org/Licenses/by/4.0/)。