0

我一直在尝试在生产中部署我的本地应用程序

我的宝石文件

source 'https://rubygems.org'
ruby '2.0.0'

gem 'pry', '0.9.12'
gem 'mysql', '2.9.1'
gem 'rails-api', '0.1.0'
gem 'rails', '4.0.1'
gem 'awesome_print', '1.1.0'

group :test, :development do
  gem 'raddocs', '0.2.0'
  gem 'rspec-rails', '2.13.0'
  gem 'rspec-core', '2.13.1'
  gem 'rspec_api_documentation', '1.0.0'
end

group :development do
  gem 'railroady', '1.1.1'
end

group :test do
  gem 'database_cleaner'
  gem 'capybara', '2.1.0'
  gem 'shoulda-matchers', '1.5.6'
  gem 'factory_girl_rails', '4.0'
  gem "factory_girl", "4.0"
end

我的路线文件中有下一条路线:

post '/region/:id/service' => 'region#service'

我的控制器看起来像这样:

class RegionController < ApplicationController
  def service
    region = Region.find params[:id]
    render text: region.name
  end
end

好的,问题是,当我使用curlin development 调用服务时,效果很好:

$ curl -X POST localhost:port/region/6/service -d ""

但是当我将文件上传到heroku并再次调用该服务时,我得到404 not found(错误)500 internal server(错误)

cleardb根据文档使用插件。

我认为问题是数据库。起初,我根据以下内容编写了用于生产环境的数据库信息的 database.yml:

$ heroku config | grep CLEARDB_DATABASE_URL

但我认为没有必要,因为heroku可以根据这条线自动完成......我想是的

-----> Writing config/database.yml to read from DATABASE_URL

我尝试了两种方式都没有结果,当我尝试在生产中进行查询时,我真的不知道为什么服务会崩溃。

我的database.yml看起来像

development:
  adapter: mysql
  password: xxx
  database: myapp.development
  pool: 5
  timeout: 5000

test:
  adapter: mysql
  password: xxx
  database: myapp.test_1
  pool: 5
  timeout: 5000

production:
  adapter: mysql
  encoding: utf8
  database: xxx
  username: yyy
  password: zzz
  pool: 5
  timeout: 5000
  host: us-cdbr-east-04.cleardb.com
4

1 回答 1

1

经过一些调试后,我发现 heroku 中的 id 被分配了每 10 个数字,例如我的表区域之一看起来:

+----+-----------+-------+---------------------+---------------------+
| id | name      | state | created_at          | updated_at          |
+----+-----------+-------+---------------------+---------------------+
|  1 | Brasil    |     1 | 2014-01-08 13:12:56 | 2014-01-08 13:12:56 |
| 11 | Chile     |     1 | 2014-01-08 13:12:56 | 2014-01-08 13:12:56 |
| 21 | Peru      |     1 | 2014-01-08 13:12:56 | 2014-01-08 13:12:56 |
| 31 | Argentina |     1 | 2014-01-08 13:12:56 | 2014-01-08 13:12:56 |
+----+-----------+-------+---------------------+---------------------+

“ClearDB 使用循环复制来提供主-主 MySQL 支持。因此,必须配置某些东西,例如 auto_increment 键(或序列),以便在所有情况下一个主不使用与另一个主相同的键。我们这样做这是通过配置 MySQL 跳过某些键,并强制 MySQL 为每个使用的键使用特定的偏移量。我们使用值 10 而不是 2 的原因是为了未来的发展。

谢谢。

于 2014-01-08T14:41:49.960 回答