如何在Ubuntu 16.04上备份和还原PostgreSQL数据库

介绍

PostgreSQL是一个免费的开源数据库管理系统,可用于存储与网站有关的信息。它也被称为Postgres。该软件本身具有高性能的对象关系数据库,非常适合大型数据库和Web应用程序。

话虽这么说,任何数据库管理员最重要的任务之一就是定期备份数据库。在这里,您将学习如何在Ubuntu 16.04上备份和还原PostgreSQL数据库。

先决条件

  • 运行Ubuntu 16.04的服务器。
  • 具有sudo特权的非root用户。

步骤1:更新系统套件

在开始之前,请更新服务器上的软件包。

sudo apt-get update -y
sudo apt-get upgrade -y

步骤2:安装PostgreSQL

幸运的是,PostgreSQL在Ubuntu 16.04存储库中可用。您可以使用以下命令轻松安装它。

sudo apt-get install postgresql postgresql-contrib

安装完成后,它将创建一个名为postgresrole 的用户postgrespostgres还将创建一个名为的系统帐户。

启动postgresql服务,并使其能够在启动时运行。

sudo systemctl start postgresql
sudo systemctl enable postgresql

步骤3:备份说明

PostgreSQL带有一个称为pg_dump将数据库信息备份到文件的实用程序。

您可以从命令行界面运行此实用程序。例如,如果要备份单个数据库,请运行以下命令:

sudo pg_dump -U user_name database_name > backup_file

注意:该命令必须以超级用户身份运行。

您也可以通过以postgres用户身份登录来备份数据库。

sudo su - postgres
pg_dump postgres > postgres.bak

上面的命令将备份名为的默认数据库postgres

您也可以备份远程数据库。

pg_dump -U user_name -h remote_ip_address -p remote_port database_name > backup_file

如果要备份系统上的所有数据库,则pg_dumpall使用。

sudo pg_dumpall -U user_name > backup_file

步骤4:还原指示

您可以pg_dump使用psql命令来还原由命令创建的数据库。

首先,使用创建一个空数据库name new_database

sudo -u postgres psql
createdb -T template0 new_database

接下来,重定向backup_file使用以下命令调用的数据库转储:

psql new_database < backup_file

如果要在遇到错误时立即停止还原过程,请运行以下命令:

psql --set ON_ERROR_STOP=on new_database < backup_file

您可以pg_dumpall通过将文件传递到来还原命令创建的数据库psql

psql -U user_name -f backup_file   

结论

您现在已经拥有足够的知识来备份和还原PostgreSQL数据库。保留常规备份非常重要,因为它们对恢复系统很有用。



Leave a Comment

如何在Arch Linux上安装MariaDB 10.3或MySQL 8.0

如何在Arch Linux上安装MariaDB 10.3或MySQL 8.0

先决条件运行最新的Arch Linux的Vultr服务器(请参阅本文。)Sudo访问:需要以root身份运行的命令以#开头,其中一个

使用密钥文件在Ubuntu 16.04上的访问控制中在MongoDB 3.4中部署具有高可用性的副本集

使用密钥文件在Ubuntu 16.04上的访问控制中在MongoDB 3.4中部署具有高可用性的副本集

自2009年推出以来,MongoDB一直引领NoSQL行业。MongoDB的核心概念之一是副本集,因此在使用i之前

自动备份多个MySQL或MariaDB数据库

自动备份多个MySQL或MariaDB数据库

简介在本文中,我们将逐步介绍如何使用自定义bash脚本备份位于同一台计算机上的多个MySQL或MariaDB数据库

如何在Debian 9上安装Apache Cassandra 3.11.x

如何在Debian 9上安装Apache Cassandra 3.11.x

使用其他系统?Apache Cassandra是免费的开源NoSQL数据库管理系统,旨在提供可扩展性,高

如何在CentOS 7上安装和配置OrientDB Community Edition

如何在CentOS 7上安装和配置OrientDB Community Edition

OrientDB是下一代多模型开源NoSQL DBMS。通过支持多种数据模型,OrientDB可以在以下方面提供更多功能和灵活性:

如何在Ubuntu 16.04上备份,还原或传输MySQL / MariaDB数据库

如何在Ubuntu 16.04上备份,还原或传输MySQL / MariaDB数据库

备份是处理数据库的重要部分。无论您是运行公司网站还是仅托管WordPress,备份您的信息都很重要

如何在Ubuntu 15.10上安装Redis

如何在Ubuntu 15.10上安装Redis

Redis是键值数据存储解决方案,通常称为NoSQL数据库。它是内存中的单元,因此可以实现很高的读/写速度。

备份MySQL数据库

备份MySQL数据库

MySQL是世界上用于数据库的最流行的软件。确保您具有数据库备份非常重要。这种做法允许

在Ubuntu 16.04上通过SSL支持保护MariaDB

在Ubuntu 16.04上通过SSL支持保护MariaDB

MariaDB是一个免费的开源数据库,并且是MySQL中使用最广泛的直接替代方法。它由MySQL的开发人员制作,旨在恢复

使用Telegraf在Debian Jessie上安装InfluxDB

使用Telegraf在Debian Jessie上安装InfluxDB

简介InfluxDB是用Go编写的基于时间序列的数据库。InfluxDB有许多实际用途,其中之一是将监视数据存储在服务器上。一世

如何在Arch Linux上安装PostgreSQL 11.1

如何在Arch Linux上安装PostgreSQL 11.1

先决条件运行最新的Arch Linux的Vultr服务器(请参阅本文。)Sudo访问。需要以root身份运行的命令以#开头,其中一个

在OpenBSD 6上配置MariaDB

在OpenBSD 6上配置MariaDB

在本文中,我将向您展示如何在OpenBSD 6上安装MariaDB并将其配置为可供chroot的Web服务器(Apache或Nginx)访问。你会

如何在Ubuntu 16.04 LTS上安装Apache Cassandra 3.11.x

如何在Ubuntu 16.04 LTS上安装Apache Cassandra 3.11.x

使用其他系统?Apache Cassandra是免费的开源NoSQL数据库管理系统,旨在提供可扩展性,高

使用Snort设置Bar 2

使用Snort设置Bar 2

Barnyard2是一种将Snort的二进制输出存储和处理到MySQL数据库中的方法。开始之前,请注意,如果您没有打nor

如何使用Redis配置WordPress

如何使用Redis配置WordPress

Redis是一个数据结构存储。它在WordPress网站中很受欢迎,因为它通过优化的缓存方法提供了巨大的性能提升。

如何在Ubuntu 16.04上安装和使用ArangoDB

如何在Ubuntu 16.04上安装和使用ArangoDB

使用其他系统?简介ArangoDB是一个开放源代码NoSQL数据库,具有用于文档,图形和键值的灵活数据模型。它是

如何在Arch Linux上安装MongoDB 4.0

如何在Arch Linux上安装MongoDB 4.0

先决条件运行最新的Arch Linux的Vultr服务器(请参阅本文)Sudo访问:需要以root身份运行的命令以#开头,其中一个

如何在CentOS 7上安装Apache Cassandra 3.11.x

如何在CentOS 7上安装Apache Cassandra 3.11.x

使用其他系统?Apache Cassandra是免费的开源NoSQL数据库管理系统,旨在提供可扩展性,高

如何在CentOS 7上安装Laravel GitScrum

如何在CentOS 7上安装Laravel GitScrum

Laravel GitScrum或GitScrum是一种开源生产力工具,旨在帮助开发团队以类似的方式实施Scrum方法。

使用Docker在CentOS 7上开始使用SQL Server 2017(MS-SQL)

使用Docker在CentOS 7上开始使用SQL Server 2017(MS-SQL)

前提条件Docker引擎1.8+。至少4GB的磁盘空间。至少4GB的RAM。步骤1.安装Docker为了安装SQL-Server,Docker mus

AI 能否應對越來越多的勒索軟件攻擊?

AI 能否應對越來越多的勒索軟件攻擊?

勒索軟件攻擊呈上升趨勢,但人工智能能否幫助應對最新的計算機病毒?AI 是答案嗎?在這裡閱讀知道是 AI 布恩還是禍根

ReactOS:這是 Windows 的未來嗎?

ReactOS:這是 Windows 的未來嗎?

ReactOS,一個開源和免費的操作系統,這裡有最新版本。它能否滿足現代 Windows 用戶的需求並打倒微軟?讓我們更多地了解這種老式但更新的操作系統體驗。

通過 WhatsApp 桌面應用程序 24*7 保持聯繫

通過 WhatsApp 桌面應用程序 24*7 保持聯繫

Whatsapp 終於為 Mac 和 Windows 用戶推出了桌面應用程序。現在您可以輕鬆地從 Windows 或 Mac 訪問 Whatsapp。適用於 Windows 8+ 和 Mac OS 10.9+

人工智能如何將流程自動化提升到新的水平?

人工智能如何將流程自動化提升到新的水平?

閱讀本文以了解人工智能如何在小型公司中變得流行,以及它如何增加使它們成長並為競爭對手提供優勢的可能性。

macOS Catalina 10.15.4 補充更新引發的問題多於解決

macOS Catalina 10.15.4 補充更新引發的問題多於解決

最近,Apple 發布了 macOS Catalina 10.15.4 補充更新以修復問題,但似乎該更新引起了更多問題,導致 mac 機器變磚。閱讀這篇文章以了解更多信息

大數據的13個商業數據提取工具

大數據的13個商業數據提取工具

大數據的13個商業數據提取工具

什麼是日誌文件系統,它是如何工作的?

什麼是日誌文件系統,它是如何工作的?

我們的計算機以稱為日誌文件系統的有組織的方式存儲所有數據。這是一種有效的方法,可以讓計算機在您點擊搜索時立即搜索和顯示文件。 https://wethegeek.com/?p=94116&preview=true

技術奇點:人類文明的遙遠未來?

技術奇點:人類文明的遙遠未來?

隨著科學的快速發展,接管了我們的大量工作,我們陷入無法解釋的奇點的風險也在增加。閱讀,奇點對我們意味著什麼。

洞察 26 種大數據分析技術:第 1 部分

洞察 26 種大數據分析技術:第 1 部分

洞察 26 種大數據分析技術:第 1 部分

2021 年人工智能對醫療保健的影響

2021 年人工智能對醫療保健的影響

過去幾十年,醫療保健領域的人工智能取得了巨大飛躍。因此,醫療保健中人工智能的未來仍在日益增長。