Files
markbase/markbase-raid/src/raid/level_1.rs
Warren 1300a4e223
Some checks failed
Test / test (push) Has been cancelled
Test / build (push) Has been cancelled
MarkBase架构升级:Multi-Volume Virtual Tree + Dual-View Management + Git Remote修正
核心功能:
-  Categories/Series双视图管理(category_view.rs + import_markdown.rs)
-  FUSE Multi-Volume支持(tree_type参数)
-  SSH/SFTP/SCP/rsync协议完整实现(4042行)
-  NFS/SMB Module Phase 1-3完成
-  Archive Module Phase 1-4完成(2916行)
-  Download Center API完整实现
-  S3兼容API实现(560行)

Git配置修正:
-  删除错误origin(gitea.momentry.ddns.net)
-  删除m5max128(指向机器名)
-  设置origin = m5max128gitea.momentry.ddns.net/admin/markbase
-  设置m4minigitea = m4minigitea.momentry.ddns.net/warren/markbase

数据清理:
-  删除38个临时SQLite(保留accusys.sqlite、demo.sqlite)
-  删除.bak、test_*.bin、调试脚本等临时文件
-  删除临时目录(build/、download files/、raid_test/等)
-  更新.gitignore排除临时文件

架构优化:
- 52个文件修改,2434行新增,4739行删除
- Workspace成员整合(16个crate)
- 数据库状态:accusys.sqlite保留(主demo测试)

远程同步:
-  准备推送到m5max128gitea(远程Gitea)
-  准备推送到m4minigitea(本地Gitea)
2026-06-12 12:59:54 +08:00

60 lines
1.5 KiB
Rust

use super::controller::RaidArray;
use super::{MemberStatus, RaidAlgorithm, RaidError, RaidLevel};
use std::sync::Arc;
pub struct Raid1 {
array: Arc<RaidArray>,
}
impl Raid1 {
pub fn new(array: Arc<RaidArray>) -> Self {
Raid1 { array }
}
}
impl RaidAlgorithm for Raid1 {
fn read(&mut self, block_offset: u64, size: u64) -> Result<Vec<u8>, RaidError> {
let member = &self.array.members[0];
if member.status != MemberStatus::Online {
return Err("Member offline".into());
}
let file = std::fs::File::open(&member.device_path)?;
use std::io::{Read, Seek};
let mut file = file;
file.seek(std::io::SeekFrom::Start(block_offset))?;
let mut buffer = vec![0u8; size as usize];
file.read_exact(&mut buffer)?;
Ok(buffer)
}
fn write(&mut self, block_offset: u64, data: &[u8]) -> Result<(), RaidError> {
for member in &self.array.members {
if member.status != MemberStatus::Online {
continue;
}
let file = std::fs::OpenOptions::new()
.write(true)
.open(&member.device_path)?;
use std::io::{Seek, Write};
let mut file = file;
file.seek(std::io::SeekFrom::Start(block_offset))?;
file.write_all(data)?;
}
Ok(())
}
fn get_total_size(&self) -> u64 {
self.array.total_size
}
fn get_level(&self) -> RaidLevel {
RaidLevel::RAID1
}
}