web-dev-qa-db-ja.com

Webpacker 4.2が/app/public/packs/manifest.json herokuでアプリケーションを見つけられない

私は少し困惑しています。私のローカルRailsアプリはwebpacker 4.2でうまく動作して反応しますが、本番環境にデプロイすると素晴らしいcan't find application in /app/public/packs/manifest.jsonエラー。

これが私が試したものです:

  • JavaScriptパックタグのターボリンクの詳細を追加/削除しようとしました。
  • 削除されたjavascript includeタグ(これが役立つかどうかは不明)
  • 最新のWebpackerを使用していることを確認してください4.2
  • rakeアセット:クリーン&&レイクアセット:herokuで手動でプリコンパイルを実行して、ビルドが確実に行われるようにしました。

これを引き起こしている本番環境でビルドステップまたは何かが欠けていますか?確認することは何ですか?

サーバーエラー:

2019-12-03T15:18:19.022024+00:00 app[web.1]: I, [2019-12-03T15:18:19.021952 #30]  INFO -- : [aa0374eb-bab1-40cc-b40b-6ae3d195e07d] Completed 500 Internal Server Error in 112ms (ActiveRecord: 30.4ms | Allocations: 21296)
2019-12-03T15:18:19.023103+00:00 app[web.1]: F, [2019-12-03T15:18:19.023029 #30] FATAL -- : [aa0374eb-bab1-40cc-b40b-6ae3d195e07d]
2019-12-03T15:18:19.023107+00:00 app[web.1]: [aa0374eb-bab1-40cc-b40b-6ae3d195e07d] ActionView::Template::Error (Webpacker can't find application in /app/public/packs/manifest.json. Possible causes:
2019-12-03T15:18:19.023109+00:00 app[web.1]: 1. You want to set webpacker.yml value of compile to true for your environment
2019-12-03T15:18:19.023111+00:00 app[web.1]: unless you are using the `webpack -w` or the webpack-dev-server.
2019-12-03T15:18:19.023114+00:00 app[web.1]: 2. webpack has not yet re-run to reflect updates.
2019-12-03T15:18:19.023116+00:00 app[web.1]: 3. You have misconfigured Webpacker's config/webpacker.yml file.
2019-12-03T15:18:19.023118+00:00 app[web.1]: 4. Your webpack configuration is not creating a manifest.
2019-12-03T15:18:19.023120+00:00 app[web.1]: Your manifest contains:

{
 "application.js": "/packs/js/application-2a0e2c932678ebbf2ae7.js",
"application.js.map": "/packs/js/application-2a0e2c932678ebbf2ae7.js.map",
"entrypoints": {
 "application": {
"js": [
"/packs/js/application-2a0e2c932678ebbf2ae7.js"
],
 "js.map": [
 "/packs/js/application-2a0e2c932678ebbf2ae7.js.map"
 ]
 },
 "server_rendering": {
 "js": [
 "/packs/js/server_rendering-eb794d024d4852e8ab55.js"
],
 "js.map": [
 "/packs/js/server_rendering-eb794d024d4852e8ab55.js.map"
 ]
}
 },
"server_rendering.js": "/packs/js/server_rendering-eb794d024d4852e8ab55.js",
"server_rendering.js.map": "/packs/js/server_rendering-eb794d024d4852e8ab55.js.map"
}

...

<%= stylesheet_link_tag    'application', media: 'all', 'data-turbolinks-track': 'reload' %>
<%= stylesheet_pack_tag 'application', media: 'all', 'data-turbolinks-track': 'reload' %>
<%= javascript_pack_tag 'application' %>

<link href="https://fonts.googleapis.com/css?family=Open+Sans|Roboto+Slab:700&display=swap" rel="stylesheet">

2019-12-03T15:18:19.023193+00:00 app[web.1]: [aa0374eb-bab1-40cc-b40b-6ae3d195e07d] app/views/layouts/application.html.erb:10

Webpacker.yml

    # Note: You must restart bin/webpack-dev-server for changes to take effect

    default: &default
      source_path: app/javascript
      source_entry_path: packs
      public_root_path: public
      public_output_path: packs
      cache_path: tmp/cache/webpacker
      check_yarn_integrity: false
      webpack_compile_output: false

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

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

      # Extract and emit a css file
      extract_css: false

      static_assets_extensions:
        - .jpg
        - .jpeg
        - .png
        - .gif
        - .tiff
        - .ico
        - .svg
        - .eot
        - .otf
        - .ttf
        - .woff
        - .woff2

      extensions:
        - .jsx
        - .vue
        - .mjs
        - .js
        - .sass
        - .scss
        - .css
        - .module.sass
        - .module.scss
        - .module.css
        - .png
        - .svg
        - .gif
        - .jpeg
        - .jpg

    development:
      <<: *default
      compile: true

      # Verifies that correct packages and versions are installed by inspecting package.json, yarn.lock, and node_modules
      check_yarn_integrity: true

      # Reference: https://webpack.js.org/configuration/dev-server/
      dev_server:
        https: false
        Host: localhost
        port: 3035
        public: localhost:3035
        hmr: false
        # Inline should be set to true if using HMR
        inline: true
        overlay: true
        compress: true
        disable_Host_check: true
        use_local_ip: false
        quiet: false
        headers:
          'Access-Control-Allow-Origin': '*'
        watch_options:
          ignored: '**/node_modules/**'

    test:
      <<: *default
      compile: true

      # Compile test packs to a separate directory
      public_output_path: packs-test

    production:
      <<: *default

      # Production depends on precompilation of packs prior to booting for performance.
      compile: true

      # Extract and emit a css file
      extract_css: true

      # Cache manifest.json for performance
      cache_manifest: true

2
Justin

application.cssmanifest.jsonがないようです。つまり、Webpack javascriptファイル内からcssをインポートしていない可能性があります。

それがすべて当てはまる場合は、次のいずれかの方法で本番環境のエラーを修正できます。

  • クイック(一時)修正:extract_css: falseconfig/webpacker.ymlproductionブロックに追加します(ローカル環境を模倣します)
  • Webpackerでcssをコンパイルしたくない場合:アプリケーションレイアウトから<%= stylesheet_pack_tag 'application' %>を削除します
  • Webpackerで一部のcssをコンパイルする場合:Webpack javascriptから少なくとも1つのcssファイルをインポートします
5
rossta

Rails 6+ with webpackerを使用している場合、最新のRails 6更新により、javascriptファイルとcssファイルの両方がapp/javascriptの下に移動されます/ app/assets

app/javascript:
  ├── packs:
  │   # only webpack entry files here
  │   └── application.js
  └── src:
  │   └── application.css
  └── images:
      └── logo.svg

ただし、古いバージョンから新しいバージョンにアップグレードしたにもかかわらず、CSSをapp/assets/stylesheetsフォルダからコンパイルしたい場合は、以下の調整に従ってください。

  1. 解決されたパスにconfig/webpacker.ymlが含まれるように、webpackのapp/assetsで以下を更新します。
// config/webpacker.yml

resolved_paths: ['app/assets']
  1. 下の行をapp/javascript/packs/application.jsにコピーします。
// app/javascript/packs/application.js

import 'stylesheets/application'

bin/webpack-dev-serverを実行すると、CSSコンパイルの問題が修正されます。

1
Anto Dominic