반응형

파이썬으로 벡터 데이터베이스 Weaviate 연동하기
: 인공지능 시대의 데이터 검색 비법

GPT, 추천 시스템, 검색엔진…
이 모든 것의 뒤에는 벡터 데이터베이스가 있습니다.
그중 Weaviate는 지금 가장 ‘핫’한 선택지라는 거,
알고 계셨나요?

 

 

안녕하세요, 여러분!

오늘은 요즘 AI와 검색 분야에서 큰 주목을 받고 있는 벡터 데이터베이스 중 하나인 Weaviate를 파이썬으로 연동하는 방법에 대해 이야기해볼게요.

기존 관계형 데이터베이스와는 다르게, 벡터 기반으로 데이터를 저장하고 검색할 수 있는 이 혁신적인 도구는 특히 AI 모델과 찰떡궁합입니다.

“음… 그게 뭔데?” 하고 고개를 갸웃하셨다면, 지금 이 글을 정독하셔야 할 이유가 충분합니다 😉

단순한 이론 설명이 아닌, 실습 가능한 코드 예제와 함께 직접 동작시켜보는 튜토리얼 형태로 구성했으니, 끝까지 따라오시면 완전 정복하실 수 있어요!

 

1. Weaviate란 무엇인가요? 🧠

Weaviate는 오픈소스 기반의 벡터 검색 엔진(Vector Search Engine)입니다.

일반적인 데이터베이스처럼 텍스트나 숫자를 저장하는 기능은 물론이고, 이미지·텍스트·음성 등의 비정형 데이터를 벡터 형태로 저장하고 검색할 수 있도록 최적화된 구조를 갖고 있어요.

쉽게 말하면,

자연어 기반의 유사도 검색을 구현할 때 아주 강력한 도구라는 거죠.

GPT, BERT, CLIP, SBERT 등 다양한 AI 임베딩 모델과 연결해서, 어떤 문장이 다른 문장과 얼마나 비슷한지를 빠르게 찾아주는 시스템을 만들 수 있어요.

🔧 Weaviate의 주요 특징

  • 벡터 임베딩 데이터를 저장하고 검색하는 데 최적화된 DB
  • OpenAI, HuggingFace 등 다양한 임베딩 모델과 자동 연동 가능
  • REST API와 GraphQL API 모두 지원
  • Python, JavaScript 등 다양한 클라이언트 라이브러리 제공

📦 저장 방식: 벡터와 함께 저장하는 객체 기반 구조

Weaviate는 데이터를 단순 문자열로 저장하는 게 아니라, Object + Vector 형태로 저장합니다.

즉, 예를 들어 다음처럼 저장할 수 있어요:

Object (Text) Vector (임베딩)
"강아지는 귀엽다" [0.12, 0.98, ..., 0.34]
"고양이는 독립적이다" [0.22, 0.76, ..., 0.18]

이 벡터 값은 AI 임베딩 모델을 통해 자동 생성되며, 저장된 벡터끼리의 코사인 유사도 기반으로 비슷한 데이터를 검색할 수 있게 되는 거죠. 정말 똑똑하죠?

📈 활용 분야는 어디에?

  • ChatGPT와 같은 검색 기반 챗봇의 벡터 검색 엔진
  • 제품 추천 시스템에서 유사도 기반 상품 검색
  • 이미지·텍스트 검색 엔진

요약하자면,

Weaviate는 지금 시대의 AI 애플리케이션에 꼭 필요한 검색형 데이터베이스예요.

아직 익숙하지 않아도, 한 번 써보면 “아 이래서 다들 벡터DB 쓰는구나” 하실 거예요!

 

 

2. 벡터 데이터베이스가 필요한 이유는? 🔍

여러분 혹시 이런 경험 없으세요?

검색창에 뭔가 입력했는데, 딱 원하는 결과가 안 나올 때요.

그런 순간마다 “내가 말한 의도를 컴퓨터가 정확히 이해했으면 좋겠는데…” 라고 생각한 적,

저만 그런 거 아니죠? 😅

바로 그 문제를 해결해주는 게 벡터 검색, 그리고 그 기반이 되는 벡터 데이터베이스입니다.

🧩 기존 키워드 검색의 한계

  • 키워드 기반 검색은 정확한 단어 일치가 있어야 함
  • 문맥이나 의미는 반영되지 않음 (ex. "강아지" vs "멍멍이")
  • 비정형 데이터(이미지, 음성 등)는 검색하기 어렵다

그렇다면 어떻게 하면 문맥까지 반영한 “의미 기반 검색”이 가능할까요?

답은 AI 임베딩 + 벡터 유사도 검색입니다.

🔮 AI 시대의 데이터 검색 방식: 유사도 기반

최근 ChatGPT, 추천 시스템, 검색 기반 챗봇 등의 서비스들은 자연어 처리 모델로부터 생성된 벡터를 활용해 유사한 정보를 찾아냅니다.

이걸 가능하게 해주는 게 바로 벡터 데이터베이스예요.

기존 방식 벡터 방식
“고양이 사진” → 키워드 일치한 결과만 출력 “귀여운 반려동물 이미지”도 유사한 결과로 출력
텍스트 외 데이터 검색 어려움 이미지, 음성도 벡터화해서 검색 가능

🚀 왜 Weaviate인가요?

벡터 검색을 지원하는 데이터베이스는 많지만, Weaviate는 AI 모델을 자동 연동해주는 “Hybrid Search” 기능이 있어 정말 편리해요.

게다가 GraphQL API를 제공해, 구조화된 쿼리도 가능하다는 점에서 타 DB보다 유연하게 활용할 수 있답니다.

  • OpenAI, Cohere, HuggingFace 등의 임베딩 API와 자동 연동
  • REST API + GraphQL로 다양한 형태의 검색 가능

결론은 이거예요.

이제는 키워드 기반 검색에서 벗어나, 의미와 문맥을 반영한 스마트한 검색 시스템이 필요한 시대입니다. Weaviate는 그런 변화의 중심에 있는 도구라고 볼 수 있죠.

 

 

3. Weaviate 설치 및 기본 설정 방법 ⚙️

이제 본격적으로 시작해볼까요?

Weaviate는 로컬, 클라우드, Docker를 통해 쉽게 실행할 수 있어요.

특히 학습이나 테스트용으로는 Docker로 설치하는 게 가장 간편합니다.

여기선 Docker 기반 설치를 중심으로 설명드릴게요.

🐳 Step 1: Docker 설치

  • Docker Desktop을 다운로드하고 설치합니다.
  • 설치 후 Docker가 실행되고 있는지 확인하세요.
 

Docker Desktop: The #1 Containerization Tool for Developers | Docker

Docker Desktop is collaborative containerization software for developers. Get started and download Docker Desktop today on Mac, Windows, or Linux.

www.docker.com

 

📦 Step 2: Docker Compose 파일 작성

아래와 같은 내용의 docker-compose.yml 파일을 만들어주세요. 최신 버전 정보는 공식 문서에서 확인할 수 있어요.

version: '3.4'
services:
  weaviate:
    image: semitechnologies/weaviate:1.23.3
    ports:
      - "8080:8080"
    restart: on-failure
    environment:
      QUERY_DEFAULTS_LIMIT: 25
      AUTHENTICATION_ANONYMOUS_ACCESS_ENABLED: 'true'
      PERSISTENCE_DATA_PATH: "./data"
      DEFAULT_VECTORIZER_MODULE: text2vec-openai
      ENABLE_MODULES: text2vec-openai
      OPENAI_APIKEY: your-openai-api-key-here

 

여기서 text2vec-openai는 OpenAI 기반 임베딩을 사용하는 모듈이에요.

물론 HuggingFace, Cohere 같은 다른 모듈도 설정 가능하지만, 가장 간단한 건 OpenAI API 키를 사용하는 거죠.

🚀 Step 3: Weaviate 서버 실행

터미널을 열고 docker-compose.yml이 있는 경로에서 아래 명령어를 실행해보세요.

docker-compose up -d

 

브라우저에서 http://localhost:8080/v1/.well-known/ready 로 접속하면 서버 상태를 확인할 수 있어요. “OK”라는 응답이 나오면 성공적으로 Weaviate 인스턴스가 실행된 거예요!

🧪 테스트를 위한 준비 완료!

여기까지 완료되면 이제 파이썬에서 Weaviate에 접속해서 데이터를 주고받을 준비가 된 거예요.

다음 단계에서는 실제로 파이썬 코드로 Weaviate와 연결해보면서 본격적인 실습을 진행해볼게요!

 

 

4. 파이썬에서 Weaviate와 연결하기 💻

이제 Weaviate 서버가 정상 실행되고 있다는 전제 하에, 파이썬 코드로 Weaviate와 연결해보겠습니다. Python에서는 공식 라이브러리인 weaviate-client를 사용하면 손쉽게 데이터를 전송하거나 검색할 수 있어요.

📦 Step 1: weaviate-client 설치

pip install weaviate-client

 

최신 버전이 잘 설치되었는지 아래 명령어로 확인해보세요.

pip show weaviate-client

🔗 Step 2: 클라이언트 연결

import weaviate

# 클라이언트 인스턴스 생성
client = weaviate.Client(
    url="http://localhost:8080",  # 로컬호스트로 실행 중일 경우
    additional_headers={
        "X-OpenAI-Api-Key": "your-openai-api-key-here"  # text2vec-openai 모듈을 위한 키
    }
)

# 연결 확인
if client.is_ready():
    print("✅ Weaviate 연결 성공!")
else:
    print("❌ 연결 실패")

 

이 코드에서 client.is_ready()는 실제로 서버가 정상 작동 중인지 확인하는 용도로 사용됩니다.

연결에 성공했다면 이제 데이터를 클래스 형태로 정의하고 벡터 저장을 시작할 수 있어요.

🧱 Step 3: 데이터 스키마(Class) 정의

# 기존 스키마 삭제 (테스트용)
client.schema.delete_all()

# 새 스키마 정의
class_obj = {
    "class": "Document",
    "description": "A collection of text documents",
    "vectorizer": "text2vec-openai",
    "properties": [
        {
            "name": "content",
            "dataType": ["text"],
            "description": "The content of the document"
        }
    ]
}

client.schema.create_class(class_obj)

 

이제 "Document"라는 이름의 클래스에 데이터를 저장할 준비가 완료된 상태예요.

이름, 설명, 속성(property), 그리고 어떤 벡터화 방식(text2vec-openai)을 사용할지를 명시했죠.

📌 다음 단계는?

여기까지 따라오셨다면, 이제 본격적으로 데이터를 벡터로 저장하고 검색하는 실습을 진행해볼 차례예요!

 

다음 단계에서는 여러 문장을 벡터로 저장하고, 유사도 검색하는 코드를 함께 작성해볼게요 🔍

놓치지 말고 꼭 따라와주세요!

 

 

5. 실전 예제: 문서 벡터화하고 검색하기 🔎

이제 진짜 재미있는 단계예요 😎

이전 단계에서 정의한 Document 클래스에 데이터를 저장하고, AI 임베딩을 기반으로 유사한 문서를 검색해보는 예제를 직접 실행해볼게요.

📥 Step 1: 문서 데이터 삽입

documents = [
    {"content": "강아지는 충성스럽고 귀엽다."},
    {"content": "고양이는 독립적인 성격을 가지고 있다."},
    {"content": "사람은 다양한 감정을 가진 존재다."},
    {"content": "AI는 인간의 지능을 모방하려는 기술이다."},
    {"content": "햄스터는 작고 귀여운 반려동물이다."}
]

for doc in documents:
    client.data_object.create(data_object=doc, class_name="Document")

 

이 코드는 각 문장을 하나의 오브젝트로 Document 클래스에 저장하는 예제예요.

저장하는 동시에 OpenAI 임베딩 API를 통해 자동으로 벡터화되죠.

🔎 Step 2: 유사도 기반 검색 실행

예를 들어, “귀여운 동물”이라는 문장과 가장 유사한 내용을 찾고 싶다면 다음과 같이 검색할 수 있어요.

response = client.query.get("Document", ["content"]) \
    .with_near_text({"concepts": ["귀여운 동물"]}) \
    .with_limit(2) \
    .do()

print(response)

 

이렇게 하면 벡터 간의 유사도를 기준으로 가장 비슷한 문장을 찾아주는 거죠.

정말 신기하고도 똑똑한 검색 방식이에요 🤯

📌 검색 결과 예시

순위 문장 내용
1위 “강아지는 충성스럽고 귀엽다.”
2위 “햄스터는 작고 귀여운 반려동물이다.”

이 결과를 보면 확실히 “귀여운 동물”이라는 키워드와 가장 의미상 가까운 문장을 골라내고 있어요.

이게 바로 기존 키워드 검색으로는 불가능한 의미 기반 검색의 힘이죠!

🙋‍♀️ 활용 아이디어

  • FAQ 자동 응답 시스템 (비슷한 질문 자동 매칭)
  • 뉴스 기사 유사도 분석
  • 추천 시스템의 콘텐츠 기반 필터링

이제 여러분도 직접 데이터를 저장하고, AI처럼 똑똑한 검색을 구현할 수 있게 된 거예요!

간단한 코드 몇 줄로 강력한 검색 시스템을 만들 수 있다니, 이건 꼭 써봐야죠 🤖

 

 

6. 함께 쓰면 좋은 도구들 및 활용 팁 💡

Weaviate를 혼자 쓰는 것도 물론 훌륭하지만, 다양한 도구들과 결합하면 훨씬 더 막강한 성능과 편의성을 누릴 수 있어요.

특히 AI 기반 검색 시스템을 구축하거나 RAG, 챗봇, 추천 시스템 등을 만들고 싶다면,

아래와 같은 툴들과 궁합이 정말 좋습니다!

🤖 1. 임베딩 모델 API: OpenAI, Cohere, HuggingFace

  • text2vec-openai: ChatGPT 계열 OpenAI 임베딩 사용 가능
  • text2vec-cohere: 빠르고 저렴한 Cohere 벡터화 지원
  • text2vec-transformers: HuggingFace 모델 직접 연동 가능

🧰 2. 프론트엔드 연결: Streamlit, Gradio, FastAPI

  • Streamlit: 실시간 검색 인터페이스 구축에 딱! 초보자도 쉽게 사용 가능
  • Gradio: 이미지 + 텍스트를 처리하는 UI가 필요할 때 유용
  • FastAPI: RESTful API와 검색 서비스 서버 구축에 최적

📈 3. 대규모 데이터 관리: Elasticsearch, Milvus, Qdrant과 비교

DB 특징
Weaviate AI 벡터 자동 연동 + GraphQL 지원
Milvus 대규모 처리에 강점, 고성능 검색에 특화
Qdrant Rust 기반, 빠른 속도와 유연한 API
Elasticsearch 전통적 검색엔진 + 플러그인으로 벡터 검색 확장

🎯 활용 팁 정리

  • 작은 테스트부터 시작하세요: 5~10개 데이터로 먼저 실험해보면 이해가 쏙쏙!
  • 임베딩 모델에 따라 결과가 완전히 달라져요: 다양한 모델을 시도해 보세요.
  • Streamlit 대시보드로 실시간 검색 앱 만들기 추천!

Weaviate는 단독으로도 훌륭하지만, 연결할수록 무한히 확장 가능한 데이터 AI 인프라가 됩니다.

직접 이 조합들을 활용해보면서 나만의 “지식 검색 플랫폼”을 구축해보세요 🚀

 

 

파이썬과 Weaviate, AI 검색의 시작점

지금까지 함께 살펴본 Weaviate는 단순한 데이터 저장소가 아닙니다.

의미 기반 검색, 유사도 기반 추천, 인공지능 챗봇의 핵심이 되는 중요한 도구입니다.

파이썬으로 간단하게 설치하고 연결해, 복잡한 벡터 연산 없이도 고급 검색 기능을 구현할 수 있다는 점은 정말 큰 장점이죠.

이제는 키워드 검색을 넘어서야 할 때입니다.

AI 서비스에 꼭 필요한 벡터 DB 기술, 여러분도 이제 첫발을 내디뎠습니다.

오늘 배운 내용으로 여러분의 프로젝트에 더 스마트한 기능을 넣어보세요!

궁금한 점이 있다면 댓글로 남겨주시고, 더 알고 싶은 주제가 있다면 언제든지 요청해주세요.  😉

놓치지 않도록 구독과 북마크는 필수!

반응형
반응형

파이썬 데이터베이스 프로그래밍 완전 입문
: 벡터 데이터베이스 Milvus 연동 방법

AI 서비스를 만들려면 대량의 비정형 데이터를 어떻게 저장하고 검색할지부터 고민해야 하죠.
그 해답, 바로 벡터 데이터베이스 Milvus입니다!

 

 

안녕하세요!

요즘 AI, 특히 생성형 AI와 추천 시스템에서 많이 듣게 되는 단어가 있죠.

바로 벡터 데이터베이스(Vector DB)입니다.

그중에서도 Milvus는 오픈소스 벡터 DB 중에서도 가장 많이 쓰이는 툴인데요.

이 글에서는 Milvus가 뭔지, 왜 써야 하는지, 그리고 파이썬으로 어떻게 연동하고 사용하는지까지 차근차근 안내해 드릴게요.

개념 설명은 물론이고, 실습 예제까지 함께 다룰 거니까 초보자 분들도 따라 하기 쉽게 설명드릴게요! 🧑‍💻

그럼 본격적으로 시작해볼까요?

 

1. Milvus란 무엇인가요? 🧠

Milvus는 고차원 벡터 데이터를 효율적으로 저장하고 검색할 수 있도록 설계된 오픈소스 벡터 데이터베이스입니다.

2020년 Zilliz라는 회사에서 처음 개발되었고, 현재는 LF AI & Data 재단의 공식 프로젝트로 운영되고 있어요.

벡터 데이터란 텍스트, 이미지, 영상 등 비정형 데이터를 임베딩(embedding) 기법을 통해 고차원 숫자 배열로 바꾼 것을 말합니다.

예를 들어,

"파이썬"이라는 단어를 벡터화하면 다음과 같은 모양이 될 수 있어요:

[0.132, -0.874, 0.341, ..., 0.290]  # 총 768차원의 벡터라고 가정

 

Milvus는 이런 벡터들을 빠르게 저장하고, 유사도를 계산하여 비슷한 의미의 벡터를 빠르게 검색해 줍니다.

이 기능은 검색엔진, 추천 시스템, AI 챗봇, 얼굴 인식, LLM 기반 RAG 등 다양한 분야에 활용되고 있어요.

Milvus의 주요 특징

  • 수십억 개 벡터 저장 및 검색 가능 (대규모 확장성)
  • CPU 및 GPU 기반 인덱싱 지원 (FAISS, HNSW 등 통합)
  • 다양한 쿼리 기능: 벡터 유사도, 필터 조건 등 복합 검색 가능
  • RESTful API 및 Python SDK 지원으로 쉬운 연동

Milvus는 어떤 상황에 적합할까요?

이런 경우 Milvus가 매우 유용합니다:

  1. AI 응답에 유사 문서를 찾아 붙이는 RAG 구조 만들 때
  2. 이미지 유사도 검색을 통한 추천 시스템 구축 시
  3. 보안 시스템에서 얼굴 인식 기반 출입 제어할 때
  4. 수백만 개의 질문-응답을 저장하고 검색하는 챗봇 구축 시

요즘 ChatGPT처럼 LLM 기반 시스템에서도 Milvus는 핵심 역할을 해요.

LLM은 입력된 질문과 유사한 벡터를 찾고, 그에 대응되는 문서를 검색해서 답변을 생성하죠.

이 때 Milvus가 없으면 검색 속도도 느려지고 정확도도 떨어질 수 있어요.

 

정리하자면, Milvus는 단순한 저장소가 아니라 AI 시대의 핵심 검색 인프라라고 볼 수 있습니다.

 

 

2. 벡터 DB가 필요한 이유는? 🔍

우리는 하루에도 수백 개의 데이터를 보고, 클릭하고, 검색합니다.

그런데 그 데이터들 대부분은 비정형 데이터예요.

예를 들면

텍스트, 이미지, 음성 같은 거죠. 이런 데이터는 기존의 관계형 데이터베이스(RDBMS)로는 검색이나 저장이 비효율적이에요.

이럴 때 필요한 것이 바로 벡터화(Embedding)입니다.

데이터를 벡터로 바꾸면, 수학적으로 유사도를 계산할 수 있고, 그걸 이용해서 비슷한 의미를 찾을 수 있어요.

예를 들어,

"고양이"와 "강아지"는 다른 단어지만 의미상 비슷하죠?

이걸 일반 DB는 이해 못 하지만, 벡터 DB는 이해할 수 있습니다.

비교: 관계형 DB vs 벡터 DB

항목 관계형 DB 벡터 DB
데이터 형태 정형 데이터 (테이블 구조) 비정형 데이터를 벡터로 표현
검색 방식 정확한 값 매칭 유사도 기반 검색 (Nearest Neighbor)
활용 분야 재고관리, 회계, 회원정보 추천, 검색, AI 서비스
확장성 세로 확장 위주 수평 확장에 최적화

그렇다면 왜 지금 벡터 DB가 주목받을까요?

  • 생성형 AI(Generative AI)의 급속한 성장 때문이에요.
  • LLM은 입력된 문장을 벡터로 바꾼 후, 비슷한 문서 벡터를 찾아 답변을 생성합니다.
  • 기존 DB는 이런 검색을 빠르고 효율적으로 처리하기 어렵습니다.

결국, 벡터 DB는 AI가 제대로 작동하기 위한 필수 인프라가 된 거죠.

특히 챗봇, 추천 서비스, 개인화 콘텐츠 제공, 문서 요약, 자동 분류 등 다양한 AI 서비스에서 없어서는 안 되는 존재가 되었습니다.

 

이제는 데이터를 저장하는 것보다, "어떻게 검색하고 연결할 것인가?"가 더 중요한 시대예요.

벡터 DB는 바로 그 질문에 대한 답입니다.

 

 

3. Milvus 설치 및 기본 설정 ⚙️

Milvus는 다양한 환경에서 실행할 수 있지만, 대부분의 경우 Docker를 이용한 설치가 가장 간단하고 안정적입니다.

특히 학습 및 실습용으로는 Docker Compose를 활용하는 것이 편리하죠.

🧰 Milvus 설치 방법 (Docker 기반)

  1. Docker와 Docker Compose를 설치합니다.
  2. Milvus 공식 Github 저장소에서 docker-compose 파일을 다운로드합니다.
  3. 터미널에서 docker-compose up -d 명령어로 Milvus를 실행합니다.
git clone https://github.com/milvus-io/milvus.git
cd milvus/deployments/docker-compose
docker-compose up -d

 

위 명령어를 실행하면 Milvus와 필수 서비스(Meta Store, Message Queue 등)가 함께 실행됩니다.

약 2~3분이면 모든 컨테이너가 정상적으로 뜨고,

Milvus 서버가 로컬에서 포트 19530번으로 열려요.

Milvus 실행 확인

Milvus가 잘 실행됐는지 확인하려면 아래 명령어를 이용해 로그를 확인해 보세요.

docker-compose logs -f milvus-standalone

 

"Milvus is ready to serve" 라는 메시지가 뜬다면 설치 성공!

이제 Python에서 연동할 준비가 된 거예요 😎

📦 Milvus 구성요소 요약

구성 요소 설명
Milvus 벡터 저장 및 검색 엔진
Etcd 분산 구성 저장소 (메타데이터 관리)
MinIO 객체 스토리지 시스템 (파일 저장소)
Pulsar/Kafka 메시지 큐 시스템 (비동기 처리)

Milvus 버전 확인

docker exec -it milvus-standalone milvus --version

 

여기까지 설치가 완료되었다면, 이제 Milvus와 Python을 연결해서 실제 데이터를 넣고 검색해 볼 수 있습니다.

바로 다음 단계에서 Milvus의 Python SDK를 활용해보겠습니다!

 

 

4. 파이썬에서 Milvus 연동하기 🐍

Milvus가 잘 설치되었다면, 이제 Python 코드에서 Milvus에 연결하고 데이터를 주고받을 수 있어야겠죠?

이를 위해 Milvus 팀이 공식적으로 제공하는 pymilvus 라이브러리를 사용합니다.

이 모듈은 Milvus 서버와의 통신을 쉽게 만들어주는 Python SDK입니다.

🛠️ pymilvus 설치 및 환경 설정

pip install pymilvus

 

이제 Python에서 Milvus 서버와 연결을 시도해볼 수 있습니다.

기본 포트는 19530이고, Docker로 실행했다면 localhost로 접근할 수 있어요.

from pymilvus import connections

connections.connect(
    alias="default",
    host="127.0.0.1",
    port="19530"
)

📌 연결 확인

from pymilvus import utility

print(utility.get_server_version())  # 버전 출력
print(utility.has_collection("my_collection"))  # 컬렉션 존재 확인

 

Milvus와 연결이 성공하면 서버 버전이 출력되고, 컬렉션 여부를 확인할 수 있습니다.

이제 데이터를 저장할 공간인 컬렉션(collection)을 생성해 봅시다!

📁 컬렉션 생성: 벡터 저장 공간 만들기

from pymilvus import Collection, FieldSchema, CollectionSchema, DataType

fields = [
    FieldSchema(name="id", dtype=DataType.INT64, is_primary=True, auto_id=False),
    FieldSchema(name="embedding", dtype=DataType.FLOAT_VECTOR, dim=128)
]

schema = CollectionSchema(fields=fields, description="Test vector collection")

collection = Collection(name="my_collection", schema=schema)
  • id 필드는 primary key로 지정되어 있어야 합니다.
  • embedding 필드는 벡터 값을 저장하며, 차원(dim)을 꼭 지정해야 합니다.

✅ 요약: Milvus 연동 핵심 단계

  1. pymilvus 설치
  2. Milvus 서버 연결 (host, port 확인)
  3. 컬렉션 스키마 정의
  4. 컬렉션 생성 및 존재 여부 확인

이제 Milvus에 연결해서 데이터를 저장할 준비가 완료되었습니다!

다음 단계에서는 실제 벡터 데이터를 삽입하고 유사한 벡터를 검색해보는 실전 예제를 다뤄보겠습니다 🚀

 

 

5. Milvus 실전 예제: 벡터 삽입과 검색 🔢

Milvus에 컬렉션을 만들고 연결을 완료했다면, 이제 진짜 벡터 데이터를 넣어보고, 그 중에서 가장 유사한 벡터를 검색해보는 실습을 해봐야겠죠?

이 파트에서는 벡터 데이터 삽입 → 인덱스 생성 → 유사도 검색까지의 전 과정을 차례대로 설명드릴게요.

📌 Step 1: 임의의 벡터 데이터 생성 및 삽입

import random
import numpy as np
from pymilvus import Collection

# 128차원 임의 벡터 생성
def generate_vectors(num, dim):
    return [[random.random() for _ in range(dim)] for _ in range(num)]

vectors = generate_vectors(5, 128)
ids = [i for i in range(5)]

collection = Collection("my_collection")
collection.insert([ids, vectors])
  • 총 5개의 벡터를 생성해서 ID와 함께 삽입합니다.

삽입이 완료되면 내부적으로 Milvus는 데이터를 segment로 나눠서 디스크에 저장합니다.

그다음으로 해야 할 작업은 빠른 검색을 위한 인덱스 생성입니다.

📌 Step 2: 인덱스 생성

index_params = {
    "metric_type": "L2",
    "index_type": "IVF_FLAT",
    "params": {"nlist": 64}
}

collection.create_index(
    field_name="embedding",
    index_params=index_params
)

collection.load()  # 컬렉션 로딩

 

Milvus는 다양한 인덱스 타입을 지원하는데, 여기서는 가장 기본적인 IVF_FLAT을 사용했어요.

검색을 하기 위해선 반드시 컬렉션을 load() 해줘야 합니다!

📌 Step 3: 유사도 검색 (Similarity Search)

search_params = {"metric_type": "L2", "params": {"nprobe": 10}}

query_vector = [vectors[0]]  # 첫 번째 벡터를 검색 기준으로 사용

results = collection.search(
    data=query_vector,
    anns_field="embedding",
    param=search_params,
    limit=3,
    output_fields=["id"]
)

for result in results[0]:
    print(f"ID: {result.id}, Distance: {result.distance}")

 

위 코드는 첫 번째 벡터와 가장 유사한 3개의 벡터를 찾아내는 예제입니다.

유사도 측정에는 L2 거리(Euclidean Distance)가 사용되고, nprobe는 검색 정확도와 속도에 영향을 주는 매개변수입니다.

🧾 전체 프로세스 요약

  1. 벡터 데이터 생성
  2. Milvus 컬렉션에 삽입
  3. 인덱스 생성
  4. 컬렉션 로드
  5. 검색 수행

여기까지 따라오셨다면, 이제 Milvus를 이용해 벡터 데이터를 완전히 다룰 수 있게 된 거예요!

그렇다면 이런 기능을 실제 서비스에서는 어떻게 쓸 수 있을까요?

 

다음 마지막 섹션에서 Milvus를 활용한 AI 서비스 시나리오를 함께 살펴봅시다 😊

 

6. Milvus를 활용한 AI 서비스 시나리오 🚀

이제 Milvus의 기본적인 사용법과 구조는 익혔습니다.

그럼 도대체 Milvus를 실제 서비스에서는 어떻게 활용할 수 있을까요?

이 파트에서는 Milvus의 기능을 살려 구현할 수 있는 대표적인 AI 서비스 시나리오 4가지를 소개하겠습니다.

🧠 1. RAG 기반 챗봇: LLM과 Milvus의 완벽 콤보

최근 가장 핫한 AI 아키텍처 중 하나인 RAG(Retrieval-Augmented Generation)는 LLM에 벡터 검색을 결합해 보다 정확하고 실제 데이터 기반의 답변을 생성하는 방식입니다.

  • 질문을 임베딩(embedding) 벡터로 변환
  • Milvus에서 관련 문서를 벡터 유사도로 검색
  • 검색된 문서를 기반으로 LLM이 응답 생성

이 방식은 ChatGPT 플러그인, 사내 지식 챗봇, 검색 기반 문서 요약 등에 널리 쓰이고 있으며 Milvus는 벡터 검색을 빠르게 처리하는 핵심 엔진 역할을 합니다.

🖼️ 2. 이미지 검색 및 추천 시스템

유저가 업로드한 이미지와 유사한 사진이나 상품을 추천하고 싶을 때, Milvus는 딱 맞는 도구입니다.

이미지를 벡터로 변환해 저장하고, 유사한 벡터를 찾아주는 것이 핵심이죠.

# 예시) 이미지 feature vector 추출 후 Milvus에 저장 및 검색
image_vector = model.encode(image)
collection.insert([image_id, image_vector])
collection.search(data=[image_vector], anns_field="embedding", ...)

 

AI 모델은 이미지 간 유사도를 판단하고, Milvus는 가장 유사한 이미지를 뽑아냅니다.

이런 구조는 이커머스 추천, 디자인 검색, 패션 코디 추천 등 다양한 곳에 활용돼요.

📚 3. 학습 콘텐츠 큐레이션 시스템

사용자가 공부하고 있는 개념이나 질문 내용을 바탕으로, 가장 관련성 높은 학습 자료를 추천해주는 시스템입니다.

  • "파이썬 리스트 슬라이싱이 뭐야?" → 관련 블로그, 문서, 영상 추천

텍스트 벡터 임베딩 + Milvus 검색 + 추천 알고리즘을 조합하면 개인화된 학습 경험을 제공할 수 있어요.

온라인 교육 플랫폼에서 특히 많이 활용됩니다.

🔐 4. 얼굴 인식 보안 시스템

CCTV 영상에서 추출한 얼굴 특징 벡터를 기반으로, Milvus에 저장된 사용자 벡터와 비교하여 신원을 판별합니다.

이는 금융 보안, 사무실 출입, 비대면 신원 인증 등 보안이 중요한 환경에서 빠르고 정확한 인증 수단으로 각광받고 있어요.

🚀 Milvus는 단순한 DB가 아닙니다

Milvus는 AI 기능을 실시간으로 가능하게 만들어주는 검색 엔진이자 추론 인프라입니다.

단순한 저장소가 아니라, 데이터를 "이해하고 연결하는" 기능을 제공하는 차세대 도구죠.

 

 

마무리  🧩

지금까지 벡터 데이터베이스 Milvus의 개념부터 설치, 파이썬 연동, 실전 예제까지 한 걸음씩 알아봤습니다.

처음엔 생소할 수 있지만, AI 서비스를 만들다 보면 Milvus와 같은 벡터 DB의 필요성을 절실히 느끼게 됩니다.

특히 검색 기능이나 추천 시스템, RAG 구조 기반의 LLM 챗봇을 구현할 때 Milvus는 단순한 저장소가 아니라 핵심 인프라로서의 역할을 하죠.

기존 RDB나 NoSQL과는 전혀 다른 방식으로 데이터를 처리하고 검색하는 이 새로운 패러다임은, 앞으로 AI 시대에서 더욱 널리 활용될 것으로 보입니다.

처음 배우는 분들을 위해 최대한 쉽게 설명드리려고 했지만, 실습하면서 막히는 부분이 있다면 공식 문서와 커뮤니티도 적극 참고해보세요.

Milvus는 전 세계적으로 활발하게 사용되는 프로젝트이기 때문에, 다양한 예제와 가이드도 잘 정리되어 있답니다 😊

이번 글을 통해 벡터 DB의 기초를 다지고, 여러분만의 AI 서비스로 확장해보세요!

늘 그렇듯, 코딩은 직접 손으로 해봐야 진짜 내 것이 된답니다 💪

반응형
반응형

나의 프로젝트에 어떤 데이터베이스를 선택해야 할까?

그 많고 많은 데이터베이스 중,
나의 프로젝트에는 대체 어떤 DB를 써야 하는 걸까요? 🤔
선택만 잘해도 절반은 성공입니다!

 

 

안녕하세요!

오늘은 정말 많은 분들이 고민하는 주제 하나를 가져와봤어요.

바로 “내 프로젝트에 딱 맞는 데이터베이스 선택”입니다.

웹 서비스를 만들 때, 앱을 개발할 때, 심지어는 개인 포트폴리오 프로젝트를 할 때도 가장 먼저 마주하게 되는 고민 중 하나죠.

 

관계형 DB를 쓸까, NoSQL을 써야 할까? RDS? Redis? 아니면 Milvus 같은 벡터 DB?

 

이름은 다 들어봤지만 언제, 어떤 상황에서 써야 하는지 헷갈릴 때가 많습니다.

그래서 오늘은 다양한 데이터베이스 종류의 핵심 특징과 실제 활용 사례를 함께 정리해보면서 여러분의 프로젝트에 가장 잘 맞는 DB를 찾을 수 있도록 도와드릴게요.

특히 요즘 뜨는 클라우드 기반 DB, 벡터 DB, 그래프 DB까지 빠짐없이 다루니 끝까지 함께 해주세요! 💪

 

1. 관계형 데이터베이스 vs NoSQL, 무엇이 다른가요? 🔍

데이터베이스를 선택할 때 가장 먼저 부딪히는 질문이 바로

“관계형 DB를 쓸까, NoSQL을 쓸까?”일 거예요.

두 유형은 구조, 사용 목적, 성능에서 큰 차이를 보이는데요.

이 차이를 먼저 이해해야 프로젝트의 방향성을 결정할 수 있습니다.

📘 관계형 데이터베이스 (RDBMS)

  • 정해진 스키마에 따라 데이터를 테이블 형식으로 저장합니다.
  • SQL 쿼리를 사용하여 데이터 검색 및 조작이 가능합니다.
  • 트랜잭션 처리(ACID 특성)가 뛰어나 데이터 무결성이 중요한 프로젝트에 적합합니다.

RDBMS 대표 사례

PostgreSQL, MySQL, MariaDB, SQLite, Oracle 등이 있습니다.

이들은 전통적인 웹 서비스, 금융 시스템, ERP 등에서 널리 쓰이고 있어요.

📗 NoSQL 데이터베이스

  • 테이블 대신 문서, 키-값, 그래프, 열 기반 등 다양한 형태로 데이터를 저장합니다.
  • 스키마가 자유롭고 유연해서 빠른 개발과 데이터 구조 변경에 용이합니다.
  • 대용량 데이터를 분산 저장하며 수평 확장성이 뛰어납니다.

NoSQL 대표 사례

MongoDB, Cassandra, Redis, Neo4j, Elasticsearch 등이 있어요.

실시간 분석, 추천 시스템, IoT 데이터 수집, 그래프 기반 탐색 등에서 두각을 나타내죠.

🔍 두 유형의 핵심 비교

항목 관계형 DB NoSQL DB
구조 고정된 테이블 + 스키마 유연한 스키마 (또는 없음)
확장성 수직 확장 수평 확장
쿼리 언어 SQL Mongo Query, CQL 등
사용 사례 금융, ERP, 전통 웹 실시간 분석, 분산 저장

요약하자면,

구조화된 데이터를 안정적으로 다뤄야 한다면 RDBMS가,

데이터 구조가 자주 바뀌고 확장성과 속도가 중요하다면 NoSQL이 유리해요.

 

다음 섹션에서는 실제 관계형 DB 종류들을 비교해보면서 어떤 프로젝트에 어울리는지 더 자세히 볼게요!

 

 

2. 인기 관계형 DB: PostgreSQL, MySQL, SQLite 비교 📊

관계형 데이터베이스(RDBMS)는 웹 서비스뿐만 아니라 거의 모든 기업 시스템에서 기본으로 쓰이죠.

그중에서도 PostgreSQL, MySQL(MariaDB), SQLite는 가장 널리 사용되는 대표 주자들입니다.

그런데 비슷해 보이지만 성격과 강점은 제각각이에요.

어떤 DB가 여러분의 프로젝트에 적합할지 하나씩 살펴보죠.

🦉 PostgreSQL: 확장성과 정합성이 강점!

  • 오픈소스지만 기업급 기능을 지원하며 다양한 확장 모듈을 사용할 수 있어요.
  • 트랜잭션 처리와 동시성 제어가 강력해 금융, 정부, 대형 시스템에 적합합니다.
  • JSON, GIS, 풀텍스트 검색 등 복합 데이터 처리도 잘 지원합니다.

🐬 MySQL / MariaDB: 쉽고 빠른 시작!

  • 가장 오래되고 유명한 웹 친화형 RDBMS로, PHP 기반 CMS와 찰떡입니다.
  • 오픈소스인 MariaDB는 MySQL과 호환되면서도 라이선스 제약이 적어요.
  • 중소형 웹 프로젝트, 쇼핑몰, 커뮤니티 구축에 많이 활용됩니다.

📱 SQLite: 작고 가볍지만 강력해요!

  • 서버가 따로 필요 없는 파일 기반 데이터베이스입니다.
  • 앱 설치 시 함께 배포 가능해서 모바일 앱, IoT 기기, 데스크탑 앱에 탁월해요.
  • 로컬 환경 테스트용으로도 자주 활용됩니다.

🧾 주요 관계형 DB 비교표

DBMS 특징 활용 사례
PostgreSQL 확장성, 안정성, 복잡한 쿼리 가능 데이터 분석, 금융, 대형 시스템
MySQL / MariaDB 웹 친화적, 빠른 시작 가능 중소형 웹사이트, CMS, 쇼핑몰
SQLite 경량화, 무설치, 파일 기반 모바일 앱, 로컬 테스트

결론적으로,

프로젝트의 규모와 목적에 따라

 

PostgreSQL은 복잡한 엔터프라이즈 시스템에,

MySQL/MariaDB는 일반 웹 서비스에,

SQLite는 간단한 로컬 저장에 적합하다고 볼 수 있습니다.

 

다음에는 NoSQL DB의 실전 활용 케이스를 알아볼게요!

 

 

3. 유연한 NoSQL DB: MongoDB, Cassandra는 언제 쓸까? 🧩

NoSQL 데이터베이스는 전통적인 RDBMS로는 감당하기 힘든 유연함과 확장성을 제공합니다.

특히 MongoDB와 Cassandra는 서로 다른 방향으로 강점을 지니고 있어요.

이 둘을 제대로 이해하면 복잡한 비정형 데이터나 대용량 분산 환경에서도 거뜬한 데이터베이스 설계를 할 수 있습니다.

🍃 MongoDB: 문서형 DB의 대표주자

  • JSON과 유사한 BSON 포맷으로 데이터를 저장, 구조가 자유롭습니다.
  • 데이터 간 관계가 단순하거나 유동적인 경우에 적합해요.
  • 콘텐츠 관리 시스템, 실시간 피드, IoT에 자주 쓰입니다.

💡 예를 들면, 뉴스 사이트에서 게시물마다 구조가 조금씩 다를 때, MongoDB는 유연하게 대응할 수 있어요.

🛰️ Cassandra: 확장성과 가용성의 끝판왕

  • 대용량 데이터를 분산 환경에 자동으로 저장하고 복제합니다.
  • 쓰기 성능이 탁월하고 장애 복구 능력이 뛰어납니다.
  • 로그 저장, 실시간 메시징, IoT 센서 데이터 저장에 적합해요.

💡 페이스북, 넷플릭스 등 글로벌 서비스를 위한 초대형 트래픽 처리에 활용되는 이유도 여기 있습니다.

⚖️ MongoDB vs Cassandra 한눈에 비교!

항목 MongoDB Cassandra
데이터 구조 문서형(BSON) 컬럼 패밀리
확장성 수평 확장 가능 고도 분산 및 복제
쓰기 성능 좋음 아주 뛰어남
사용 사례 콘텐츠, IoT, 유연한 구조 로그, 분석, 대용량 메시징

결론!

구조가 자유롭고 빠르게 변하는 콘텐츠 중심 서비스에는 MongoDB,

수평 확장성과 쓰기 성능이 중요한 대규모 시스템에는 Cassandra가 훨씬 유리합니다.

 

다음 STEP에서는 요즘 핫한 벡터 DB와 그래프 DB에 대해 소개할게요!

 

 

4. 최신 트렌드: 벡터 DB와 그래프 DB의 활용 사례 🚀

최근 데이터베이스 업계에서 가장 주목받는 분야는 바로 벡터 DB와 그래프 DB입니다.

AI, 검색, 추천 시스템이 발전하면서 이 두 기술의 활용도가 급격히 늘고 있는데요.

기존의 RDB나 NoSQL로는 불가능했던 의미 기반 검색관계 중심 탐색이 가능해졌기 때문이죠.

🧠 벡터 DB: Milvus, Weaviate, Qdrant

  • 딥러닝 벡터 임베딩을 저장하고, 유사도 기반 검색을 수행합니다.
  • 텍스트, 이미지, 음성 등 다양한 데이터를 벡터화해 검색에 활용할 수 있어요.
  • 챗봇 RAG 시스템, 추천 시스템, 검색엔진에 필수적으로 활용됩니다.

📌 Milvus는 GPU 최적화가 잘 되어 있어 고속 검색에 특화,

      Weaviate는 AI 통합 기능이 우수하고,

      Qdrant는 경량화 및 Rust 기반 고성능을 지향합니다.

🕸️ 그래프 DB: Neo4j

  • 데이터 간 복잡한 관계를 노드(Node)와 엣지(Edge)로 표현합니다.
  • 패턴 탐색, 경로 탐색이 뛰어나고 Cypher라는 전용 쿼리언어를 사용해요.
  • 지식 그래프, 사기 탐지, 네트워크 분석에 적합합니다.

📌 예를 들면, 고객 간 추천 관계 분석이나 SNS 친구 추천 알고리즘 같은 데에 강력하죠.

🔍 최신 DB 기술 한눈에 정리

DB 종류 핵심 특징 대표 활용 사례
Milvus GPU 기반 벡터 유사도 검색 최적화 AI 검색 시스템, 추천엔진
Weaviate AI 내장, 자연어 질의 지원 RAG 기반 검색엔진
Qdrant 고성능, Rust 기반 경량화 이미지 검색, 대규모 벡터 저장
Neo4j 노드-엣지 기반 관계 탐색 지식 그래프, 관계 분석

요즘 AI 서비스나 검색 추천 기능을 고려하고 있다면 벡터 DB는 사실상 필수에 가깝고,

관계 분석이나 트리 구조 탐색이 중심이라면 그래프 DB가 정답일 수 있어요.

 

이제 마지막으로 프로젝트 유형별로 어떤 DB가 적합할지 정리해볼까요? 👇

 

 

5. 클라우드 DBaaS: Amazon RDS, BigQuery, Snowflake 살펴보기 ☁️

요즘처럼 빠르게 변화하는 개발 환경에서 클라우드 기반 데이터베이스 서비스(DBaaS)는 선택이 아닌 필수가 되고 있어요.

직접 서버를 관리하지 않아도 되고, 확장성도 뛰어나고, 보안 설정까지 알아서 해주니까요.

이번 섹션에서는 대표적인 클라우드 DBaaS 세 가지, Amazon RDS, Google BigQuery, Snowflake를 비교해볼게요.

☁️ Amazon RDS: 친숙한 RDB를 클라우드로

  • MySQL, PostgreSQL, MariaDB, Oracle, SQL Server 등 다양한 관계형 DB를 클라우드에서 관리할 수 있어요.
  • AWS 콘솔로 인스턴스 생성, 백업, 스냅샷, 보안 설정까지 클릭 몇 번이면 끝!
  • 웹 서비스 백엔드, ERP, 내부 업무 시스템에 잘 어울립니다.

📊 Google BigQuery: 쿼리 하나로 수천만 행을!

  • 수십 테라바이트까지도 몇 초 내로 분석할 수 있는 강력한 분석 전용 DB입니다.
  • SQL로 데이터 처리, 머신러닝 모델 학습까지도 가능한 서버리스 기반 플랫폼!
  • 실시간 대시보드, 마케팅 분석, IoT 센서 데이터 분석에 자주 쓰여요.

❄️ Snowflake: 멀티 클라우드 분석의 강자

  • AWS, GCP, Azure 모두 지원하는 멀티 클라우드 분석 DB입니다.
  • 스토리지와 컴퓨팅이 완전히 분리되어 있어 비용 효율성 + 유연성 모두 챙길 수 있어요.
  • 데이터 웨어하우징, 크로스 플랫폼 분석에 특화되어 있습니다.

🔍 DBaaS 3종 비교 요약

서비스 특징 활용 사례
Amazon RDS 관계형 DB 클라우드 관리형 서비스 웹앱, ERP, 내부시스템
Google BigQuery 대용량 데이터 분석 전용, 서버리스 실시간 분석, ML, 마케팅
Snowflake 멀티 클라우드, 스토리지/컴퓨팅 분리 데이터 웨어하우징, 플랫폼 간 연동

이처럼 DBaaS는 단순한 데이터 저장소를 넘어, 분석과 머신러닝, 확장성과 유연성을 고려한 플랫폼으로 진화하고 있습니다.

만약 클라우드에서 손쉽게 DB를 관리하고 싶다면, 위 3가지 중에서 프로젝트 성격에 맞는 걸 골라보세요. 😎

 

 

6. 프로젝트 유형별 추천 DB 시나리오 정리 🎯

지금까지 다양한 데이터베이스 종류를 살펴봤는데요,

이제 정말 중요한 건, "내 프로젝트에 어떤 DB를 선택해야 하는가?" 하는 거죠.

여기서는 실무에서 자주 등장하는 프로젝트 유형을 기준으로 추천 DB를 정리해볼게요.

🛒 쇼핑몰, 커뮤니티 사이트

  • MySQL / MariaDB: 웹 개발 프레임워크와 궁합이 좋고, 개발 자료도 풍부해요.
  • Redis: 장바구니, 세션 관리용으로 함께 사용하면 성능 향상됩니다.

📊 데이터 분석, BI 플랫폼

  • PostgreSQL: 복잡한 쿼리, 대용량 집계에 탁월해요.
  • BigQuery / Snowflake: 클라우드에서 실시간 분석, 대규모 처리에 최적화.

📱 모바일/IoT/로컬 앱

  • SQLite: 앱에 내장하기 좋고, 별도 서버 없이 동작 가능해요.
  • MongoDB / Firebase: 유연한 데이터 구조와 빠른 변경에 적합합니다.

🤖 AI, 추천, 검색 서비스

  • Milvus / Weaviate / Qdrant: 임베딩 기반 유사도 검색에 필수!
  • Elasticsearch: 텍스트 기반 검색 기능 구현에 매우 유리해요.

🔐 보안성과 관계 중심 분석이 중요한 서비스

  • Neo4j: 관계 기반 탐색이 중요한 사기 탐지, 추천 시스템에 최적화.
  • PostgreSQL: 복잡한 규칙과 조건이 필요한 트랜잭션 처리에 강력합니다.

결론적으로,

정해진 정답은 없지만, 프로젝트의 성격에 따라 각 데이터베이스의 특장점을 적극 활용하면 개발 효율과 성능을 극대화할 수 있어요.

 

이제 마지막 마무리 단계에서 오늘의 핵심을 요약하고, 여러분의 선택을 응원해볼게요! 🙌

 

 

마무리 ✍️

지금까지 다양한 데이터베이스 종류와 각각의 활용 케이스를 자세히 살펴봤습니다.

관계형 DB vs NoSQL, 벡터 DB와 그래프 DB까지 비교하면서 어떤 DB가 여러분의 프로젝트에 가장 적합할지 가늠할 수 있는 기준을 세워봤는데요.

결국 중요한 건 내 프로젝트의 성격과 요구사항입니다.

무작정 성능 좋은 DB, 요즘 핫한 DB를 쫓기보단, 규모, 사용 목적, 데이터 구조 등을 꼼꼼히 따져서 선택해야 최적의 결과를 얻을 수 있어요.

 

만약 지금도 고민된다면 이렇게 질문해보세요.

  • 이 프로젝트에서 가장 중요한 건 속도인가요? 정합성인가요?
  • 데이터 구조는 자주 바뀌나요, 아니면 고정되어 있나요?
  • 향후 확장이 예상되나요? 아니면 단기 프로젝트인가요?

이런 질문들을 바탕으로 DB를 선택하면, 개발 후 후회하는 일은 훨씬 줄어들 거예요 😊

 

지금 시작하는 작은 프로젝트가 나중엔 수십만 명이 사용하는 서비스가 될 수도 있잖아요?

그 첫걸음을 좋은 데이터베이스 선택으로 시작해보세요!

반응형

+ Recent posts