如何在Elastic Beanstalk容器中提供Rails应用程序的webpacked资产?

时间:2018-03-04 13:43:50

标签: ruby-on-rails webpack ruby-on-rails-5 elastic-beanstalk

我正在使用Rails5应用程序并成功将其部署到EB容器中。

但是直接在public/packs中提供的webpacked资产在生产环境中返回404。

在目前的情况下,我设置RAILS_SKIP_ASSET_COMPILATION = false所以我在每次部署应用程序之前预先编译资产。

我过去常常使用heroku作为生产环境,当时一切正常。

这是我的config/webpacker.yml

source_path: app/frontend/javascripts
  source_entry_path: packs
  public_output_path: packs # public/packs/filename-[hash].js
  cache_path: tmp/cache/webpacker

  # Additional paths webpack should lookup modules
  # ['app/assets', 'engine/foo/app/assets']
  resolved_paths: []

  # Reload manifest.json on all requests so we reload latest compiled packs
  cache_manifest: false

  extensions:
    - .js
    - .sass
    - .scss
    - .css
    - .png
    - .svg
    - .gif
    - .jpeg
    - .jpg

我试过的......

我尝试将public_output_path从包更改为资产。但同样的错误仍然存​​在......

1 个答案:

答案 0 :(得分:1)

我也遇到了这个问题。我不确定您是使用Nginx还是Passenger。但是,如果是Nginx,则可能要向/etc/nginx/conf.d/webapp_healthd.conf添加一个位置块,如下所示:

location /packs {
  alias /var/app/current/public/packs;
  gzip_static on;
  gzip on;
  expires max;
  add_header Cache-Control public;
}

然后运行sudo /etc/init.d/nginx restart

应该足以使其正常工作。但是,您需要使用这些自定义设置在项目中创建一个.ebextensions/文件,以免被Elastic Beanstalk默认配置覆盖。

请参见Maria Luisa Carrion D.的this post,以了解如何自动执行nginx配置。