ホームページ > ウェブフロントエンド > jsチュートリアル > React と Docker を使用してフロントエンド アプリケーションをパッケージ化してデプロイする方法

React と Docker を使用してフロントエンド アプリケーションをパッケージ化してデプロイする方法

王林
リリース: 2023-09-26 15:14:08
オリジナル
1569 人が閲覧しました

React と Docker を使用してフロントエンド アプリケーションをパッケージ化してデプロイする方法

React と Docker を使用してフロントエンド アプリケーションをパッケージ化およびデプロイする方法

フロントエンド アプリケーションのパッケージ化とデプロイは、プロジェクト開発の非常に重要な部分です。最新のフロントエンド フレームワークの急速な発展により、React は多くのフロントエンド開発者にとって最初の選択肢となっています。コンテナ化ソリューションとして、Docker はアプリケーションのデプロイメントプロセスを大幅に簡素化できます。この記事では、React と Docker を使用してフロントエンド アプリケーションをパッケージ化してデプロイする方法を紹介し、具体的なコード例を示します。

1. 準備
始める前に、必要なソフトウェアとツールをインストールする必要があります:

  1. Node.js: React プロジェクトのインストールと管理に使用されます。
  2. Docker: アプリケーション コンテナーの構築と実行に使用されます。

2. React アプリケーションの作成
まず、Create React App スキャフォールディング ツールを使用して、新しい React アプリケーションを作成する必要があります。ターミナルを開いて次のコマンドを実行します:

npx create-react-app my-app
cd my-app
ログイン後にコピー

これにより、my-app という名前の新しい React アプリが作成され、そのディレクトリに入ります。

3. Dockerfile の書き込み
プロジェクトのルート ディレクトリに Dockerfile という名前のファイルを作成し、テキスト エディターで開きます。

Dockerfile は、Docker にイメージの構築方法を指示する一連の命令が含まれるテキスト ファイルです。次のコンテンツを追加します。

# 使用官方的Node.js 12基础镜像作为构建环境
FROM node:12 as build-env
# 设置工作目录
WORKDIR /app
# 将项目的依赖文件复制到工作目录
COPY package.json ./
# 安装项目依赖
RUN npm install
# 将项目文件复制到工作目录
COPY . ./
# 执行React项目的构建
RUN npm run build

# 使用Nginx作为基础镜像来提供Web服务
FROM nginx:alpine
# 复制构建产物到Nginx的默认Web根目录
COPY --from=build-env /app/build /usr/share/nginx/html
# 使用80端口运行Nginx
EXPOSE 80
# 启动Nginx服务
CMD ["nginx", "-g", "daemon off;"]
ログイン後にコピー

上記の Dockerfile の最初の部分では、Node.js ベース イメージをビルド環境として使用し、プロジェクトの依存関係をインストールし、React プロジェクトのビルドを実行します。 2 番目の部分では、Nginx ベース イメージを使用して Web サービスを提供し、ビルド製品を Nginx のデフォルト Web ルート ディレクトリにコピーします。

4. Docker イメージを構築する
ターミナルで次のコマンドを使用して、プロジェクトのルート ディレクトリに Docker イメージを構築します:

docker build -t my-app .
ログイン後にコピー

これにより、 という名前のファイルが構築されます。 my- app の Dockerfile Docker イメージに基づいています。ビルドが完了したら、docker image コマンドを使用して、ビルドされたイメージを表示できます。

5. Docker コンテナを実行します
ターミナルで、次のコマンドを使用して Docker コンテナを実行します:

docker run -d -p 8080:80 my-app
ログイン後にコピー

これにより、コンテナ内のポート 80 で Nginx サービスが開始され、変更されます。コンテナの 80 ポートはホストのポート 8080 にマッピングされます。

これで、ブラウザを開いて http://localhost:8080 にアクセスし、デプロイされた React アプリケーションを表示できます。

6. 概要
この記事では、React と Docker を使用してフロントエンド アプリケーションをパッケージ化してデプロイする方法を紹介します。 Create React App スキャフォールディング ツールを使用して React アプリケーションを作成し、Dockerfile を作成して Docker イメージを構築し、Docker を使用してコンテナを実行してサービスを提供することで、フロントエンド アプリケーションを簡単にパッケージ化し、サポートする環境にデプロイできます。ドッカー。この記事がお役に立てば幸いです。

以上がReact と Docker を使用してフロントエンド アプリケーションをパッケージ化してデプロイする方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート