备份psgsql数据库
1.创建备份文件夹
mkdir /usr/src/database-backup
2.创建备份脚本文件

docekr容器中新建vim命令
apt-get update
apt-get install vim
vim pgsql-backup.sh

3.编写脚本文件
因为我这里是用docker安装的pgsql,所以需要docker exec -it到容器中去执行这个脚本
这里不管是备份脚本还是恢复脚本都需要在pgsql的bin文件下执行,依托于pg_dump命令和pg_restore命令

 **备份脚本**
# /bin/bash
echo "开始执行 PostgreSql数据库的备份!"
echo "backup ing -------------------"
nowtime=$(date +%F+%T)
export PGPASSWORD=root
echo "时间:" $nowtime
set timeout 500
/usr/bin/pg_dump --file "/usr/src/pgsql-database-backup/"$nowtime".backup"--host "121.4.226.11" --port "5432" --username "postgres" --dbname "postgres" --verbose --role "postgres" --format=c --blobs --encoding "UTF8"
echo "数据库备份结束!"exit;

4.将docker容器内的文件复制出来

docker cp 6354d22cae75:/usr/src/pgsql-database-backup /usr/src/database-backup

**恢复脚本**# /bin/bash
echo "开始执行 PostgreSql数据库的恢复!"
echo "restore ing -------------------"
nowtime=$(date +%F+%T)
export PGPASSWORD=root
echo "时间:" $nowtime
set timeout 500
/usr/bin/pg_restore --host "121.4.226.11" --port "5432" --username "postgres" -W
--dbname "test" --verbose "/usr/src/pgsql-database-backup/2021-08-18+02:08:14.backup"
echo "数据库恢复结束!"exit;
选项option...
下面的命令行参数控制输出的内容和格式。dbname
声明将要转储的数据库名。 如果没有声明这个参数,那么使用环境变量 PGDATABASE。 如果那个环境变量也没声明,
那么用发起连接的用户名。-a
--data-only
只输出数据,不输出模式(数据定义)。这个选项只是对纯文本格式有意义。对于归档格式,你可以在调用 pg_restore 的时候声明选项。-b
--blobs
在转储中包含大对象。必须选择一种非文本输出格式。-c
--clean
输出在创建数据库创建命令之前先清理(删除)该数据库对象的命令。这个选项只是对纯文本格式有意义。对于归档格式,你可以在调用 pg_restore 的时候声明选项。-C
--create
以一条创建该数据库本身并且与这个数据库联接等命令开头进行输出。 (如果是这种形式的脚本,那么你在运行脚本
之前和哪个数据库联接就不重要了。)这个选项只对纯文本格式有意义。对于归档格式,你可以在调用 pg_restore 的时候声明该选项。-d
--inserts
将数据输出为的INSERT命令(而不是 COPY)。 这样会导致恢复非常缓慢。 这个选项主要用于制作那种可以用于
其它非 PostgreSQL 数据库的转储。 请注意,如果你重新排列了字段顺序,那么恢复可能会完全失败。 -D 更安全,
但是也更慢。-D
--column-inserts
--attribute-inserts
把数据转储为带有明确字段名的 INSERT 命令。 (INSERT INTO table(column, ...) VALUES ...)。 这样会
导致恢复非常缓慢,它主要用于制作那种可以用于其它非 PostgreSQL 数据库的转储。-f file
--file=file
把输出发往指定的文件。如果忽略这些,则使用标准输出。-F format
--format=format
选择输出的格式。format可以是下列之一:p
输出纯文本SQL脚本文件(缺省)t
输出适合输入到 pg_restore 里的tar归档文件。 使用这个归档允许在恢复数据库时重新排序和/或把数据库对象排除
在外。同时也可能可以在恢复的时候限制对哪些数据进行恢复。c
输出适于给 pg_restore 用的客户化归档。 这是最灵活的格式,它允许对装载的数据和对象定义进行重新排列。
这个格式缺省的时候是压缩的。-i
--ignore-version
忽略在 pg_dump 和数据库服务器之间的版本差别。pg_dump 可以处理来自以前版本的PostgreSQL 的数据库,但是太老的版本则不被支持了(目前是支持到 7.0)。
如果你需要跨越版本检查时才使用这个选项( 而且如 pg_dump 失效,别说我没警告你)。-n namespace
--schema=schema
只转储 schema 的内容。 如果没有声明这个选项,所有目标数据库中的非系统模式都会被转储出来。注意: 在这个模式里,pg_dump 并不试图转储任何其它选定模式可能依赖的数据库对象。 因此,系统不保证单一的
一个模式的转储就可以成功地恢复到一个干净的数据库中去。-o
--oids
作为数据的一部分,为每个表都输出对象标识(OID)。 如果你的应用在某种程度上引用了OID字段的话,
(比如,在外键约束中用到)。 那么使用这个选项。否则,不应该使用这个选项。-O
--no-owner
不 把对象的所有权设置为对应源数据库。 通常, pg_dump 发出(psql特有的) ALTER OWNER 或者
SET SESSION AUTHORIZATION 语句以设置创建的数据库对象的所有权。 又见 -R 和
-X use-set-session-authorization选项。请注意 -O 并不防止所有对数据库的重新联接,只是防止那些为调整权限进行的排它联接。这个选项只是对纯文本格式有意义。对于归档格式,在你调用 pg_restore 的时候你可以声明该选项。-R
--no-reconnect
这个选项已经过时,但是出于向下兼容的考虑,仍然接受这个选项。-s
--schema-only
只输出对象定义(模式),不输出数据。-S username
--superuser=username
声明关闭触发器时需要用到的超级用户名。 它只有使用了 --disable-triggers 的时候才有关系。 (通常,我们
最好不要输入这个参数,而是用超级用户启动生成的脚本。)-t table
--table=table
只输出表 table的数据。 很可能是在不同模式里面有多个同名表;如果这样,那么所有匹配的表都将被转储出来。
同时声明 --schema 和 --table 则只选择一个表。注意: 在这个模式里,pg_dump 并不试图转储任何其它选定表可能依赖的数据库对象。 因此,系统不保证单一的一个
表的转储就可以成功地恢复到一个干净的数据库中去。-v
--verbose
声明冗余模式。 这样将令 pg_dump 输出详细的对象评注以及转储文件的启停时间和进度信息到标准输出上。-x
--no-privileges
--no-acl
避免输出 ACL(赋予/撤消 命令)和表的所有者关系信息。-X disable-dollar-quoting
--disable-dollar-quoting
这个选项关闭使用美元符包围函数体。强制它们用 SQL 标准的字串语法的引号包围。-X disable-triggers
--disable-triggers
这个选项只是和创建仅有数据的转储相关。它告诉 pg_dump 包含在恢复数据时,临时关闭目标表上面的触发器的命令。
如果你在表上有参考完整性检查或者其它触发器,而恢复数据的时候你不想重载他们,那么你就应该使用这个选项。目前,为 --disable-triggers 发出的命令必须用超级用户来做。 因此,你应该同时用 -S 声明一个超级用户名,
或者最好是用一个超级用户的身份来启动这个生成的脚本。这个选项只对纯文本格式有意义。对于归档格式,你可以在调用 pg_restore 的时候声明这个选项。-X use-set-session-authorization
--use-set-session-authorization
输出 SQL 标准 SET SESSION AUTHORIZATION 命令而不是 OWNER TO 命令。 这样的转储结果更加复合标准,
但是依赖转储中的对象的历史,可能不能正确恢复。-Z 0..9
--compress=0..9
声明在那些支持压缩的格式中使用的压缩级别。 (目前只有客户化格式支持压缩)。下面的命令行参数控制数据库为联接参数。
-h host
--host=host
声明运行服务器的机器的主机名。 如果数值以斜杠开头,则它被用做到 Unix 域套接字的路径。 缺省是从 PGHOST
环境变量中取得的,如果设置了这个环境变量的话,否则,尝试一个 Unix 域套接字连接。-p port
--port=port
声明服务器正在侦听并等待联接的 TCP 端口或本地 Unix 主控套接字文件句柄。 缺省时使用环境变量 PGPORT的值(如果存在),或者是编译时的缺省值。-U username
以给出用户身分联接。-W
强制口令提示。如果服务器需要口令认证,那么这个动作应该自动发生。pg_restore --  从一个由 pg_dump 创建的备份文件中恢复 PostgreSQL 数据库。
pg_restore 接受下列命令行参数。filename
声明要恢复的备份文件的位置。如果没有声明,则使用标准输入。-a
--data-only
只恢复数据,而不恢复表模式(数据定义)。-c
--clean
创建数据库对象前先清理(删除)它们。-C
--create
在恢复数据库之前先创建它。(如果出现了这个选项,和 -d 在一起的数据库名只是用于发出最初的
CREATE DATABASE命令。 所有数据都恢复到名字出现在归档中的数据库中去。)-d dbname
--dbname=dbname
与数据库 dbname 联接并且直接恢复到该数据库中。-e
--exit-on-error
如果在向数据库发送 SQL 命令的时候碰到错误,则退出。 缺省是继续执行并且在恢复结束时显示一个错误计数。-f filename
--file=filename
声明生成的脚本的输出文件,或者出现-l 选项时用于列表的文件,缺省是标准输出。-F format
--format=format
声明备份文件的格式。因为pg_restore 会自动判断格式,所以如果声明了,它可以是下面之一:t
备份是一个 tar 归档。 使用这个格式允许在恢复数据库的时候重新排序和/或把表模式元素排除出去。
同时还可能在恢复的时候限制装载的数据。c
备份的格式是来自pg_dump的客户化格式。 这是最灵活的格式,因为它允许重新对数据排序,也允许重载表模式元素。缺省时这个格式是压缩的。-i
--ignore-version
忽略数据库版本检查。-I index
--index=index
只恢复命名的索引。-l
--list
列出备份的内容。这个操作的输出可以用 -L 选项限制和重排所恢复的项目。-L list-file
--use-list=list-file
只恢复在 list-file 里面的元素,以它们在文件中出现的顺序。 你可以移动各个行并且也可以通过在行开头放 ';'
的方式注释。(见下文获取例子。)-O
--no-owner
不 要输出设置对象的权限,以便与最初的数据库匹配的命令。 缺省时,pg_restore 发出 ALTER OWNER 或SET SESSION AUTHORIZATION 语句设置创建出来的模式元素的所有者权限。 如果最初的数据库连接不是由超级用户(或者是拥有所有创建出来的对象的同一个用户)发起的,那么这些语句将失败。 使用 -O,那么任何用户都可以用于初始的连接,并且这个用户将拥有所有创建出来的对象。-P function-name(argtype [, ...])
--function=function-name(argtype [, ...])
只恢复指定的命名函数。请注意仔细拼写函数名及其参数,应该和转储的内容列表中的完全一样。-R
--no-reconnect
这个选项已经废弃了,但是为了保持向下兼容仍然接受。-s
--schema-only
只恢复表结构(数据定义)。不恢复数据,序列值将重置。-S username
--superuser=username
设置关闭触发器时声明超级用户的用户名。 只有在设置了 --disable-triggers 的时候才有用。-t table
--table=table
只恢复表指定的表的定义和/或数据。-T trigger
--trigger=trigger
只恢复指定的触发器。-v
--verbose
声明冗余模式。-x
--no-privileges
--no-acl
避免 ACL 的恢复(grant/revoke 命令)。-X use-set-session-authorization
--use-set-session-authorization
输出 SQL 标准的 SET SESSION AUTHORIZATION 命令,而不是 OWNER TO 命令。
这样令转储与标准兼容的更好,但是根据转储中对象的历史,这个转储可能不能恰当地恢复。-X disable-triggers
--disable-triggers
这个选项只有在执行仅恢复数据的时候才相关。它告诉 pg_restore 在装载数据的时候执行一些命令
临时关闭在目标表上的触发器。 如果你在表上有完整性检查或者其它触发器, 而你又不希望在装载数据的时候激活它们,
那么可以使用这个选项。

PostGreSql的备份和恢复相关推荐

  1. linux postgresql 恢复数据库,PostgreSQL数据库备份和恢复

    一.备份 1.cmd到PostgreSQL安装目录bin下 2.备份命令 pg_dump -h 192.168.100.23 -U postgres postgres > D:\postgres ...

  2. PostgreSQL数据库备份和恢复

  3. 数据库服务器 之 Postgresql备份和恢复------SQL转储篇

    作者:小P 来自:LinuxSir.Org 摘要: 和任何包含珍贵数据的东西一样,PostgreSQL 数据库也应该经常备份.备份PostgreSQL数据库有三种方法,各种方法有利有弊,本文先讲一下S ...

  4. pgsql的数据备份和恢复

    cd /opt/opsmgr/web/components/postgresql96linux64.1/bin 进入对应的pg数据库的bin目录下: 执行备份操作 ./pg_dump -U postg ...

  5. PostgreSQL数据库系列之六:增量备份和恢复

    [概述] 备份是恢复的前提.不发生故障时,世界很太平,但发生故障时,如果不能顺利进行恢复,那将是一场噩梦!甚至可能对于企业是致命打击,这绝对不是危言耸听! 日常的备份有效性的检查就显得尤其重要,一个无 ...

  6. Postgresql杂谈 18—Postgresql中的备份和恢复(二)

    上一篇文章中,我们主要学习了Postgresql的逻辑备份和恢复,接着上一篇的内容,今天我们介绍下Postgresql的物理备份.所谓物理备份,就是针对数据库的数据文件或者目录进行备份,物理备份的好处 ...

  7. iptables规则备份和恢复,任务计划chkconfig工具systemd管理服务

    2019独角兽企业重金招聘Python工程师标准>>> iptables规则备份和恢复 备份 iptables-save > /tmp/ipt.txt service ipta ...

  8. 自动化部署之gitlab备份和恢复

    <font size=5>gitlab的备份和恢复</font> (1)创建备份目录,并授权 [root@linux-node1 ~]# mkdir /data/backups ...

  9. iptables规则备份和恢复、firewall的zone的操作、service的操作

    iptables规则备份和恢复 保存和备份iptables规则如下: service iptables save //会把规则保存到/etc/sysconfig/iptables 把iptables规 ...

最新文章

  1. 【Python培训基础】一篇文件教你py文件打包成exe
  2. 为什么CSS使用假元素?
  3. mybatis一对多关联 创建_MyBatis多对多关联查询(级联查询)
  4. 关于java同步包中ConcurrentLinkedQueue类的深入分析与理解
  5. 七十六、 数据结构二叉树及其代码实现
  6. Nginx 常见问题解决
  7. ubuntu 14.04 编译android4.0 出现gcc-version.sh: line 11: cc: command not found错误解决方法
  8. 网络爬虫-获取网页中的数据加伪装头,伪装成浏览器多次访问,避免单次访问导致ip被封
  9. 黑马程序员——选择排序
  10. 乐视网回击贾跃亭:债务处理没有进展,先拿出57亿再说
  11. 【线程】——等待集(wait,notify,notifyAll)
  12. xml property标签注入一个类变量_Spring-06-依赖注入(DI)
  13. Android KLog源代码分析
  14. 7种提高工作效率的Vim操作
  15. android selector的item属性
  16. php oracle 存储过程,用PHP调用Oracle存储过程
  17. 解读BOLT引擎例子——HelloBolt2
  18. zuc算法代码详解_ZUC算法了解
  19. 微信小程序tap事件中target与currentTarget的区别
  20. Cocos2d-JS: 2.编译到安卓和iOS

热门文章

  1. 基于微信小程序医院预约挂号系统PHP后端接口
  2. Labview VISA 读取串口
  3. ArcGIS:区域分析工具概述
  4. JAVA· chatAt()方法
  5. Unresolved Dependencies
  6. python调用VBA的宏
  7. 初探脚本小子--快速上手自写信息收集脚本
  8. 网络接口型单片机微机综合实验开发装置QY-DPJ09
  9. H5 video标签的用法及问题
  10. (转)机器学习系列(7)_机器学习路线图(附资料)