Building and Managing Nx Workspaces: Claude Code 활용 가이드
building and managing nx workspaces: Claude Code 활용. 실용적인 코드 예시를 포함합니다.
Nxワークスペースの구축をClaude Code로 효율화하기
NxはNrwlが개발するモノレポ관리ツールで、豊富な플러그인エコシステムと高度な빌드グラフ解析が特徴です。Claude Code와組み合わせることで、Nxの多機能さを最大限に活かせます。
ワークスペースの初期セットアップ
> Nxワークスペースを新規생성して。
> 구성:
> - apps/frontend: React + Vite
> - apps/backend: NestJS API
> - libs/shared-types: 共通타입定義
> - libs/ui-components: 共通UI컴포넌트
# Nxワークスペースの作成
npx create-nx-workspace@latest my-workspace \
--preset=integrated \
--nxCloud=skip
# プラグインの追加
nx add @nx/react
nx add @nx/nest
프로젝트の추가とジェネレーター활용
Nxのジェネレーターを使えば、一貫した구성で프로젝트を추가할 수 있습니다。
> React애플리케이션를 추가해줘。Vitestで테스트も설정して。
# Reactアプリの生成
nx g @nx/react:app frontend \
--bundler=vite \
--unitTestRunner=vitest \
--e2eTestRunner=playwright \
--style=css
# ライブラリの生成
nx g @nx/react:lib ui-components \
--unitTestRunner=vitest \
--publishable \
--importPath=@my-workspace/ui-components
project.jsonの설정
> frontend앱の빌드설정を최적화して。
> 환경 변수の전환とソースマップの설정も추가して。
{
"name": "frontend",
"targets": {
"build": {
"executor": "@nx/vite:build",
"options": {
"outputPath": "dist/apps/frontend",
"generatePackageJson": false
},
"configurations": {
"production": {
"mode": "production",
"sourcemap": false
},
"development": {
"mode": "development",
"sourcemap": true
}
}
},
"serve": {
"executor": "@nx/vite:dev-server",
"defaultConfiguration": "development"
}
}
}
影響範囲の分析と선택的実行
Nxの強力な依存グラフ解析を활용します。
> 변경の影響を受ける프로젝트だけ테스트を実行する
> CI파이프라인を作って。
# 影響を受けるプロジェクトの確認
nx affected --target=test --base=main
# 依存グラフの可視化
nx graph
# 並列実行数の指定
nx affected --target=build --parallel=5
# .github/workflows/ci.yml
name: CI
on: [pull_request]
jobs:
affected:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
with:
fetch-depth: 0
- uses: nrwl/nx-set-shas@v4
- run: npm ci
- run: npx nx affected -t lint test build --parallel=3
カスタムジェネレーターの생성
프로젝트固有の보일러플레이트をジェネレーター化할 수 있습니다。
> API엔드포인트を추가するカスタムジェネレーターを作って。
> コントローラ、サービス、DTOの파일を自動생성したい。
// tools/generators/api-endpoint/index.ts
import { Tree, generateFiles, joinPathFragments, names } from '@nx/devkit';
interface Schema {
name: string;
project: string;
}
export default async function (tree: Tree, schema: Schema) {
const { className, fileName } = names(schema.name);
const projectRoot = `apps/${schema.project}/src`;
generateFiles(
tree,
joinPathFragments(__dirname, 'files'),
joinPathFragments(projectRoot, fileName),
{ className, fileName, template: '' }
);
}
정리
Claude Codeを활용すれば、Nxの豊富な機能を빠르게理解し、効率的なモノレポ環境を구축할 수 있습니다。モノレポ관리の基本やTypeScript개발のコツ도 참고하세요.
Nx의 상세 정보는Nx공식 문서를 참고하세요.
Claude Code 워크플로우를 한 단계 업그레이드하세요
지금 바로 Claude Code에 복사해 쓸 수 있는 검증된 프롬프트 템플릿 50선.
이 글을 작성한 사람
Masa
Claude Code를 적극 활용하는 엔지니어. 10개 언어, 2,000페이지 이상의 테크 미디어 claudecode-lab.com을 운영 중.
관련 글
Claude Code로 리팩토링을 자동화하는 방법
Claude Code를 활용해 코드 리팩토링을 효율적으로 자동화하는 방법을 알아봅니다. 실전 프롬프트와 구체적인 리팩토링 패턴을 소개합니다.
Claude Code로 사이드 프로젝트 개발 속도를 극대화하는 방법 [예제 포함]
Claude Code를 활용해 개인 프로젝트 개발 속도를 획기적으로 높이는 방법을 알아봅니다. 실전 예제와 아이디어부터 배포까지의 워크플로를 포함합니다.
Complete CORS Configuration Guide: Claude Code 활용 가이드
complete cors configuration guide: Claude Code 활용. 실용적인 팁과 코드 예시를 포함합니다.