Получение 404 в приложении Ruby Sinatra - Heroku

У меня есть простое приложение Sinatra. На локальной машине работает нормально.

Развернул его на Heroku, и я продолжаю получать 404 в журналах.

Я обещаю, что искал в Интернете около 5 часов подряд и не могу понять это.

Журналы, которые я получаю:

2014-11-08T00:17:12.537150+00:00 heroku[web.1]: Starting process with command `bundle exec rackup config.ru -p 51609`
2014-11-08T00:17:12.840926+00:00 heroku[web.1]: Process exited with status 143
2014-11-08T00:17:16.370395+00:00 app[web.1]: [2014-11-08 00:17:16] INFO  WEBrick 1.3.1
2014-11-08T00:17:16.370515+00:00 app[web.1]: [2014-11-08 00:17:16] INFO  ruby 2.0.0 (2014-10-27) [x86_64-linux]
2014-11-08T00:17:16.371280+00:00 app[web.1]: [2014-11-08 00:17:16] INFO  WEBrick::HTTPServer#start: pid=2 port=51609
2014-11-08T00:17:16.745163+00:00 heroku[web.1]: State changed from starting to up
2014-11-08T00:17:35.351527+00:00 heroku[router]: at=info method=GET path="/" host=pacific-refuge-6392.herokuapp.com request_id=406b2ea5-5898-4a86-8a26-6bf71f70d3f6 fwd="200.170.116.105" dyno=web.1 connect=3ms service=22ms status=404 bytes=319
2014-11-08T00:17:35.352064+00:00 app[web.1]: 200.170.116.105 - - [08/Nov/2014 00:17:35] "GET / HTTP/1.1" 404 18 0.0030

Мой Gemfile выглядит так:

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

gem 'sinatra-base'
gem 'sinatra-assetpack'
gem 'sinatra-asset-pipeline'
gem 'sass'
gem 'datamapper'
gem 'pony'

group :production do
    gem "pg"
    gem "dm-postgres-adapter"
end

group :development, :test do
    gem "sqlite3"
    gem "dm-sqlite-adapter"
end

Proclife:

web: bundle exec rackup config.ru -p $PORT

Я попробовал его с рубином вместо стойки и несколько других вариантов, которые я нашел.

Конфиг.ру

require './my_launch'
run Sinatra::Application

И, наконец, мое приложение: my_launch.rb:

require 'sinatra/base'
require 'sinatra/assetpack'
require 'sass'
require 'data_mapper'
require 'dm-migrations'
require 'pony'

DataMapper.setup(:default, ENV['DATABASE_URL'] || "sqlite3://#{Dir.pwd}/mylaunch.db")

class Users
  include DataMapper::Resource
  property :id, Serial
  property :email, String, :required => true, :format => :email_address
  property :created_at, DateTime
end

DataMapper.finalize.auto_upgrade!


class MyLaunch < Sinatra::Base
  set :sessions, true
  register Sinatra::AssetPack

  assets do
     css :main, [
      '/css/*.css'
     ]
     css_compression :sass
  end

  get '/' do
    erb :index
  end

  post '/' do
    n = Users.new
    n.email = params[:email]
    n.created_at = Time.now
    n.save
    redirect '/obrigado'
  end

  get '/obrigado' do
    erb :obrigado
  end

  get '/admin' do
    @users = Users.all :order => :id.desc
    erb :admin
  end

  run! if app_file == $0
end

Моя база данных выглядит нормально. Чтобы проверить это, я запустил консоль heroku и создал запись в своей базе данных. Через требование my_launch.rb и создание Users.new и более поздних версий Users.save

https://github.com/abarro/mylaunch


person abarro    schedule 08.11.2014    source источник


Ответы (1)


В вашем конфигурационном файле ваш вызов run Sinatra::Application отличается от унаследованного вами класса Sinatra, в котором определены все ваши маршруты. Измените его на

require './my_launch'
run MyLaunch
person Benji    schedule 08.11.2014