繁体   English   中英

Rails Capistrano在本地预编译资产,但无法在生产中加载

[英]Rails Capistrano precompile assets locally not loading on production

我将Rails应用程序部署到了AWS服务器上并尝试运行rake资产:在本地进行预编译并在部署时上传。由于服务器上的内存不足问题,

这是我的deploy.rb

# config valid only for current version of Capistrano
lock '3.5.0'

set :application, 'fullpower_tee'
set :repo_url, 'git_repo' # Edit this to match your repository
set :branch, :master
set :deploy_to, '/home/deploy/fullpower_tee'
set :pty, true
set :linked_files, %w{config/database.yml config/application.yml}
set :linked_dirs, %w{bin log tmp/pids tmp/cache tmp/sockets vendor/bundle public/system public/uploads}
set :keep_releases, 2
set :rvm_type, :user
set :rvm_ruby_version, 'ruby-2.2.1'


set :puma_rackup, -> { File.join(current_path, 'config.ru') }
set :puma_state, "#{shared_path}/tmp/pids/puma.state"
set :puma_pid, "#{shared_path}/tmp/pids/puma.pid"
set :puma_bind, "unix://#{shared_path}/tmp/sockets/puma.sock"    #accept array for multi-bind
set :puma_conf, "#{shared_path}/puma.rb"
set :puma_access_log, "#{shared_path}/log/puma_error.log"
set :puma_error_log, "#{shared_path}/log/puma_access.log"
set :puma_role, :app
set :puma_env, fetch(:rack_env, fetch(:rails_env, 'production'))
set :puma_threads, [0, 8]
set :puma_workers, 0
set :puma_worker_timeout, nil
set :puma_init_active_record, true
set :puma_preload_app, false


namespace :deploy do
  namespace :assets do

    Rake::Task['deploy:assets:precompile'].clear_actions

    desc 'Precompile assets locally and upload to servers'
    task :precompile do
      on roles(fetch(:assets_roles)) do
        run_locally do
          with rails_env: fetch(:rails_env) do
            execute 'bin/rake assets:precompile'
          end
        end

        within release_path do
          with rails_env: fetch(:rails_env) do
            old_manifest_path = "#{shared_path}/public/assets/manifest*"
            execute :rm, old_manifest_path if test "[ -f #{old_manifest_path} ]"
            upload!('./public/assets/', "#{shared_path}/public/", recursive: true)
          end
        end

        run_locally { execute 'rm -rf public/assets' }
      end
    end

  end
end

namespace :deploy do

  after :restart, :clear_cache do
    on roles(:web), in: :groups, limit: 3, wait: 10 do
      # Here we can do anything such as:
      # within release_path do
      #   execute :rake, 'cache:clear'
      # end
    end
  end

end

和我的config / environments / production.rb

  # 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

  # config.assets.precompile += %w( *.css *.js )

  # Add the fonts path
  config.assets.paths << "#{Rails.root}/app/assets/fonts"

  # Precompile additional assets
  config.assets.precompile += %w( .svg .eot .woff .ttf )
  config.assets.precompile += %w( *.js )
  config.assets.precompile += [ 'admin.css',
                                'bootstrap.css',
                                'dark-red-theme.css',
                                'style.css',
                                'jquery.growl.css',
                                'default-theme.css',
                                'font-awesome.css',
                                'jquery.simpleLens.css',
                                'jquery.smartmenus.bootstrap.css',
                                'nouislider.css',
                                'sequence-theme.modern-slide-in.css',
                                'slick.css',
                                'admin/app.css',
                                'admin/cart.css',
                                'admin/foundation.css',
                                'admin/normalize.css',
                                'admin/help.css',
                                'admin/ie.css',
                                'autocomplete.css',
                                'application.css',
                                'foundation.css',
                                'home_page.css',
                                'login.css',
                                'markdown.css',
                                'myaccount.css',
                                'normalize.css',
                                'pikachoose_product.css',
                                'product_page.css',
                                'products_page.css',
                                'shopping_cart_page.css',
                                'signup.css',
                                'site/app.css',
                                'sprite.css',
                                'tables.css',
                                'cupertino/jquery-ui-1.8.12.custom.css',# in vendor
                                'scaffold.css' # in vendor
                                ]

和我的application.rb有

config.assets.initialize_on_precompile = false

capistrano部署可以成功地在本地预编译资产,然后将其上传到shared / public目录,但是我看不到资产加载到我的网站上,因为一天以来一直困扰于此问题,请帮助!

这是我的浏览器日志 在此处输入图片说明

编辑

假设您的网址是404ing,并且不会像请求中包含哈希一样显示,您需要确保在布局/视图文件中使用stylesheet_link_tag加载CSS文件。 以及在CSS本身中使用各种资产助手来获取背景图像。

http://guides.rubyonrails.org/asset_pipeline.html#coding-links-to-assets

Capistrano从git部署。 如果您不想将共享资产推送到github,则可以将其配置为从本地存储库中提取,但是无论资产是否需要在源代码控制中。

 set :repo_url, 'file:///path/to/repo/.git' 

将其设置为本地存储库。

如果您完全不想在git repo中存储已编译的更改,则可以在rake assets:precompile完成后运行scp命令。

 execute 'scp -r public/assets/* user@serverip:/var/www/apps/yourapppath/shared/public/assets/*' 

当然要指出正确的地方。

我还想考虑一下,可以通过一些清单文件而不是预编译列表中的30个文件来优化资产。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM