1

每当我在 Rails 应用程序的数据库上运行 rake 任务时,都会出现以下错误。

pg_dump: server version: 9.2.4; pg_dump version: 9.1.5
pg_dump: aborting because of server version mismatch

我搜索了一下,发现了一些关于更新 postgres brew 包的建议,但这没有用。

为什么使用了不正确的 pg_dump 版本,我该如何解决?或者我应该寻找什么搜索词来找到解决方案?

编辑

我的 pg_dump 配置信息:

$ pg_dump --version
> pg_dump (PostgreSQL) 9.1.5
$ which pg_dump
> /usr/bin/pg_dump
$ echo $PATH
> /Users/andrewharvey/.rvm/gems/ruby-1.9.3-p392@mantawatch/bin:/Users/andrewharvey/.rvm/gems/ruby-1.9.3-p392@global/bin:/Users/andrewharvey/.rvm/rubies/ruby-1.9.3-p392/bin:/Users/andrewharvey/.rvm/bin:/usr/local/heroku/bin:/usr/bin:/bin:/usr/sbin:/sbin:/usr/local/bin:/usr/local/bin:/usr/bin:/bin:/usr/sbin:/sbin:/usr/local/bin:/usr/bin:/bin:/usr/sbin:/sbin:/usr/local/bin:/Users/andrewharvey/.rvm/bin

我正在使用 oh_my_zsh,路径是在我的 .zshrc 文件中定义的。这可能是我的问题的原因(我确信这可以被清理),不幸的是我不知道我在做什么来调试和编辑它。感谢指针(我正在使用通过 Homebrew 安装的 RVM 和 postgres)。

source $ZSH/oh-my-zsh.sh

[[ -s "$HOME/.rvm/scripts/rvm" ]] && . "$HOME/.rvm/scripts/rvm"

alias pg='pg_ctl -D /usr/local/var/postgres -l /usr/local/var/postgres/server.log'

export
 PATH=$PATH:/usr/local/bin:/Users/andrewharvey/.rvm/gems/ruby-2.0.0-p0/bin:/Users/andrewharvey/.rvm/gems/ruby-2.0.0-p0@global/bin:/Users/andrewharvey/.rvm/rubies/ruby-2.0.0-p0/bin:/Users/andrewharvey/.rvm/bin:/usr/bin:/bin:/usr/sbin:/sbin:/usr/local/bin:/usr/bin:/bin:/usr/sbin:/sbin:/usr/local/bin

### Added by the Heroku Toolbelt
export PATH="/usr/local/heroku/bin:$PATH"
4

2 回答 2

5

对于 mac 用户,放在 .profile 文件的顶部。

export PATH="/Applications/Postgres.app/Contents/MacOS/bin:$PATH"

然后运行

. ~/.profile
于 2013-10-13T14:18:16.530 回答
3

下面的输出显示了什么?看起来您尝试使用的 pg_dump 版本是 9.1 版本,而您要连接的集群是 9.2。如果是这种情况,那么您需要确定 9.2 pg_dump 的正确路径。

pg_dump --version

which pg_dump

echo $PATH

[在 OP 提供更多细节后编辑]

根据此页面:https ://wiki.postgresql.org/wiki/Installers/Mac_OS_X ,自制软件可能将工具安装在/usr/local/bin. 但是,您的电流$PATH位于/usr/local/bin其他几条路径之后。我已经整理了你的$PATH设置。因此,请尝试将以下更改保存到您的.zshrc文件中并获取它以获取更改(source ~/.zshrc)。

export PATH=/usr/local/bin:/Users/andrewharvey/.rvm/gems/ruby-2.0.0-p0/bin:/Users/andrewharvey/.rvm/gems/ruby-2.0.0-p0@global/bin:/Users/andrewharvey/.rvm/rubies/ruby-2.0.0-p0/bin:/Users/andrewharvey/.rvm/bin:/usr/bin:/bin:/usr/sbin:/sbin:/usr/local/bin:/usr/bin:/bin:/usr/sbin:/sbin:/usr/local/bin:$PATH
export PATH="/usr/local/heroku/bin:$PATH"
于 2013-07-21T18:11:24.493 回答