gpt4 book ai didi

ruby-on-rails - 自学 Rails 将第一个应用程序部署到 heroku - 上传失败 - sqlite3 和 postgre 故障

转载 作者:行者123 更新时间:2023-12-04 05:58:28 39 4
gpt4 key购买 nike

我自学 Rails。我是一名程序员,但不是网络程序员。我正在阅读 Michael Hartl 的书 here

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

git push heroku master

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

gem 'sqlite3'

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

我试过了,然后运行 ​​bundle install,然后尝试推送应用程序。没有运气我在我的控制台上收到此消息:

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 网站的建议 here

更改我的 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

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

最佳答案

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

group :production do
gem 'pg'
end

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

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

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

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

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

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

     bundle install --without production

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

再次强调,自制软件是您的 friend 。

$ brew install postgresql

关于ruby-on-rails - 自学 Rails 将第一个应用程序部署到 heroku - 上传失败 - sqlite3 和 postgre 故障,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10321189/

39 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com