최근 수정 시각 : 2024-02-11 20:01:49

Btrfs

파일 시스템
{{{#!wiki style="margin: 0 -10px -5px; min-height: 26px"
{{{#!folding [ 펼치기 · 접기 ]
{{{#!wiki style="margin: -6px -1.5px -13px"
마이크로소프트 FAT NTFS ReFS
애플 HFS HFS+ APFS
리눅스/유닉스 ext2 ext3 ext4
Btrfs F2FS XFS ZFS
}}}}}}}}} ||

1. 개요2. 특징3. 주의사항4. 기타


B-tree file system
Btrfs 문서 (영문)

1. 개요

오픈소스 커뮤니티에서 개발하는 유닉스/ 리눅스용 파일 시스템으로, 주요 기여자는 SUSE, 메타, 웨스턴 디지털, 오라클 등이다.

2. 특징

  • 가볍다.
  • B-Tree[1] 기반
  • Copy-On-Write[2]
  • 빈 공간 캐시, inode 캐시 지원
  • 자동 조각모음
  • 공간 압축: 작은 파일들을 한 섹터에 몰아넣는다.
  • 데이터 압축: zlib, LZO, z-standard 압축 알고리즘 지원
  • SSD 최적화: TRIM과는 상관없다. [3]
  • 서브볼륨 관리: 각각의 서브볼륨을 파티션처럼 취급 가능
  • 스냅샷 관리: 볼륨을 통째로 박제한다. 파일을 스냅샷으로 저장해두었던 상태로 쉽게 되돌릴수 있어 랜섬웨어 대응이나 백업 용도로 매우 좋으며, 증분 백업도 지원한다. 설정 예시
  • 파티션 테이블이 없는 BtrFS 디스크: 파티션 테이블이 없는 BtrFS 디스크를 지원한다. 단 GRUB에서 사용을 권장하지 않는다.
  • 데이터 중복제거(Data deduplication)

3. 주의사항

  • 4K로 정렬된 디스크에서 최적의 속도를 발휘한다. MBR 디스크는 섹터 정렬에 주의해야 한다.
  • swap 파일 기능은 리눅스 5.0 이상부터 사용이 가능하며, swap 파일의 Copy-On-Write를 비활성화해야 한다. btrfs에서의 swap 파일 생성 방법
  • LILO나 구버전 GRUB이나 구버전 리눅스 커널에서는 부트로더가 btrfs 파티션을 읽지 못하는 문제가 종종 있다. btrfsprog를 설치하고 initramfs를 다시 생성해도 안되는 경우 적절한 용량[4]의 파티션을 하나 파서 /boot로 할당해 FAT32(vfat)로 포맷하고 여기다가 부트로더를 물려주면 해결된다. /boot 디렉토리 파일들을 새로 판 파티션에 옮기는거 까먹으면 대략 낭패다. 잊지 말자! 어차피 UEFI 쓰면 ESP 잡느라 FAT32 파티션 하나 파야 하는거 처음부터 UEFI로 설치하자
  • 특이사항으로 레드햇 엔터프라이즈 리눅스 계열 배포판 ( CentOS 등)의 경우, RHEL 7에서 실험적으로 지원하기 시작하였으나 얼마 지나지 않은 RHEL 7.4부터 deprecated되었고 RHEL 8부터는 지원이 아예 제거되었다. 레드햇은 Btrfs 대신 Stratis XFS 조합을 밀고 싶어하는 모양새.
    • 반면 RHEL의 업스트림인 페도라에서는 2020년의 페도라 33부터 Btrfs가 파일시스템 기본값이 되었다.
    • 오라클의 RHEL 클론 배포판인 오라클리눅스 8 이상에서는 레드햇 호환 커널이 아닌 자체 커널(UEK)에서만 Btrfs를 지원한다.

4. 기타


[1] 자동으로 밸런싱이 가능한 데이터 정리 알고리즘. Binary tree 와는 다르다. [2] 쉽게 말해 파일을 복사해 동일한 파일을 만들 경우, 실제로는 새 파일을 만들지 않고 원래 파일을 그대로 사용한다. 파일을 수정할때 비로소 새 파일을 만들어서 쓰기 시작하며 그래서 이름이 copy, on write 이다. 사용 시나리오가 맞는다면 저장 공간과 복사용 디스크 IO시간을 크게 아낄 수 있다. [3] mount 옵션에도 TRIM 활성화인 discard와 별개로 SSD 최적화 알고리즘 활성화를 위한 ssd 옵션이 있다. [4] 일반적으로 256MB 정도가 좋다. [5] 흔히 ipTIME으로 알려져 있다.