1. 環境構築
Next.jsのセットアップ
Nxの公式ドキュメントを参考に環境構築をします。
Next.jsで新しいNxワークスペースを作成するには下記コマンドを実行します。
npx create-nx-workspace@latest --preset=next
data:image/s3,"s3://crabby-images/a1db8/a1db8142d1f0d05379ec7ca115defff74cb2e56b" alt=""
workspaceはデフォルトの「org」アプリケーションの名前は「pro01」としました。
インストールが終わると、org > apps の中に先ほど作ったアプリケーション(pro01)が入っています。
data:image/s3,"s3://crabby-images/4a257/4a257e33df8a59caeb3f5af5b3a4a16bdd6bcde5" alt=""
アプリケーションの追加
下記コマンドで新しいアプリケーションを追加します。
nx g @nx/next:app アプリケーションの名前
例)nx g @nx/next:app pro02
data:image/s3,"s3://crabby-images/73ed1/73ed1cde10e32f4b2c43c6e8ed9323d922f025a4" alt=""
問題なくアプリケーションが追加されました。
必要のない「pro01-e2e」と「pro02-e2e」は削除しておきます。
2. githubへアップロード
githubでレポジトリを準備し、先ほど作ったワークスペースをアップロードします。
git init
git add .
git commit -m "first commit"
git branch -M main
git remote add origin https://github.com/********/YOUR-REPOSITORY-NAME.git
git push -u origin main
3. AWS Amplify設定
AWSの管理画面からAmplifyを開きます。
Amplifyホスティングの「使用を開始する」をクリックします。
data:image/s3,"s3://crabby-images/580f5/580f55293c4543bfcb7418e90a0a47fea1d0e1f9" alt=""
既存のコードからgithubを選択します。
data:image/s3,"s3://crabby-images/36402/36402a056c4a2c82a432f654000c4e4d71102d4a" alt=""
githubの認証画面に飛ぶので認証し、該当のレポジトリを選択します。
ブランチを選択したら、「monorepoを接続しますか?フォルダを選択してください」にチェックをいれ、ルートからのアプリケーションまでのパスを書きます。
data:image/s3,"s3://crabby-images/e3b1a/e3b1aa87075318d1967bd308b8e6eb018876a77e" alt=""
次にビルドの設定をします。
ここは自動でビルド設定が検出されるので、問題ない場合はそのまま受け入れます。
version: 1
applications:
- frontend:
phases:
preBuild:
commands:
- npm ci
build:
commands:
- npx nx build pro01
artifacts:
baseDirectory: dist/apps/pro01/.next
files:
- '**/*'
cache:
paths:
- node_modules/**/*
buildPath: /
appRoot: apps/pro01
「次へ」を押すと確認画面が出てくるので、問題ないようなら「保存してデプロイ」をします。
data:image/s3,"s3://crabby-images/6edf5/6edf5f3c195939c840674a101746893afbb921fd" alt=""
デプロイが開始され、問題なくデプロイされました。
data:image/s3,"s3://crabby-images/12c33/12c333af3a6b0af269632793fcd9f72bc630053f" alt=""
もう一つのアプリケーション(pro02)も同じように設定してください。