[python] 파이썬 웹 서비스에서 사용되는 NoSQL 데이터베이스 솔루션
목차
MongoDB
MongoDB는 유연한 문서 지향 NoSQL 데이터베이스이며, JSON과 유사한 문서 형식으로 데이터를 저장합니다. 이를 통해 파이썬 웹 애플리케이션에서 쉽게 활용할 수 있습니다.
import pymongo
# MongoDB에 연결
client = pymongo.MongoClient("mongodb://localhost:27017/")
# 데이터베이스 및 컬렉션 생성
db = client["mydatabase"]
collection = db["mycollection"]
# 문서 삽입
data = {"name": "John", "age": 30}
collection.insert_one(data)
# 쿼리 실행
result = collection.find_one({"name": "John"})
print(result)
Redis
Redis는 메모리 기반의 키-값 저장소로, 데이터를 빠르게 캐싱하거나 임시 저장하는 데 사용됩니다. 특히 빠른 읽기 및 쓰기 작업을 지원하여 파이썬 웹 서비스의 성능을 향상시킬 수 있습니다.
import redis
# Redis에 연결
r = redis.StrictRedis(host='localhost', port=6379, db=0)
# 데이터 저장
r.set('name', 'Alice')
# 데이터 조회
result = r.get('name')
print(result)
Cassandra
Cassandra는 분산형 데이터베이스 시스템으로 대량의 데이터를 처리하는 데 용이합니다. 파티셔닝과 복제를 통해 안정적인 데이터 저장과 고가용성을 제공하여 파이썬 웹 서비스의 확장성을 높일 수 있습니다.
from cassandra.cluster import Cluster
# Cassandra에 연결
cluster = Cluster(['localhost'])
session = cluster.connect()
# 데이터베이스 생성 및 테이블 생성
session.execute("CREATE KEYSPACE my_keyspace WITH replication = {'class': 'SimpleStrategy', 'replication_factor': 1}")
session.execute("CREATE TABLE my_keyspace.my_table (id int PRIMARY KEY, data text);")
# 데이터 삽입
session.execute("INSERT INTO my_keyspace.my_table (id, data) VALUES (1, 'example data')")
# 데이터 조회
result = session.execute("SELECT * FROM my_keyspace.my_table WHERE id=1")
for row in result:
print(row.id, row.data)
저희가 살펴본 MongoDB, Redis, 그리고 Cassandra는 파이썬 웹 서비스에서 NoSQL 데이터베이스의 다양한 활용을 제공합니다. 각각의 용도와 특징에 따라 적절한 데이터베이스를 선택하여 웹 서비스의 성능과 확장성을 높일 수 있습니다.