본문 바로가기
IT/Nas

[Nas] Nextcloud S3 스토리지 연동: 성능, 비용 효율성 심층 분석

by 수누다 2026. 6. 3.

안녕하세요, 13년차의 서버실 주인장입니다. 오늘은 제가 홈랩에서 정말 유용하게 쓰고 있는 Nextcloud와 S3 스토리지 연동에 대한 이야기를 해보려고 합니다. 사실 처음 Nextcloud를 구축했을 때, 저장 공간 확장에 대한 고민이 많았거든요. 로컬 디스크는 언젠가 한계에 부딪히기 마련이고, 안정성과 확장성을 모두 잡으려면 뭔가 다른 방법이 필요했습니다. 혹시 여러분도 이런 고민 해보신 적 있으신가요?

그래서 제가 직접 여러 방법을 탐색하고 삽질해본 끝에, Nextcloud S3 스토리지 연동이 가장 합리적인 해결책이라는 결론에 도달했습니다. 특히 MinIO 같은 S3 호환 오브젝트 스토리지를 활용하면, 비용 효율적으로 대용량 스토리지를 구축하면서도 성능까지 잡을 수 있다는 걸 깨달았죠. 오늘은 그 경험을 바탕으로 Nextcloud와 S3 스토리지 연동의 A부터 Z까지, 그리고 성능과 비용 효율성을 어떻게 분석하고 최적화할 수 있는지 심층적으로 파헤쳐 보겠습니다.

Nextcloud와 S3 오브젝트 스토리지 연동의 전체 아키텍처 개요

Nextcloud S3 스토리지 연동의 전체 아키텍처 개요입니다.

Nextcloud와 S3 오브젝트 스토리지, 왜 중요할까요?

먼저, 핵심 개념부터 짚고 넘어가겠습니다. Nextcloud는 오픈 소스 기반의 개인 클라우드 솔루션입니다. Dropbox나 Google Drive처럼 파일을 저장하고 공유하며, 캘린더, 연락처, 문서 편집 등 다양한 기능을 웹 인터페이스를 통해 제공하죠. 제가 이걸 홈랩에 구축해서 가족 사진이나 문서 백업용으로 아주 잘 쓰고 있거든요.

그럼 S3 오브젝트 스토리지(Object Storage)는 뭘까요? 쉽게 말해, 파일을 '오브젝트'라는 단위로 저장하는 방식입니다. 기존의 파일 시스템처럼 계층 구조가 아니라, 고유한 키(Key)를 통해 데이터를 관리하는데요. Amazon Web Services(AWS)의 S3가 가장 대표적인 서비스인데, 저는 홈랩 환경에서 S3 API를 지원하는 MinIO를 주로 사용합니다. MinIO는 온프레미스 환경이나 클라우드에서 직접 S3 호환 오브젝트 스토리지를 구축할 수 있게 해주는 솔루션이거든요. 마치 AWS S3를 내 서버에 직접 설치해서 쓰는 느낌이라고 생각하시면 됩니다.

✅ Nextcloud + S3 연동의 장점

  • 무한한 확장성(Scalability): S3는 이론적으로 무한대에 가까운 저장 공간을 제공합니다. 디스크를 추가하거나 서버를 교체할 필요 없이 필요한 만큼 용량을 늘릴 수 있어요.
  • 높은 안정성(Durability): 데이터가 여러 노드에 분산 저장되기 때문에, 특정 디스크나 서버에 문제가 생겨도 데이터 손실 위험이 적습니다. MinIO도 분산 모드로 구성하면 이 장점을 누릴 수 있죠.
  • 비용 효율성(Cost-Effectiveness): 사용한 만큼만 비용을 지불하는 종량제 모델이라, 초기 투자 비용 부담이 적습니다. 특히 MinIO는 오픈 소스라 소프트웨어 비용이 들지 않고요.
  • 성능 최적화: S3는 대규모 분산 환경에 최적화되어 있어, 적절히 구성하면 빠른 데이터 접근 속도를 기대할 수 있습니다.

MinIO를 활용한 Nextcloud S3 스토리지 연동 실전 가이드

자, 이제 실제로 Nextcloud에 S3 스토리지를 연동하는 방법을 알아보겠습니다. 저는 주로 Docker Compose를 사용해서 MinIO를 구축하는데요, 이게 제일 빠르고 간편하더라고요.

1단계: MinIO 서버 구축 (Docker Compose)

먼저 MinIO 서버를 준비해야 합니다. 저는 MinIO 공식 문서를 참고해서 Docker Compose 파일을 만들었어요. 아래처럼 docker-compose.yaml 파일을 생성해줍니다.


version: '3.8'
services:
  minio:
    image: quay.io/minio/minio:latest
    ports:
      - "9000:9000"
      - "9001:9001"
    environment:
      MINIO_ROOT_USER: minioadmin # 관리자 사용자 이름 (꼭 바꿔주세요!)
      MINIO_ROOT_PASSWORD: minioadminpassword # 관리자 비밀번호 (꼭 바꿔주세요!)
      MINIO_SERVER_URL: "http://minio.yourdomain.com:9000" # MinIO 서버 URL
    command: server /data --console-address ":9001"
    volumes:
      - ./minio_data:/data # MinIO 데이터가 저장될 경로
    healthcheck:
      test: ["CMD", "curl", "-f", "http://localhost:9000/minio/health/live"]
      interval: 30s
      timeout: 20s
      retries: 3

위 파일에서 MINIO_ROOT_USERMINIO_ROOT_PASSWORD반드시 강력한 비밀번호로 변경해주세요! 그리고 ./minio_data 경로는 실제 MinIO 데이터가 저장될 디렉터리입니다. 저는 보통 /mnt/minio_data 같은 경로로 지정해서 영구 저장소를 사용하곤 합니다. 파일 생성 후, 아래 명령어로 MinIO를 실행합니다.


docker compose up -d

MinIO가 실행되면 http://your_server_ip:9001로 접속해서 웹 콘솔에 로그인할 수 있습니다. 여기서 버킷(Bucket)을 생성해줘야 하는데요, Nextcloud에서 사용할 버킷을 미리 만들어두면 편리합니다. 예를 들어 nextcloud-bucket이라는 이름으로 생성해볼게요.

2단계: Nextcloud S3 External Storage 설정

이제 Nextcloud 관리자 페이지에서 외부 스토리지를 연결할 차례입니다. Nextcloud에 로그인한 후, 관리자 설정(Settings) > 관리(Administration) > 외부 저장소(External storages) 메뉴로 이동합니다. 여기서 새로운 저장소를 추가합니다.

  1. 폴더 이름(Folder name): Nextcloud 내에서 보일 폴더 이름입니다. 예를 들어 S3 Storage라고 입력합니다.
  2. 외부 저장소(External storage): 드롭다운에서 Amazon S3 compatible을 선택합니다.
  3. 인증(Authentication): Access key & secret key를 선택합니다.
  4. 버킷(Bucket): MinIO에서 생성한 버킷 이름을 입력합니다 (예: nextcloud-bucket).
  5. 호스트(Hostname): MinIO 서버의 IP 주소 또는 도메인과 포트 번호를 입력합니다 (예: your_minio_server_ip:9000).
  6. 포트(Port): MinIO 서비스 포트 (예: 9000).
  7. SSL/TLS 사용(Enable SSL/TLS): MinIO에 SSL/TLS를 적용했다면 체크합니다. 홈랩에서는 처음에는 HTTP로 시작하고, 나중에 Traefik 같은 리버스 프록시를 통해 SSL을 적용하는 경우가 많습니다.
  8. 버킷 URL(Bucket URL): MinIO 콘솔에서 확인할 수 있는 버킷의 URL을 입력합니다. (예: http://your_minio_server_ip:9000/nextcloud-bucket)
  9. 액세스 키(Access key): MinIO 설정 시 사용했던 MINIO_ROOT_USER (또는 새로 생성한 사용자)
  10. 시크릿 키(Secret key): MinIO 설정 시 사용했던 MINIO_ROOT_PASSWORD (또는 새로 생성한 사용자 비밀번호)
Nextcloud 외부 저장소 설정 화면: MinIO 정보 입력 예시

Nextcloud 외부 저장소 설정 화면입니다. MinIO 정보를 정확히 입력하는 것이 중요해요.

모든 정보를 입력하고 나면, 초록색 체크 표시가 뜨면서 정상적으로 연결되었음을 확인할 수 있을 겁니다. 만약 빨간색 X 표시가 뜬다면, 뭔가 잘못된 거겠죠? ⚠️

⚠️ 삽질 경험: "Failed to connect to S3" 에러

제가 이 과정에서 가장 많이 겪었던 삽질 중 하나가 바로 "Failed to connect to S3" 에러였습니다. 처음엔 MinIO 서버가 문제인가 싶어서 MinIO 로그만 계속 들여다봤거든요. 근데 알고 보니 Nextcloud 서버에서 MinIO 서버로의 네트워크 연결 문제인 경우가 많더라고요.

트러블슈팅 팁:

  1. 방화벽 확인: Nextcloud 서버에서 MinIO 서버의 9000번 포트(API)와 9001번 포트(콘솔)로의 아웃바운드 연결이 허용되어 있는지 확인하세요. MinIO 서버에서도 인바운드 연결이 허용되어야 합니다.
  2. 네트워크 연결 테스트: Nextcloud 서버에서 curl http://your_minio_server_ip:9000 명령어를 실행해서 MinIO API에 접근 가능한지 테스트해보세요.
  3. SSL/TLS 설정 확인: MinIO에 SSL/TLS를 적용했는데 Nextcloud 설정에서 "Enable SSL/TLS"를 체크하지 않았거나, 그 반대의 경우에도 연결 오류가 발생합니다. 특히 홈랩에서 자가 서명(self-signed) 인증서를 사용하는 경우, Nextcloud가 해당 인증서를 신뢰하지 못해서 문제가 생길 수 있어요. 이럴 때는 Nextcloud 서버에 MinIO의 CA 인증서를 등록해주거나, 테스트 목적으로는 "SSL/TLS 사용"을 잠시 끄고 시도해볼 수도 있습니다 (운영 환경에서는 절대 권장하지 않습니다!).
  4. 액세스 키/시크릿 키 오타: 너무 기본적인 실수지만, 의외로 많이 하는 실수입니다. 대소문자 구분도 중요하니 꼼꼼하게 확인해주세요.
  5. 버킷 이름 확인: MinIO에 생성한 버킷 이름과 Nextcloud에 입력한 버킷 이름이 정확히 일치하는지 확인해야 합니다.

이런 문제들을 하나씩 해결해가면서 드디어 초록색 체크 표시를 봤을 때의 그 쾌감이란! 🎉 여러분도 꼭 성공하시길 바랍니다.

Nextcloud S3 연동 결과 검증 및 성능 분석

연동이 완료되었다면, 이제 Nextcloud 웹 인터페이스에서 S3 Storage라는 이름의 폴더가 보일 겁니다. 여기에 파일을 업로드해보세요. 파일이 MinIO 버킷으로 정상적으로 업로드되는지 MinIO 콘솔에서도 확인해볼 수 있습니다.

Nextcloud에 마운트된 S3 스토리지 폴더와 업로드된 파일 목록

Nextcloud에 성공적으로 마운트된 S3 스토리지와 업로드된 파일들입니다.

성능 분석: 기대와 현실

저는 Nextcloud를 S3에 연동한 후, 로컬 스토리지와 비교해서 파일 업로드/다운로드 성능을 직접 테스트해봤습니다. 결론부터 말씀드리면, "대용량 파일"이나 "다수의 작은 파일" 처리에서 S3 연동의 이점을 명확히 느낄 수 있었습니다.

  • 대용량 파일(Large Files): 단일 대용량 파일(예: 1GB 이상)의 경우, MinIO가 백엔드 디스크의 성능을 충분히 활용하면서도 Nextcloud 서버의 I/O 부하를 줄여주기 때문에, 체감 성능이 로컬 디스크와 크게 다르지 않거나 오히려 더 안정적인 모습을 보여주기도 했습니다. 특히 MinIO를 분산 환경으로 구성하면 여러 노드가 병렬로 처리하여 더욱 빠르죠.
  • 다수의 작은 파일(Many Small Files): 수천, 수만 개의 작은 파일을 업로드할 때는 S3 오브젝트 스토리지의 특성상 메타데이터 처리 오버헤드가 발생할 수 있습니다. 하지만 Nextcloud의 캐싱 메커니즘과 MinIO의 최적화 덕분에, 일반적인 사용 환경에서는 큰 불편함 없이 사용할 수 있었습니다. 다만, 파일 동기화 클라이언트에서 초기 동기화 시에는 시간이 좀 더 걸릴 수 있습니다.
  • 랜덤 액세스(Random Access): Nextcloud가 S3에 저장된 파일을 스트리밍하거나 부분적으로 액세스할 때, S3의 바이트 범위 요청(Byte-range requests) 기능 덕분에 효율적으로 동작합니다. 이건 로컬 디스크와 거의 동일한 사용자 경험을 제공해줍니다.

결론적으로, Nextcloud와 S3의 연동은 파일 I/O 성능보다는 안정성, 확장성, 그리고 관리 용이성 측면에서 큰 이점을 가져다줍니다. 특히 Nextcloud 서버의 디스크 용량 고민에서 해방될 수 있다는 점이 정말 매력적이었어요.

비용 효율성 심층 분석

비용 효율성은 S3 스토리지 연동의 핵심 이유 중 하나입니다. 제가 홈랩에서 MinIO를 쓰는 주된 이유도 바로 이것인데요.

MinIO (온프레미스 S3) vs. Public Cloud S3 (AWS S3)

저처럼 홈랩에서 MinIO를 운영한다면, 초기 하드웨어 투자 비용(서버, 디스크)은 발생하지만, 그 이후에는 데이터 저장량에 따른 추가 비용이 거의 들지 않습니다. 전기세 정도가 들겠네요. 장기적으로 대용량 데이터를 저장할 계획이라면 매우 비용 효율적인 선택이 될 수 있습니다.

반면 AWS S3 같은 퍼블릭 클라우드 서비스를 이용하면, 초기 하드웨어 투자 없이 바로 사용할 수 있습니다. 하지만 데이터 저장량(Storage), 데이터 전송량(Data Transfer), API 요청(Requests)에 따라 요금이 부과됩니다. 특히 데이터 전송량(특히 Ingress/Egress, 외부로 나가는 트래픽) 요금이 예상보다 많이 나올 수 있으니, 요금 구조를 잘 이해하고 사용해야 합니다.

구분 로컬 디스크 (Nextcloud 기본) MinIO (온프레미스 S3) AWS S3 (퍼블릭 클라우드)
확장성 제한적 (서버 디스크 용량에 의존) 높음 (스케일 아웃 가능) 매우 높음 (무제한에 가까움)
안정성 단일 서버 장애에 취약 분산 구성 시 높음 매우 높음 (다중 가용영역)
초기 비용 디스크 구매 비용 서버/디스크 구매 비용 없음 (클라우드 서비스)
운영 비용 전기세, 유지보수 전기세, 유지보수 저장량, 전송량, 요청 수에 따라 과금
성능 서버 I/O 성능에 직접 영향 백엔드 스토리지 성능에 영향, 분산 시 향상 대규모 분산 환경에 최적화
관리 편의성 쉬움 중간 (직접 구축/관리) 쉬움 (클라우드 제공)
Nextcloud 스토리지 옵션(로컬, MinIO, AWS S3)의 비용 및 성능 특성 비교표

Nextcloud 스토리지 옵션별 주요 특성 비교표입니다. 각 환경에 맞는 최적의 선택을 할 수 있도록 도와줍니다.

개인적으로는 MinIO를 홈랩에 구축하고, 중요한 데이터는 퍼블릭 클라우드 S3에 백업하는 하이브리드 전략을 추천합니다. 이렇게 하면 비용과 안정성을 동시에 잡을 수 있거든요. 저는 MinIO에 가족 사진을 저장하고, 이 MinIO 버킷을 다시 AWS S3 Glacier Deep Archive 같은 저렴한 스토리지 클래스에 비동기적으로 백업하는 식으로 활용하고 있습니다.

마무리하며: 얻은 교훈과 다음 단계

오늘은 Nextcloud와 S3 오브젝트 스토리지 연동에 대해 심층적으로 다뤄봤습니다. 제가 직접 경험하며 배운 점들을 정리해보자면 이렇습니다.

  • 확장성과 안정성: Nextcloud의 저장 공간 고민을 S3 연동으로 깔끔하게 해결할 수 있었습니다. 로컬 디스크의 한계를 넘어서는 유연함을 제공하죠.
  • MinIO의 매력: 홈랩 환경에서 S3 호환 스토리지를 구축하기에 MinIO는 정말 훌륭한 선택입니다. 오픈 소스라 비용 부담도 적고, 직접 관리하는 재미도 있고요.
  • 트러블슈팅은 기본: 역시 인프라 엔지니어의 숙명은 삽질 후 해결이죠! 네트워크, 방화벽, 인증서 문제는 늘 꼼꼼하게 확인해야 합니다.
  • 비용과 성능의 균형: 퍼블릭 클라우드 S3와 온프레미스 MinIO의 장단점을 잘 이해하고 자신의 환경에 맞는 최적의 솔루션을 선택하는 지혜가 필요합니다.

이 글을 통해 Nextcloud S3 스토리지 연동에 대한 궁금증이 해소되고, 여러분의 홈랩이나 서버실 운영에 도움이 되었으면 좋겠습니다. 다음번에는 MinIO 클러스터 구성으로 고가용성(High Availability)을 확보하는 방법이나, Nextcloud 성능 최적화를 위한 Redis 캐싱 설정에 대해 다뤄볼까 합니다. 그때까지 다들 즐거운 삽질(?) 되시길 바랍니다! 궁금한 점이 있다면 언제든지 댓글로 남겨주세요.