- 数据库备份pg_dump和pg_store
防止数据丢失第一道防线,数据备份。数据备份分逻辑备份和物理备份。
2.逻辑备份
pg提高pg_dump和pg_dumpall命令进行逻辑备份。pg_dumpall是正数据集群全部转存到一个脚本文件中,而pg_dumpl可以选择一个数据库或部分表进行备份。
pg_dump可以在数据库正在使用时进行完整一致备份,它并不阻塞其他用户对数据库的访问(读或写)。
pg_dump与pg_restore配合使用,从而提供一种灵活的备份和恢复脚本。
.pg_dump
运行pg_dump时,应该检查输出,看看是否警告存在
pg_dump命令格式如下:
pg_dump [connection_option][option][option_name]
pg_dump参数如下:
-h host
运行服务器的主机名
-p port
服务器的TCP端口号
-U username
要连接的用户名
-w
从不密码提示,如服务器请求密码验证,且密码不能同其他方式(如.pgpass)来获得,则此命令会导致连接失败。
该选项使用在后台脚本中,因为后台脚本是无密码输入的。
-W
强制pg_dump在连接到一个数据库之前提示密码。该选项通常不重要,因为服务器请求密码验证,pg_dump将自动提示一个密码。
-role
该选项会导致pg_dump在连接到数据库发布一个set role rolename命令。相当于切换到另一个角色。当已验证的用户缺少pg_dump
需要权限时,可以使用这个功能切换到相应的权限角色。
-a
只对存文本格式有意义,只输入数据&