【问题标题】:How to easily clone a production postgresql database to staging [duplicate]如何轻松克隆生产 postgresql 数据库以暂存 [重复]
【发布时间】:2014-11-27 23:12:34
【问题描述】:

我在生产数据库中有数据,但想测试一些新功能,因此我在同一台服务器上设置了暂存环境,并希望将生产数据库中的数据与我的暂存应用程序一起使用。

如何将数据从我的 rails_production 数据库复制到我的 rails_staging 数据库,它们都具有相同的所有者 (postgres) 并共享相同的密码。

【问题讨论】:

  • 所选副本不是一个好选择;它特定于 PgAdmin 并使用模板,这不是最好的方法。当数据库有连接时,您不能将其复制为模板。

标签: ruby-on-rails database postgresql ruby-on-rails-4 psql


【解决方案1】:

最简单的方法是使用 pg_dump 进行备份,然后通过将输出管道传输到 psql 将其恢复到新数据库。如果你可以连接到这两个盒子,你也可以直接从 pg_dump 管道到 psql 而不使用本地文件系统。

这里描述了这个方法:

Copying PostgreSQL database to another server

【讨论】:

  • 他们都在同一个服务器上
  • 好的,所以 pg_dump 源 | psql 目标应该将数据从源传输到目标。
  • @Zehi,即使发生了一些错误(网络问题),如何确保一切正常?迁移后如何检查两个数据库是否相同?
  • 请注意这一点,因为例如,如果您从 staging 发送电子邮件,并且您在 staging DB 中有真实用户电子邮件,您将向真实用户发送垃圾邮件测试电子邮件。因此,出于多种原因(GDPR、如果您在暂存时发生某种数据泄露等情况,您自己的保护措施)建议匿名化敏感数据
猜你喜欢
  • 2011-06-23
  • 2016-12-31
  • 1970-01-01
  • 2013-05-02
  • 2018-06-01
  • 2013-07-11
  • 2011-05-04
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多