2
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

【Vue.js】エラー「failed to load config from /app/vite.config.ts」が出た場合の対処法(@esbuild/darwin-arm64とは?)

Posted at

概要

  • Vue.jsのdockerコンテナを起動したところ、failed to load config from /app/vite.config.ts...というエラーが表示されてしまいました。本記事では、その解決方法を記載します。

前提

  • Apple M1 Pro
  • node:v18.16.0
  • npm:9.5.1
  • dockerコンテナでVue.jsのアプリ起動

Vue.jsとは

Vue.jsは、MVCモデルから派生したMVVMモデルを採用したフレームワークで「Model」「View」「ViewModel」の3つの機能で設計されています。

Modelはデータの管理や保存、外部との入出力や内部的な操作などのロジックに関わる処理を担い、Viewはユーザーの入力や操作を受け付けて、画面表示などのUIに関わる処理を担うものです。そして、ModelとViewの状態を監視しているのがViewModelで、状態に変化があれば必要に応じてそれぞれに通知します。また、このようなロジックとUIを分離して状態を監視しながら処理がおこなえるのは、仮想DOMによるものです。

node_modulespackage.json

  • node_modules:Node.jsプロジェクトで使用されるパッケージの依存関係が格納されるディレクトリ
    • ルートディレクトリ内に自動的に作成され、パッケージマネージャ(npmやYarnなど)によって管理されることが多い
  • package.json:プロジェクトのメタデータや依存関係の管理に使用されるファイル。パッケージマネージャはこれらの依存関係を解決し、関連するパッケージやライブラリをnode_modulesディレクトリにダウンロード・インストールする。
  • つまりpackage.jsonが依存関係を定義するファイル、node_modulesが依存関係のコードが格納される場所、ということですね

エラー全文

  • dockerがうまく起動せず、起動しては落ちる、を繰り返していました。
  • docker logsに記載のあるエラーログは以下です。
> app@0.0.0 dev
> vite

failed to load config from /app/vite.config.ts
error when starting dev server:
Error: 
You installed esbuild for another platform than the one you're currently using.
This won't work because esbuild is written with native code and needs to
install a platform-specific binary executable.

Specifically the "@esbuild/darwin-arm64" package is present but this platform
needs the "@esbuild/linux-arm64" package instead. People often get into this
situation by installing esbuild on Windows or macOS and copying "node_modules"
into a Docker image that runs Linux, or by copying "node_modules" between
Windows and WSL environments.

If you are installing with npm, you can try not copying the "node_modules"
directory when you copy the files over, and running "npm ci" or "npm install"
on the destination platform after the copy. Or you could consider using yarn
instead of npm which has built-in support for installing a package on multiple
platforms simultaneously.

If you are installing with yarn, you can try listing both this platform and the
other platform in your ".yarnrc.yml" file using the "supportedArchitectures"
feature: https://yarnpkg.com/configuration/yarnrc/#supportedArchitectures
Keep in mind that this means multiple copies of esbuild will be present.

Another alternative is to use the "esbuild-wasm" package instead, which works
the same way on all platforms. But it comes with a heavy performance cost and
can sometimes be 10x slower than the "esbuild" package, so you may also not
want to do that.

    at generateBinPath (/app/node_modules/esbuild/lib/main.js:1874:17)
    at esbuildCommandAndArgs (/app/node_modules/esbuild/lib/main.js:1955:33)
    at ensureServiceIsRunning (/app/node_modules/esbuild/lib/main.js:2119:25)
    at build (/app/node_modules/esbuild/lib/main.js:2011:26)
    at bundleConfigFile (file:///app/node_modules/vite/dist/node/chunks/dep-e8f070e8.js:64411:26)
    at loadConfigFromFile (file:///app/node_modules/vite/dist/node/chunks/dep-e8f070e8.js:64387:31)
    at resolveConfig (file:///app/node_modules/vite/dist/node/chunks/dep-e8f070e8.js:63993:34)
    at _createServer (file:///app/node_modules/vite/dist/node/chunks/dep-e8f070e8.js:63274:26)
    at createServer (file:///app/node_modules/vite/dist/node/chunks/dep-e8f070e8.js:63271:12)
    at CAC.<anonymous> (file:///app/node_modules/vite/dist/node/cli.js:733:30)

原因:node_modules内のファイルが上書きされていた

  • エラーの内容は「esbuildパッケージが異なるプラットフォーム向けにインストールされていることが原因でアプリが起動しない」ことを言っているようです。arm64あたりのエラーは以前も別件で見たことがあったのですが、M1チップが原因だったような...また面倒な環境問題かな?と思っていたのですが、あっさり解決しました。
  • 原因は、docker-compose.yamlにありました。

エラー発生時

docker-compose.yaml
    volumes:
      - ./frontend/app:/app
      - /frontend/app/node_modules
  • 何が原因だったかというと、node_modulesディレクトリが含まれた./frontend/appディレクトリ全体をコンテナにマウントしていたからです。これにより、ディレクトリ内のネイティブバイナリファイルが上書きされてしまい、esbuildパッケージの正しいバイナリが使用できなかったと考えられます。

esbuildとは?

  • 高速なJavaScriptおよびTypeScriptのバンドルおよびトランスパイルツール
  • 実行には以下のようなプラットフォーム固有のバイナリファイルが必要
    • @esbuild/darwin-arm64: macOSのM1チップ搭載のコンピュータ向けのバイナリパッケージ
    • @esbuild/linux-arm64: LinuxのARM64アーキテクチャ向けのバイナリパッケージ
  • 正しいバイナリをインストールすることで、esbuildは正常に動作します

viteとは?

  • Vite | 次世代フロントエンドツール
  • 高速なウェブ開発用のビルドツール(フランス語で「速い」という意味らしい)
  • ES modulesと呼ばれるモジュール分割の仕組みを使い、モジュール間の依存関係解決が高速に行う→コードを素早くブラウザに配信できる。
  • vite.config.ts: Viteの設定ファイル。開発サーバーやビルドプロセスの設定、プラグインの追加などをカスタマイズできる。設定例は以下の公式ドキュメントにあります。

解決方法

  • 以下で解決しました。
docker-compose.yaml
    volumes:
      - ./frontend/app/src:/app/src
      - /frontend/app/node_modules
  • ./frontend/app/srcディレクトリのみを/app/srcにマウントし、/frontend/app/node_modulesはマウントされないようにしました。これにより、esbuildパッケージのバイナリファイルは正しい状態で保たれ、アプリが正常に起動できるようになりました。
  • ネイティブバイナリファイルが特定のプラットフォームに依存している、というのポイントだったんですね(docker-compose.yamlの書き方もあるけど)。
  • 今回のエラーは、正しいバイナリが使用できなかったために発生するエラーだと思われますので、同様の事象の方はぜひ確認ください。
2
1
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
2
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?