Btrfs trên đầu mdadm raid10, hay btrfs raid10 trên các thiết bị trần?


9

Tôi có RAID10 được quản lý bởi mdadmvà tôi có hệ thống tập tin EXT4 trên đầu trang. Tuy nhiên, tôi thích BTRFS và muốn chuyển đổi hệ thống tập tin EXT4 sang BTRFS, nhưng tôi đã suy nghĩ về hiệu suất và khả năng bảo trì. Ví dụ với BTRFS, tôi không thể dễ dàng thấy trạng thái khi tôi xóa / thêm một đĩa khác vào mảng như tôi có thể với mdadm (hoặc có lẽ tôi chỉ không biết làm thế nào - tôi đã tìm kiếm thông qua các tài liệu BTRFS và không thể tìm thấy ).

Vì vậy, từ kinh nghiệm của bạn, lựa chọn nào tốt hơn:

  1. Để đơn giản chỉ cần chuyển đổi hệ thống tập tin EXT4 và để mdadm quản lý RAID10?

  2. Để thoát khỏi mdadm, và để BTRFS làm mọi thứ?

Câu trả lời:


11

Hãy để Btrfs làm mọi thứ.

Đối với một điều, Btrfs có mã phản chiếu tích hợp riêng của nó có thể thông minh hơn madm.

Tất nhiên, nếu một đĩa bị lỗi cứng trong cặp nhân đôi trong madm raid10, bạn có thể thay thế đĩa xấu và tiếp tục với cuộc sống của mình (mặc dù sau một bộ lệnh shell phức tạp). Vấn đề là nếu đĩa của bạn bị lỗi nhẹ hơn một chút: nếu một vài khối chỉ trả lại các bit sai thay vì đưa ra mã lỗi thích hợp cho một khối xấu, thì khi đọc dữ liệu bạn sẽ ngẫu nhiên nhận được dữ liệu xấu. Btrfs thông minh hơn thế: nó kiểm tra từng bit dữ liệu. Thành thật mà nói tôi không biết liệu nói đúng hơn "mọi nút BTree" hay "mọi khối", nhưng vấn đề là khi nó đọc một số dữ liệu từ một mảng được nhân đôi, nó sẽ kiểm tra tổng kiểm tra trước khi trả lại cho bạn quá trình sử dụng. Nếu tổng kiểm tra không khớp, nó sẽ phản chiếu gương khác trong mảng trước và nếu điều đó đưa ra tổng kiểm tra chính xác,

Wiki Btrfs đặc biệt đề cập đến câu hỏi của bạn :

Nếu Btrfs dựa vào trình ánh xạ thiết bị hoặc MD để phản chiếu, nó sẽ không thể giải quyết các lỗi tổng kiểm tra bằng cách kiểm tra bản sao được nhân đôi . Các lớp thấp hơn không biết tổng kiểm tra hoặc mức độ chi tiết của các khối hệ thống tệp và do đó chúng không thể xác minh dữ liệu mà chúng trả về.

Cuối cùng, ngay cả khi không có lợi thế đáng kể này, quy trình làm việc của dòng lệnh để xử lý các thiết bị Btrfs bị loại bỏ hoặc thêm vào là cực kỳ đơn giản. Tôi thậm chí không chắc chắn mình có thể nhận được các lệnh shell shell-mount-then-fix-your-filesystem của bạn, nhưng đối với Btrfs, nó được ghi lại rất rõ ràng trên trang nhiều thiết bị như:

mount -o degraded /dev/sdb /mnt
btrfs device delete missing /mnt

Tại thời điểm này nếu bạn có đủ dung lượng trên các đĩa còn lại, bạn luôn btrfs rebalancecó thể thực hiện và thực hiện với nó; không cần phải thay gương, vì bạn hoàn toàn cần phải làm với madm! Và nếu bạn muốn thay thế nó, bạn có thể làm btrfs device addđầu tiên.


3

BTRFS vẫn đang thử nghiệm và bạn có thể kết thúc với các tính năng "thú vị" nếu có sự cố. Nếu bạn thực sự có / muốn chạy btrfs thì sẽ an toàn hơn rất nhiều khi chạy nó trên đầu trang của một cuộc đột kích phần mềm hơn là chỉ chạy trực tiếp. Khi btrfs đáo hạn và đi vào sản xuất, điều này có thể không còn đúng nữa.


Khoảng một năm trước, tôi đã thử nghiệm thiết lập btrfs trong VM. Tôi đã có thể liên tục khóa kernel (!) Bằng cách làm rối với lệnh cân bằng lại. Thời gian đã trôi qua và hy vọng điều này đã được khắc phục.
Avery Payne
Khi sử dụng trang web của chúng tôi, bạn xác nhận rằng bạn đã đọc và hiểu Chính sách cookieChính sách bảo mật của chúng tôi.
Licensed under cc by-sa 3.0 with attribution required.