简体   繁体   English

如何缩小Rails应用程序中的Java脚本文件?

[英]How to minify java script files in a rails application?

I am trying to reduce the load time of my rails application on the production server. 我试图减少我的Rails应用程序在生产服务器上的加载时间。 For now, my concern is only to reduce the assets loading time and not changing the business logic. 目前,我只关心减少资产加载时间,而不更改业务逻辑。 An online tester identified I have 2.25 MB of JS files which include third party jquery plugins. 一位在线测试人员确定我有2.25 MB的JS文件,其中包括第三方jquery插件。 And currently, all my assets are rendering from app/assets path. 目前,我所有的资产都是从应用程序/资产路径渲染的。 The console loads files like this on the index page: 控制台在索引页面上加载如下文件:

Started GET "/assets/jquery-ui.self Like this, there are a number of js files. Started GET "/assets/jquery-ui.self像这样,有很多js文件。

In my production.rb file I have set 在我的production.rb文件中,我设置了

config.serve_static_files = true config.serve_static_files = true
config.assets.js_compressor = :uglifier config.assets.js_compressor =:uglifier

In my nginx.conf I am serving assets as follows 在我的nginx.conf中,我按以下方式提供资产

location ^~ /(assets|fonts|swfs|images)/ {
    gzip_static on;
    expires max;
    add_header Cache-Control public;
  }

production.rb production.rb

Rails.application.configure do
  # Settings specified here will take precedence over those in config/application.rb.
  # Code is not reloaded between requests.
  Rails.application.config.assets.precompile += %w( *.js ^[^_]*.css *.css.erb )

  config.cache_classes = true

  # Eager load code on boot. This eager loads most of Rails and
  # your application in memory, allowing both threaded web servers
  # and those relying on copy on write to perform better.
  # Rake tasks automatically ignore this option for performance.
  config.eager_load = true

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

  # Enable Rack::Cache to put a simple HTTP cache in front of your application
  # Add `rack-cache` to your Gemfile before enabling this.
  # For large-scale production use, consider using a caching reverse proxy like
  # NGINX, varnish or squid.
  # config.action_dispatch.rack_cache = true

  # Disable serving static files from the `/public` folder by default since
  # Apache or NGINX already handles this.
  #config.serve_static_assets = ENV['RAILS_SERVE_STATIC_FILES'].present?

  config.serve_static_assets = true

  # Compress JavaScripts and CSS.
  config.assets.js_compressor = :uglifier
  # config.assets.css_compressor = :sass

  # Do not fallback to assets pipeline if a precompiled asset is missed.
  config.assets.compile = true
  #config.assets.precompile =  ['*.js', '*.css', '*.css.erb'] 

  # Asset digests allow you to set far-future HTTP expiration dates on all assets,
  # yet still be able to expire them through the digest params.
  config.assets.digest = true

  # `config.assets.precompile` and `config.assets.version` have moved to config/initializers/assets.rb

  # 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 = false

  # Use the lowest log level to ensure availability of diagnostic information
  # when problems arise.
  config.log_level = :debug

  config.action_mailer.default_url_options = { host: ENV["SMTP_HOST"] }
  config.action_mailer.asset_host = ENV["SMTP_HOST"]
  # config.action_mailer.delivery_method = :letter_opener
  config.action_mailer.raise_delivery_errors = false

  config.action_mailer.delivery_method = :smtp
  config.action_mailer.smtp_settings = {
    #Enter the smtp provider here ex: smtp.mandrillapp.com
    address: ENV["SMTP_ADDRESS"],
    port: ENV['SMTP_PORT'].to_i,
    #Enter the smtp domain here ex: vendaxo.com
    domain: ENV["SMTP_DOMAIN"],
    #Enter the user name for smtp provider here
    user_name: ENV["SMTP_USERNAME"],
    #Enter the password for smtp provider here
    password: ENV["SMTP_PASSWORD"],
    authentication: 'plain',
    enable_starttls_auto: true
  }

  # 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'

  # Ignore bad email addresses and do not raise email delivery errors.
  # Set this to true and configure the email server for immediate delivery to raise delivery errors.

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

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

  # Use default logging formatter so that PID and timestamp are not suppressed.
  config.log_formatter = ::Logger::Formatter.new

  # Do not dump schema after migrations.
  config.active_record.dump_schema_after_migration = false
end

Capistrano deploy.rb posting assets lines only as requested. Capistrano deploy.rb仅根据请求帐资产行。

append :linked_dirs, "log", "tmp/pids", "tmp/cache", "tmp/sockets", "vendor/bundle", "public/system", "public/uploads", "public/assets"
namespace :deploy do
  after  :finishing,    :compile_assets
end

What should I do in order to reduce this assets load time? 为了减少这些资产加载时间,我该怎么办? Let me know if any further information needed. 让我知道是否需要进一步的信息。

In production.rb 在production.rb中

config.assets.compile = true

RAILS_ENV=production rake assets:precompile RAILS_ENV =生产佣金资产:预编译

and push all compressed js/css files. 并推送所有压缩的js / css文件。 It will save your load time and compress all js/css/images. 它将节省您的加载时间并压缩所有js / css / images。

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

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