Linux入门攻坚——8、磁盘管理——btrfs文件系统及压缩解压缩和归档

本文主要是介绍Linux入门攻坚——8、磁盘管理——btrfs文件系统及压缩解压缩和归档,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Btrfs(B-tree),支持CoW,写时复制;

核心特性:
    多物理卷支持:btrfs可由多个底层物理卷组成:支持RAID,以联机添加、移除,修改
    写时复制更新机制(CoW):复制、更新及替换指针,而非“就地”更新;
    数据及元数据校验码:checksum
    子卷:sub_volume
    快照:支持快照的快照;
    透明压缩:

Centos6上默认没有安装。
centos7上:

使用btrfs --help可以查看帮助。

文件系统创建:
    mkfs.btrfs
        -L 'LABEL' :
        -d <type> :raid0,raid1raid5,raid6,raid10,single
        -m <profile>:raid0,raid1,raid5,raid6,raid10,single,dup
        -O <feature>
            -O list-all:列出支持的所有feature;

systemctl set-default multi-user.target    设置默认字符界面启动

不需要分区,直接将磁盘做成btrfs系统   ,添加三块磁盘:

直接格式化btrfs:

属性查看:
        btrfs filesystem show


使用blkid查看:

UUID相同,说明都是同一个btree卷,但是子卷是不同的。所以btrfs支持多物理卷。
查看卷标:

挂载文件系统:
        mount -t btrfs /dev/sdb MOUNT_POINT
       
挂载的设备可以是btr卷中的任意一个物理卷名,如这里的/dev/dec,也可以使用/dev/sdd,结果一样,mount显示的挂载设备是序列号最小的物理卷。

使用/dev/sdd挂载,结果一样:

透明压缩机制:
        mount -o compress={lzo | zlib} DEVICE MOUNT_POINT

特性中多了compress=lzo。压缩解压缩是自动且对用户是透明的。

btrfs系统原生支持RAID。
直接联机修改大小:
btrfs filesystem resize [-|+]size MOUNT_POINT


使用max,直接调整到最大物理卷容量。

添加新的物理设备:
btrfs device add DEVICE MOUNT_POINT

自动扩展了。
使文件均衡保存,即均衡操作:
btrfs balance status /mybtr  :显示均衡状态
btrfs balance start  /mybtr :启动均衡操作

移除物理设备:
btrfs device delete /dev/sdd /mybtr 

修改数据、元数据等的底层存储的RAID级别。
btrfs balance start -mconvert=raid5 /mybtr

子卷管理:
btrfs subvolume list /mybtr :显示子卷
btrfs subvolume create /mybtr/logs  :创建logs子卷

挂载父卷时,同时会挂载子卷:

也可以单独挂载子卷:
btrfs -o subvol=logs DEVICE MOUNT_POINT

显示子卷的信息:btrfs subvolume show MOUNT_POINT

mount -o subvolid=subvolume_id /dev/sdd /btrsub,如上面显示的subvolume ID为264,可以如下挂载:

删除子卷:

创建快照:

创建logs的快照logs_snapshot,文件及内容相同。

修改/mybtr/logs/grub2.cfg,保存,此时在快照中的文件内容不变。

对单个文件创建快照:cp --reflink grub2.cfg grub2.cfg_snap

快照要在当前卷或其子目录下。修改grub2.cfg,快照grub2.cfg_snap保持不变。

文件系统的转换,将ext转换为btrfs:
先创建一个分区,格式化为ext4:

要转化文件系统,先卸载,在检测,最后转换:

.

回滚到ext系统:

btrfs子命令:filesystem、device、balance、subvolume等

压缩、解压缩及归档工具

compress/uncompress:.Z
gzip/gunzip:.gz
bzip2/bunzip2:.bz2
xz/unxz:.xz
zip/unzip:.zip
tar,cpio

1、gzip/gunzip
gzip [OPTION] FILE
    -d:解压缩,相当于gunzip
    -c:将结果输出至标准输出,gzip -c FILE > FILE.gz将保留源文件
    -#:指定压缩比,1-9
压缩:gzip FILE

解压缩:gunzip FILE.gz

压缩后,源文件删除,解压缩后,压缩文件删除,节省空间。

zcat:不显示展开的前提下查看文本文件内容;

2、bzip2/bunzip2/bzcat
bzip2 [OPTION] FILE
    -k:保留源文件
    -d:解压缩
    -#:1-9,压缩比

3、xz/unxz/xzcat
xz [OPTION] FILE
    -k:保留源文件
    -d:解压缩
    -#:1-9,压缩比

对目录进行压缩,只能压缩目录中的文件:

4、tar
tar [OPTION]... 
(1)创建归档
    tar -c -f /PATH/TO/SOMEFILE.tar FILE...
    tar -cf  /PATH/TO/SOMEFILE.tar FILE...
(2)查看归档文件中的文件列表
    tar -t -f /PATH/TO/SOMEFILE.tar
(3)展开归档
    tar -x -f /PATH/TO/SOMEFILE.tar
    tar -x -f /PATH/TO/SOMEFILE.tar -C /PATH/OTHER

归档后文件大小可能变大,归档不是压缩,可以在归档的同时再压缩。

结合压缩工具实现归档并压缩,使用归档的如下选项:
    -j:bzip2,-z:gzip,-J:xz

bash脚本编程:

循环:for,while,until
    循环体:要执行的代码,可能要执行 n遍
        进入条件、退出条件

for循环:
    for 变量名 in 列表;do
        循环体
     done
执行机制:依次将列表中的元素赋值给“变量名”;每次赋值后即执行一次循环体;直到列表中的元素耗尽,循环结束。

  1 #!/bin/bash2 #3 4 if [ ! $UID -eq 0 ]; then5     echo "Only root."6     exit 17 fi8 for username in user1 user2 user3; do9     if id $username &> /dev/null; then10         echo "$username exists."11     else12         useradd $username13         if [ $? -eq 0 ]; then14             echo "$username" | passwd --stdin $username &> /dev/null15             echo "Add $username finished."16         fi17     fi18 done

列表:
    1) 直接给出列表,用空格隔开的序列
    2) 整数列表:{start..end} 如{1..10},$(seq [start] [step] end),如$(seq 2 3 10)
    3) 返回列表的命令:$(COMMAND),如 $(ls /var)
    4) glob通配机制
    5) 变量引用:$@,$*

这篇关于Linux入门攻坚——8、磁盘管理——btrfs文件系统及压缩解压缩和归档的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/498996

相关文章

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Hadoop集群数据均衡之磁盘间数据均衡

生产环境,由于硬盘空间不足,往往需要增加一块硬盘。刚加载的硬盘没有数据时,可以执行磁盘数据均衡命令。(Hadoop3.x新特性) plan后面带的节点的名字必须是已经存在的,并且是需要均衡的节点。 如果节点不存在,会报如下错误: 如果节点只有一个硬盘的话,不会创建均衡计划: (1)生成均衡计划 hdfs diskbalancer -plan hadoop102 (2)执行均衡计划 hd

linux-基础知识3

打包和压缩 zip 安装zip软件包 yum -y install zip unzip 压缩打包命令: zip -q -r -d -u 压缩包文件名 目录和文件名列表 -q:不显示命令执行过程-r:递归处理,打包各级子目录和文件-u:把文件增加/替换到压缩包中-d:从压缩包中删除指定的文件 解压:unzip 压缩包名 打包文件 把压缩包从服务器下载到本地 把压缩包上传到服务器(zip

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

hdu1565(状态压缩)

本人第一道ac的状态压缩dp,这题的数据非常水,很容易过 题意:在n*n的矩阵中选数字使得不存在任意两个数字相邻,求最大值 解题思路: 一、因为在1<<20中有很多状态是无效的,所以第一步是选择有效状态,存到cnt[]数组中 二、dp[i][j]表示到第i行的状态cnt[j]所能得到的最大值,状态转移方程dp[i][j] = max(dp[i][j],dp[i-1][k]) ,其中k满足c

综合安防管理平台LntonAIServer视频监控汇聚抖动检测算法优势

LntonAIServer视频质量诊断功能中的抖动检测是一个专门针对视频稳定性进行分析的功能。抖动通常是指视频帧之间的不必要运动,这种运动可能是由于摄像机的移动、传输中的错误或编解码问题导致的。抖动检测对于确保视频内容的平滑性和观看体验至关重要。 优势 1. 提高图像质量 - 清晰度提升:减少抖动,提高图像的清晰度和细节表现力,使得监控画面更加真实可信。 - 细节增强:在低光条件下,抖

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

数论入门整理(updating)

一、gcd lcm 基础中的基础,一般用来处理计算第一步什么的,分数化简之类。 LL gcd(LL a, LL b) { return b ? gcd(b, a % b) : a; } <pre name="code" class="cpp">LL lcm(LL a, LL b){LL c = gcd(a, b);return a / c * b;} 例题: