1

JBuilderを使い始めたばかりで、開発モードでローカルで正常に動作しています。

Nginx / Unicornサーバーにプッシュしたところ、JBuilder jsonを使用するURLを表示しようとすると、テンプレートが見つからないというエラーが表示され、:handlersリストにJBuilderがありませんか?

テンプレートがありません

テンプレートclient_events/all_client_events_for_client、application / all_client_events_for_client、{:locale => [:en]、:formats => [:html、:text、:js、:css、:ics、:csv、:png、:jpeg、: gif、:bmp、:tiff、:mpeg、:xml、:rss、:atom、:yaml、:multipart_form、:url_encoded_form、:json、:pdf、:zip]、:handlers => [:erb、:builder、 :slim、:haml]}。検索対象:* "/ home / deployer / apps / bigfor-blue /releases / 20121022093934 / app / views"

完全にローカルで動作しますが、本番環境で実行しようとすると、何らかの理由で同意しません。

どんなアイデアでも素晴らしいでしょう。

乾杯

アップデート:

Development.rb

  BigforBlue::Application.configure do
    # Settings specified here will take precedence over those in config/application.rb

    # In the development environment your application's code is reloaded on
    # every request. This slows down response time but is perfect for development
    # since you don't have to restart the web server when you make code changes.
    config.cache_classes = false

    # Log error messages when you accidentally call methods on nil.
    config.whiny_nils = true

    # Show full error reports and disable caching
    config.consider_all_requests_local       = true
    config.action_controller.perform_caching = false

    # Print deprecation notices to the Rails logger
    config.active_support.deprecation = :log

    # Only use best-standards-support built into browsers
    config.action_dispatch.best_standards_support = :builtin

    # Raise exception on mass assignment protection for Active Record models
    config.active_record.mass_assignment_sanitizer = :strict

    # Log the query plan for queries taking more than this (works
    # with SQLite, MySQL, and PostgreSQL)
    config.active_record.auto_explain_threshold_in_seconds = 0.5

    # Do not compress assets
    config.assets.compress = false

    # Expands the lines which load the assets
    config.assets.debug = true


    # MAILER

    # Don't care if the mailer can't send
    config.action_mailer.raise_delivery_errors = true

    config.action_mailer.delivery_method = :smtp

    config.action_mailer.default_url_options = { :host => "localhost:3000" }
    ActionMailer::Base.smtp_settings = {
      :address => "smtp.gmail.com",
      :port => 587,
      :authentication => :plain,
      :user_name => "**** TAKEN OUT ****",
      :password => "**** TAKEN OUT ****",
      :openssl_verify_mode => "none"
    }

  end

Production.rb

  BigforBlue::Application.configure do
    # Settings specified here will take precedence over those in config/application.rb

    # Code is not reloaded between requests
    config.cache_classes = true

    # Full error reports are disabled and caching is turned on
    config.consider_all_requests_local       = true
    config.action_controller.perform_caching = true

    # Disable Rails's static asset server (Apache or nginx will already do this)
    config.serve_static_assets = false

    # Compress JavaScripts and CSS
    config.assets.compress = true

    # Don't fallback to assets pipeline if a precompiled asset is missed
    config.assets.compile = false

    # Generate digests for assets URLs
    config.assets.digest = true

    # Defaults to nil and saved in location specified by config.assets.prefix
    # config.assets.manifest = YOUR_PATH

    # Specifies the header that your server uses for sending files
    # config.action_dispatch.x_sendfile_header = "X-Sendfile" # for apache
    # config.action_dispatch.x_sendfile_header = 'X-Accel-Redirect' # for nginx

    # Force all access to the app over SSL, use Strict-Transport-Security, and use secure cookies.
    # config.force_ssl = true

    # See everything in the log (default is :info)
    # config.log_level = :debug

    # Prepend all log lines with the following tags
    # config.log_tags = [ :subdomain, :uuid ]

    # Use a different logger for distributed setups
    # config.logger = ActiveSupport::TaggedLogging.new(SyslogLogger.new)

    # Use a different cache store in production
    # config.cache_store = :mem_cache_store

    # Enable serving of images, stylesheets, and JavaScripts from an asset server
    # config.action_controller.asset_host = "http://assets.example.com"

    # Precompile additional assets (application.js, application.css, and all non-JS/CSS are already added)
    # config.assets.precompile += %w( search.js )

    # Disable delivery errors, bad email addresses will be ignored
    # config.action_mailer.raise_delivery_errors = false

    # Enable threaded mode
    # config.threadsafe!

    # Enable locale fallbacks for I18n (makes lookups for any locale fall back to
    # the I18n.default_locale when a translation can not be found)
    config.i18n.fallbacks = true

    # Send deprecation notices to registered listeners
    config.active_support.deprecation = :notify

    # Log the query plan for queries taking more than this (works
    # with SQLite, MySQL, and PostgreSQL)
    # config.active_record.auto_explain_threshold_in_seconds = 0.5

    # MAILER
    # config.action_mailer.default_url_options = { :host => "http://*** TAKEN OUT ***" }

  end

更新2

セットアップからJBuilderを削除し、それをRABLに置き換えましたが、テンプレートとハンドラーが欠落しているという同じ問題が引き続き発生します。

したがって、Jbuilder / RABLエラーではなく、Unicorn/Nginxエラーのように見えます。

4

1 に答える 1

1

結局、この問題は、構成中、または最初のCapistranoの「capdeploy:setup」または「capdeploy:cold」のいずれかで発生したように見えます。

サーバーからアプリを削除し、新しい「cap deploy:setup」と「capdeploy:cold」を実行して問題を修正し、JBuilderが期待どおりに機能するようになりました。

Capistranoレシピは、最初のバグのある展開と2番目の動作中の展開の間で変更されなかったため、問題の原因はわかりません。

したがって、このような問題で立ち往生している場合の私のアドバイスは、アプリの完全な再デプロイがオプションになる可能性があります。

JB

于 2012-11-05T03:37:44.547 に答える