首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何在Mac上运行两个PostgreSQL副本?

如何在Mac上运行两个PostgreSQL副本?
EN

Stack Overflow用户
提问于 2016-08-26 17:14:56
回答 4查看 2.8K关注 0票数 4

我需要对一个同时具有本地和远程数据库服务器的系统运行集成测试;我希望在我的dev上在不同的端口上有两个PostgreSQL服务器。我通常使用Postgres.app --可以将其配置为运行两个实例吗?

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2016-08-26 17:54:01

只需从二进制目录(/Applications/Postgres.app/Contents/Versions/latest/bin/initdb).调用initdb即可。Pass --如果您愿意,请提供帮助,但initdb只需要一个数据目录,因此:

代码语言:javascript
运行
复制
initdb -D <dir>

完成后,转到您的新目录并编辑postgresql.conf并更改端口。

那就启动

票数 5
EN

Stack Overflow用户

发布于 2016-08-26 20:22:16

如果您安装了Postgresql的两个不同发行版,您可能会发现这更容易管理。选择https://www.postgresql.org/download/macosx/的两个

如果您从未安装Fink、Homebrew或Macports,我建议您选择Macports,因为它对其他工具的干扰较小。

要使用的端口号在postgresql.conf中配置。只要换行上面写的

港口= 5432

并重新启动该PostgreSQL服务器。

票数 1
EN

Stack Overflow用户

发布于 2016-08-26 21:57:36

虚拟机

另一个选项是在Mac上的虚拟机中运行每个Postgres集群(安装)。

平行线

我已经在Mac的Parallels桌面版本9、10和11中这样做了。(版本12是当前版本,但我还没有在Postgres上尝试过)。

我特别喜欢为Postgres使用VM,因为当不使用Postgres.app时,这个严肃的数据库往往是一个重量级的安装,例如当使用EnterpriseDB.com提供的安装程序作为对社区的礼貌时。

网络

您可以将网络配置为完全隔离,共享主机Mac的网络标识,或者为VM分配自己的IP地址,并在网络上充当单独的计算机。选择Configure… > Hardware > Network 1。在Source弹出菜单中,您可以为虚拟机网络适配器选择下列网络类型之一(描述摘自联机帮助):

  • 断开
  • 共享网络 选择此选项可启用虚拟机的网络地址转换(NAT)功能。在这种情况下,虚拟机将共享主机当前使用的任何网络连接。
  • 桥接网络 选择此选项可让虚拟机通过安装在主机上的网络适配器之一访问本地网络和Internet。在这种情况下,虚拟机被视为网络上的独立计算机,并且应该以与实际计算机相同的方式配置虚拟机。您可以选择虚拟机适配器将在桥接网络选项下面的列表中桥接的物理适配器。
  • 纯主机网络 选择此选项可允许虚拟机连接到主机和驻留在其上的虚拟机,并使其在主机之外不可见。

您可以用自己的IP号配置每个VM,而每个VM内部的Postgres使用相同的默认端口5432。提示:使用ping命令行工具来验证来宾和主机macOS是否可以到达对方。

测试

虚拟机可以帮助进行测试。

您可以以这种方式测试macOS,以来宾身份运行旧版本或较新版本的macOS。来宾macOS版本不需要与主机相同。

同样,为了测试目的,可以在不同的VM中安装不同版本的Postgres。

您可以创建一个表示整个VM的单个文件的备份副本(当然,首先关闭VM )。当您想要恢复到它的原始状态时,请用备份的新副本替换当前的VM文件。

其他虚拟机

Parallels只是macOS (MacOS)三个成功的虚拟机应用程序之一。我希望这三者都能很好地托管Postgres服务器。

苹果现在允许在Mac上作为主机运行时,将最新版本的macOS作为客户操作系统安装在虚拟机中。(许多年前以前是不允许的。) 读他们的执照的细节。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/39171536

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档