5
6

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 3 years have passed since last update.

Docker上でVueを動かすときに環境変数が読まれない

Posted at

なにが起きましたか

  • 環境
    • Docker上
    • @vue/cli
    • npm run build でビルド
    • http-server dist/ で配信

Vueのフロントエンドを作っている際,サーバサイドのAPIのエンドポイントを環境変数に格納して動かす方式を取っていた.
ローカルのビルドではちゃんと環境変数が読まれるが,Azure上にイメージをpushしたビルドでは環境変数が読まれないという状況

原因

原因は主に2つあった.

これは既にそのとおりにしており,VUE_APP_API_ENDPOINTにサーバ側URLを設定していた.しかし,それでも環境変数は読まれない.

  • Dockerfileで環境変数を設定していたが,ビルド後に環境変数を設定していた.

つまりこんな感じに書いていた

Dockerfile.production
FROM node:lts-alpine 

RUN npm install -g http-server && \
    npm install && \
    npm run build
EXPOSE 8000

ENV VUE_APP_API_ENDPOINT='https://hogehoge.net'
CMD [ "http-server", "dist", "-p", "8000", "-g", "-b" ]

なんとなく「環境変数はランタイムで読み込まれるもの」という思い込みが原因であった.加えて,ローカルでは npm run serve で動作していたため,これは実際にランタイムで(コマンドを叩いたタイミング)で環境変数が読み込まれており,何も問題がなかったこともある.
ちゃんとビルドコマンド前にENV ~~~を移動させると,環境変数を参照することができた.

結論

  • クライアントサイドかつDockerでの開発のときは,ENVをビルドコマンドの前に書こう!
    • 実行時に必要ないし,RUNのときに直接指定してもいいかもしれない.そのほうが意味的には良い
  • 思い込み怖いね
5
6
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
5
6

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?