티스토리 뷰
반응형
🚀 포트폴리오 프로젝트 시작하기: 환경 설정 및 초기 구성
개발을 시작하기 전, 프로젝트의 환경을 설정하는 과정은 매우 중요합니다.
포트폴리오 프로젝트를 Next.js(프론트엔드)와 NestJS(백엔드)로 구성하기 위해 초기 설정 및 기본 구조를 구축해 보겠습니다.
✅ 1. 프로젝트 개요
🔹 프로젝트 목표
- 개인 포트폴리오 웹사이트를 제작하여 경험과 프로젝트를 효과적으로 소개
- Next.js와 NestJS를 활용하여 풀스택 환경 구성
- PostgreSQL과 Prisma ORM을 사용하여 데이터 관리
- CI/CD를 적용하여 배포 및 유지보수 효율성 극대화
✅ 2. 개발 환경 구성
🔹 프론트엔드 환경 설정 (Next.js)
- Next.js 프로젝트 생성
- npx create-next-app@latest portfolio cd portfolio
- TypeScript 설정 추가
- touch tsconfig.json
- ESLint & Prettier 설정
- npm install --save-dev eslint prettier eslint-config-prettier eslint-plugin-prettier
- Tailwind CSS 설치 및 설정
- npm install -D tailwindcss postcss autoprefixer npx tailwindcss init -p
🔹 백엔드 환경 설정 (NestJS)
- NestJS 프로젝트 생성
- npx @nestjs/cli new backend cd backend
- TypeScript 및 ESLint 설정 추가
- npm install --save-dev eslint @typescript-eslint/parser @typescript-eslint/eslint-plugin
- PostgreSQL과 Prisma ORM 설정
- npm install @nestjs/config @nestjs/typeorm pg typeorm
- .env 파일 생성 및 환경 변수 추가
- DATABASE_URL="postgresql://user:password@localhost:5432/portfolio" SHADOW_DATABASE_URL="postgresql://user:password@localhost:5433/portfolio_shadow"
✅ 3. 데이터베이스 구성 (PostgreSQL + Prisma)
Prisma ORM을 사용하여 PostgreSQL 데이터베이스를 설정하고, SHADOW_DATABASE_URL을 활용하여 마이그레이션을 안전하게 수행합니다.
🔹 1. Prisma 설치 및 초기화
npm install @prisma/client
npx prisma init
🔹 2. prisma/schema.prisma 파일 수정
datasource db {
provider = "postgresql"
url = env("DATABASE_URL")
shadowDatabaseUrl = env("SHADOW_DATABASE_URL")
}
generator client {
provider = "prisma-client-js"
}
🔹 3. 데이터베이스 마이그레이션 실행
반응형
- 마이그레이션을 위한 데이터베이스 생성
- createdb -U user portfolio createdb -U user portfolio_shadow
- Prisma 마이그레이션 실행
- npx prisma migrate dev --name init
- Prisma 클라이언트 생성
- npx prisma generate
✅ 4. GitHub & CI/CD 설정
- GitHub 저장소 생성 및 초기화
- git init git remote add origin <repository-url>
- GitHub Actions를 활용한 CI/CD 구성 (Vercel & Railway)
- vercel.json 설정
- railway.json 설정
✅ 다음 단계
- 홈 페이지 (Home) 레이아웃 구현
- 기본적인 API 엔드포인트 설정
- 프로젝트 페이지 (Projects) UI 개발
'project > 포트폴리오만들기' 카테고리의 다른 글
🚀 Flutter Web + NestJS 풀스택 포트폴리오 프로젝트 개요 및 기술 스택 선택 (0) | 2025.03.27 |
---|---|
JAMstack 기반 포트폴리오 사이트의 배포 및 운영 (Mac Mini + Docker 기반 서버리스 프레임워크) (0) | 2025.03.15 |
JAMstack 기반 포트폴리오 사이트 최적화 및 추가 기능 구현 (0) | 2025.03.15 |
JAMstack 기반 포트폴리오 사이트 핵심 기능 개발 (0) | 2025.03.15 |
JAMstack 기반 포트폴리오 사이트 개발을 위한 기술 스택 선택 (0) | 2025.03.14 |
※ 이 포스팅은 쿠팡 파트너스 활동의 일환으로, 이에 따른 일정액의 수수료를 제공받습니다.
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- SEO 최적화
- 프론트엔드면접
- kotlin
- flax
- 프론트엔드
- 개발블로그
- 백엔드개발
- seo 최적화 10개
- fastapi
- CI/CD
- AI챗봇
- NestJS
- rag
- llm
- nextJS
- 파이썬알고리즘
- 웹개발
- Python
- Ktor
- REACT
- Docker
- Prisma
- SEO최적화
- gatsbyjs
- nodejs
- 딥러닝
- JAX
- Next.js
- PostgreSQL
- App Router
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | ||
6 | 7 | 8 | 9 | 10 | 11 | 12 |
13 | 14 | 15 | 16 | 17 | 18 | 19 |
20 | 21 | 22 | 23 | 24 | 25 | 26 |
27 | 28 | 29 | 30 | 31 |
글 보관함
반응형