我一直在尝试在生产中部署我的本地应用
我的 Gemfile :
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
好的问题是,当我在开发中使用curl
调用服务时,效果非常好:
$ curl -X POST localhost:port/region/6/service -d ""
但是当我将文件上传到heroku时,我再次调用该服务 我发现 404未找到(错误)或 500内部服务器(错误)
我根据the documentation使用cleardb
插件。
我认为问题是DATABASE。起初我根据以下内容为 production 环境编写了我的 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
答案 0 :(得分: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的原因是为了将来的开发。“
感谢。