クイックスタートガイド
このガイドでは、@aws/nx-plugin
を使用したAWSプロジェクトの迅速な構築方法について、インストールから基本的な使い方までを説明します。
始める前に以下のグローバル依存関係が必要です:
- Git
- Node >= 22(Nodeバージョン管理にはNVMの使用を推奨)
- 確認コマンド:
node --version
- 確認コマンド:
- PNPM >= 10(代替としてYarn >= 4、Bun >= 1、またはNPM >= 10も使用可能)
- 確認コマンド:
pnpm --version
、yarn --version
、bun --version
またはnpm --version
- 確認コマンド:
- UV >= 0.5.29
- Python 3.12のインストール:
uv python install 3.12.0
- 確認コマンド:
uv python list --only-installed
- Python 3.12のインストール:
- ターゲットAWSアカウント(アプリケーションのデプロイ先)に設定されたAWS Credentials
- VSCodeを使用する場合、Nx Console VSCode Pluginのインストールを推奨
ステップ1: 新しいNxワークスペースの初期化
Section titled “ステップ1: 新しいNxワークスペースの初期化”次のコマンドを実行して、任意のパッケージマネージャーでNxワークスペースを作成します:
npx create-nx-workspace@~21.0.3 my-project --pm=pnpm --preset=@aws/nx-plugin --ci=skip
npx create-nx-workspace@~21.0.3 my-project --pm=yarn --preset=@aws/nx-plugin --ci=skip
npx create-nx-workspace@~21.0.3 my-project --pm=npm --preset=@aws/nx-plugin --ci=skip
npx create-nx-workspace@~21.0.3 my-project --pm=bun --preset=@aws/nx-plugin --ci=skip
完了したら、プロジェクトディレクトリに移動します:
cd my-project
ステップ2: ジェネレータでプロジェクトをスキャフォールド
Section titled “ステップ2: ジェネレータでプロジェクトをスキャフォールド”このクイックスタートでは、tRPC API・Reactウェブサイト・Cognito認証・CDKインフラを追加します。左側のナビゲーションバーにある__Guides__から、プロジェクトタイプに応じた任意のジェネレータの組み合わせを選択できます。
tRPC APIの追加
Section titled “tRPC APIの追加”- インストール Nx Console VSCode Plugin まだインストールしていない場合
- VSCodeでNxコンソールを開く
- クリック
Generate (UI)
"Common Nx Commands"セクションで - 検索
@aws/nx-plugin - ts#trpc-api
- 必須パラメータを入力
- name: demo-api
- auth: IAM
- クリック
Generate
pnpm nx g @aws/nx-plugin:ts#trpc-api --name=demo-api --auth=IAM
yarn nx g @aws/nx-plugin:ts#trpc-api --name=demo-api --auth=IAM
npx nx g @aws/nx-plugin:ts#trpc-api --name=demo-api --auth=IAM
bunx nx g @aws/nx-plugin:ts#trpc-api --name=demo-api --auth=IAM
変更されるファイルを確認するためにドライランを実行することもできます
pnpm nx g @aws/nx-plugin:ts#trpc-api --name=demo-api --auth=IAM --dry-run
yarn nx g @aws/nx-plugin:ts#trpc-api --name=demo-api --auth=IAM --dry-run
npx nx g @aws/nx-plugin:ts#trpc-api --name=demo-api --auth=IAM --dry-run
bunx nx g @aws/nx-plugin:ts#trpc-api --name=demo-api --auth=IAM --dry-run
これによりpackages/demo-api
フォルダ内にAPIが作成されます。
Reactウェブサイトの追加
Section titled “Reactウェブサイトの追加”- インストール Nx Console VSCode Plugin まだインストールしていない場合
- VSCodeでNxコンソールを開く
- クリック
Generate (UI)
"Common Nx Commands"セクションで - 検索
@aws/nx-plugin - ts#react-website
- 必須パラメータを入力
- name: demo-website
- クリック
Generate
pnpm nx g @aws/nx-plugin:ts#react-website --name=demo-website
yarn nx g @aws/nx-plugin:ts#react-website --name=demo-website
npx nx g @aws/nx-plugin:ts#react-website --name=demo-website
bunx nx g @aws/nx-plugin:ts#react-website --name=demo-website
変更されるファイルを確認するためにドライランを実行することもできます
pnpm nx g @aws/nx-plugin:ts#react-website --name=demo-website --dry-run
yarn nx g @aws/nx-plugin:ts#react-website --name=demo-website --dry-run
npx nx g @aws/nx-plugin:ts#react-website --name=demo-website --dry-run
bunx nx g @aws/nx-plugin:ts#react-website --name=demo-website --dry-run
packages/demo-website
に新しいReactウェブサイトがスキャフォールドされます。
Cognito認証の追加
Section titled “Cognito認証の追加”- インストール Nx Console VSCode Plugin まだインストールしていない場合
- VSCodeでNxコンソールを開く
- クリック
Generate (UI)
"Common Nx Commands"セクションで - 検索
@aws/nx-plugin - ts#react-website#auth
- 必須パラメータを入力
- project: @my-project/demo-website
- cognitoDomain: my-demo
- クリック
Generate
pnpm nx g @aws/nx-plugin:ts#react-website#auth --project=@my-project/demo-website --cognitoDomain=my-demo
yarn nx g @aws/nx-plugin:ts#react-website#auth --project=@my-project/demo-website --cognitoDomain=my-demo
npx nx g @aws/nx-plugin:ts#react-website#auth --project=@my-project/demo-website --cognitoDomain=my-demo
bunx nx g @aws/nx-plugin:ts#react-website#auth --project=@my-project/demo-website --cognitoDomain=my-demo
変更されるファイルを確認するためにドライランを実行することもできます
pnpm nx g @aws/nx-plugin:ts#react-website#auth --project=@my-project/demo-website --cognitoDomain=my-demo --dry-run
yarn nx g @aws/nx-plugin:ts#react-website#auth --project=@my-project/demo-website --cognitoDomain=my-demo --dry-run
npx nx g @aws/nx-plugin:ts#react-website#auth --project=@my-project/demo-website --cognitoDomain=my-demo --dry-run
bunx nx g @aws/nx-plugin:ts#react-website#auth --project=@my-project/demo-website --cognitoDomain=my-demo --dry-run
ウェブサイトにCognito認証を追加するためのインフラとReactコードを設定します。
フロントエンドとバックエンドの接続
Section titled “フロントエンドとバックエンドの接続”- インストール Nx Console VSCode Plugin まだインストールしていない場合
- VSCodeでNxコンソールを開く
- クリック
Generate (UI)
"Common Nx Commands"セクションで - 検索
@aws/nx-plugin - api-connection
- 必須パラメータを入力
- sourceProject: @my-project/demo-website
- targetProject: @my-project/demo-api
- クリック
Generate
pnpm nx g @aws/nx-plugin:api-connection --sourceProject=@my-project/demo-website --targetProject=@my-project/demo-api
yarn nx g @aws/nx-plugin:api-connection --sourceProject=@my-project/demo-website --targetProject=@my-project/demo-api
npx nx g @aws/nx-plugin:api-connection --sourceProject=@my-project/demo-website --targetProject=@my-project/demo-api
bunx nx g @aws/nx-plugin:api-connection --sourceProject=@my-project/demo-website --targetProject=@my-project/demo-api
変更されるファイルを確認するためにドライランを実行することもできます
pnpm nx g @aws/nx-plugin:api-connection --sourceProject=@my-project/demo-website --targetProject=@my-project/demo-api --dry-run
yarn nx g @aws/nx-plugin:api-connection --sourceProject=@my-project/demo-website --targetProject=@my-project/demo-api --dry-run
npx nx g @aws/nx-plugin:api-connection --sourceProject=@my-project/demo-website --targetProject=@my-project/demo-api --dry-run
bunx nx g @aws/nx-plugin:api-connection --sourceProject=@my-project/demo-website --targetProject=@my-project/demo-api --dry-run
ウェブサイトがtRPC APIを呼び出すために必要なプロバイダ設定を行います。
CDKインフラの追加
Section titled “CDKインフラの追加”- インストール Nx Console VSCode Plugin まだインストールしていない場合
- VSCodeでNxコンソールを開く
- クリック
Generate (UI)
"Common Nx Commands"セクションで - 検索
@aws/nx-plugin - ts#infra
- 必須パラメータを入力
- name: infra
- クリック
Generate
pnpm nx g @aws/nx-plugin:ts#infra --name=infra
yarn nx g @aws/nx-plugin:ts#infra --name=infra
npx nx g @aws/nx-plugin:ts#infra --name=infra
bunx nx g @aws/nx-plugin:ts#infra --name=infra
変更されるファイルを確認するためにドライランを実行することもできます
pnpm nx g @aws/nx-plugin:ts#infra --name=infra --dry-run
yarn nx g @aws/nx-plugin:ts#infra --name=infra --dry-run
npx nx g @aws/nx-plugin:ts#infra --name=infra --dry-run
bunx nx g @aws/nx-plugin:ts#infra --name=infra --dry-run
AWSへのインフラデプロイ用CDKアプリを設定します。
ステップ3: ローカル環境でのウェブサイトとAPIの実行
Section titled “ステップ3: ローカル環境でのウェブサイトとAPIの実行”次のコマンドで、ウェブサイトと接続されたAPIのローカル開発サーバーを起動します:
pnpm nx run demo-website:serve-local
yarn nx run demo-website:serve-local
npx nx run demo-website:serve-local
bunx nx run demo-website:serve-local
ウェブサイトはhttp://localhost:4200
でアクセス可能です。
ウェブサイトとAPIへの変更は、両方のサーバーがホットリロードされるためリアルタイムで反映されます。
ステップ4: クラウドリソースの定義とAWSへのデプロイ
Section titled “ステップ4: クラウドリソースの定義とAWSへのデプロイ”packages/infra/src/stacks/application-stack.ts
を開き、次のコードを追加します:
import * as cdk from 'aws-cdk-lib';import { DemoApi, DemoWebsite, UserIdentity } from ':my-project/common-constructs';import { Construct } from 'constructs';
export class ApplicationStack extends cdk.Stack { constructor(scope: Construct, id: string, props?: cdk.StackProps) { super(scope, id, props);
const identity = new UserIdentity(this, 'identity'); const api = new DemoApi(this, 'api', { integrations: DemoApi.defaultIntegrations(this).build(), }); api.grantInvokeAccess(identity.identityPool.authenticatedRole);
new DemoWebsite(this, 'website'); }}
これがフルスタックアプリケーションをデプロイするために必要なCDKコードの全体です。
インフラのビルドとデプロイ
Section titled “インフラのビルドとデプロイ”次のコマンドでプロジェクトをビルドします:
pnpm nx run-many --target build --all
yarn nx run-many --target build --all
npx nx run-many --target build --all
bunx nx run-many --target build --all
デプロイコマンドを実行します:
pnpm nx run infra:deploy --all
yarn nx run infra:deploy --all
npx nx run infra:deploy --all
bunx nx run infra:deploy --all
ステップ5: デプロイ済みクラウドリソースとの連携テスト
Section titled “ステップ5: デプロイ済みクラウドリソースとの連携テスト”-
runtime-config.json
ファイルを取得:Terminal window pnpm nx run demo-website:load:runtime-configTerminal window yarn nx run demo-website:load:runtime-configTerminal window npx nx run demo-website:load:runtime-configTerminal window bunx nx run demo-website:load:runtime-config -
ローカルウェブサイトサーバーを起動
Terminal window pnpm nx run demo-website:serveTerminal window yarn nx run demo-website:serveTerminal window npx nx run demo-website:serveTerminal window bunx nx run demo-website:serve
ウェブサイトはhttp://localhost:4200
でアクセス可能になり、デプロイしたAPIと認証リソースと連携します。
おめでとうございます!🎉 @aws/nx-plugin
を使ったフルスタックアプリケーションの構築とデプロイに成功しました!