2

我自学rails。我是程序员,但不是网络程序员。我在这里浏览迈克尔哈特尔的书

它提到从一开始就开始部署您的应用程序是一个好主意。我同意。所以我在 Heroku 上获得了一个帐户并进行了设置等。然后创建了我的第一个应用程序 git 和作品。然后按照 Heroku 网站上的所有说明进行操作。最后,我开始使用以下命令将我的应用程序推送到 Heroku:

git push heroku master

这本书说在这个阶段可能会出现问题,因为我机器上的应用程序使用的是 sqlite3 而 Heroku 需要 postgresql。这本书建议在我的应用程序的 gem 文件中更改一行

gem 'sqlite3'

gem 'sqlite3-ruby', :group => :development

我试过了,然后运行捆绑安装,然后尝试推送应用程序。不幸的是,我在控制台上收到了这条消息:

An error occured while installing sqlite3 (1.3.6), and Bundler cannot continue.
   Make sure that `gem install sqlite3 -v '1.3.6'` succeeds before bundling.

!!无法通过 Bundler 安装 gem。!!Heroku 推送被拒绝,无法编译 Ruby/rails 应用程序

所以我尝试了 Heroku 网站在这里的建议

更改我的 gemfile

由此:

gem 'sqlite3'

对此:

gem 'pg'

所以我尝试了这种方法,然后运行“捆绑安装”。但这也没有用。我在控制台上收到此消息:

Installing pg (0.13.2) with native extensions 
Gem::Installer::ExtensionBuildError: ERROR: Failed to build gem native extension.

        /Users/AM/.rvm/rubies/ruby-1.9.2-p290/bin/ruby extconf.rb 
checking for pg_config... no
No pg_config... trying anyway. If building fails, please try again with
 --with-pg-config=/path/to/pg_config
checking for libpq-fe.h... no
Can't find the 'libpq-fe.h header
*** extconf.rb failed ***
Could not create Makefile due to some reason, probably lack of
necessary libraries and/or headers.  Check the mkmf.log file for more
details.  You may need configuration options.

Provided configuration options:
    --with-opt-dir
    --with-opt-include
    --without-opt-include=${opt-dir}/include
    --with-opt-lib
    --without-opt-lib=${opt-dir}/lib
    --with-make-prog
    --without-make-prog
    --srcdir=.
    --curdir
    --ruby=/Users/AM/.rvm/rubies/ruby-1.9.2-p290/bin/ruby
    --with-pg
    --without-pg
    --with-pg-dir
    --without-pg-dir
    --with-pg-include
    --without-pg-include=${pg-dir}/include
    --with-pg-lib
    --without-pg-lib=${pg-dir}/lib
    --with-pg-config
    --without-pg-config
    --with-pg_config
    --without-pg_config


Gem files will remain installed in /Users/AM/.rvm/gems/ruby-1.9.2-p290/gems/pg-0.13.2     for inspection.
Results logged to /Users/AM/.rvm/gems/ruby-1.9.2-p290/gems/pg-0.13.2/ext/gem_make.out
An error occured while installing pg (0.13.2), and Bundler cannot continue.
Make sure that `gem install pg -v '0.13.2'` succeeds before bundling.

尝试运行此命令:

gem install pg

失败并显示以下错误消息:

Building native extensions.  This could take a while...
ERROR:  Error installing pg:
    ERROR: Failed to build gem native extension.

/Users/AM/.rvm/rubies/ruby-1.9.2-p290/bin/ruby extconf.rb
checking for pg_config... no
No pg_config... trying anyway. If building fails, please try again with
--with-pg-config=/path/to/pg_config
checking for libpq-fe.h... no
Can't find the 'libpq-fe.h header
*** extconf.rb failed ***
Could not create Makefile due to some reason, probably lack of
necessary libraries and/or headers.  Check the mkmf.log file for more
details.  You may need configuration options.

Provided configuration options:
--with-opt-dir
--with-opt-include
--without-opt-include=${opt-dir}/include
--with-opt-lib
--without-opt-lib=${opt-dir}/lib
--with-make-prog
--without-make-prog
--srcdir=.
--curdir
--ruby=/Users/AM/.rvm/rubies/ruby-1.9.2-p290/bin/ruby
--with-pg
--without-pg
--with-pg-dir
--without-pg-dir
--with-pg-include
--without-pg-include=${pg-dir}/include
--with-pg-lib
--without-pg-lib=${pg-dir}/lib
--with-pg-config
--without-pg-config
--with-pg_config
--without-pg_config


Gem files will remain installed in /Users/AM/.rvm/gems/ruby-1.9.2-p290/gems/pg-0.13.2     for inspection.
Results logged to /Users/AM/.rvm/gems/ruby-1.9.2-p290/gems/pg-0.13.2/ext/gem_make.out

有人可以帮我解决这个问题。我遇到了障碍。不知道下一步该怎么做。谢谢

4

5 回答 5

5

您的情况下的正确配置已在其他答案中发布,为了您的方便,我将其附在此处。

group :production do
  gem 'pg'
end

group :development, :test do
  gem 'sqlite3'
end

但是,请记住,当您运行时bundle install,bundler 将尝试为所有环境安装所有 gem。稍后,它将在运行时仅加载指定环境的 gem。

这就是为什么在您的本地计算机上也尝试安装它的原因pg

您有两种可能解决编译错误:

  1. install , gem 编译libpq所需的库。pg您不需要安装完整的 PostgreSQL 客户端或堆栈,libpq足以通过编译。在 MacOSX 上,您可能希望使用homebrew安装它。

  2. 告诉 bundler 在运行安装时跳过不必要的组。

     bundle install --without production
    

附带说明一下,请记住 SQLite 和 PostgreSQL 是两个不同的数据库。使用尽可能类似于生产环境的开发环境总是一个好主意。我个人的建议是在本地机器上安装 PostgreSQL,并在开发和生产中使用它。

同样,自制软件是您的朋友。

$ brew install postgresql
于 2012-04-26T09:47:04.540 回答
2

您需要在本地安装 Postgres。看来您使用的是 Mac,因此最简单的方法是在此处使用安装程序:

http://www.postgresql.org/download/macosx/

然后在你的 Gemfile 中坚持这个:

gem 'pg'
于 2012-04-25T18:10:23.650 回答
2

所以这是有效的:1)在机器上安装postgresql

2) 对于永久修复 - 转到 .bash_rc 文件并添加以下内容: export PATH = "/Library/PostgreSQL/9.1/bin/":$PATH 或者只是安装丢失的文件并运行一次捆绑命令,键入此在应用程序的根目录中:PATH=$PATH:/Library/PostgreSQL/9.1/bin/ bundle install 或 PATH=$PATH:/Library/PostgreSQL/9.1/bin/ gem install pg

3)现在安装了pg gem

这篇文章很有帮助: http ://excid3.com/blog/installing-postgresql-and-pg-gem-on-mac-osx/

于 2012-04-25T19:50:27.067 回答
0

尝试

group :production do
  gem 'pg'
end

group :development do
  gem 'sqlite3'
end
于 2012-04-25T18:07:53.647 回答
0

我认为错误的原因是您的系统上未安装pg,因此您无法安装gem。

虽然 heroku 不建议使用不同的数据库,但我的工作是这样的:

group :test, :development do
  gem 'sqlite3'
end

group :production do
  gem 'pg'
end
于 2012-04-25T18:12:53.667 回答