• linux(3)磁盘与文件系统管理/查看硬盘、内存空间/文件系统的操作/ 文件的压缩和打包


    一.磁盘与文件系统管理

    1.分区与文件系统
    分区:记录每一个分区的开始柱面和结束柱面
    主引导区(master boot recorder):记录分区的数据,记录硬盘里所有的分区信息
    分区划分好后,要将分区格式化为系统可以识别的文件系统
    磁盘的最小物理存储单位是:扇区
    分区时格式化文件系统的最小存储单位:逻辑块,以扇区为基础,大小为2的n次方,但是一个块只能容纳一个文件
    linux的ext2文件系统每个文件内容分为两部分:存储文件的属性(放在inode中),文件的内容(放在块中)

    例:

    读取文件系统的信息: dumpe2fs   /dev/sda1
    数据读取:日志+元数据+数据存放区记录。CPU>主存储器(RAM)>硬盘,为加快速度,linux采用异步处理的方式,先从硬盘中读取文件时,会将块数据存到内存即主存储器的缓冲区中,若被修改,则变为脏数据,必须写回到硬盘中。
    载入点:必须为目录,即进入文件系统的入口
    linux支持的文件系统:
    (1)传统文件系统:ext2,MS-DOS,FAT
    (2)日志式文件系统:ext3,NTFS
    (3)网络文件系统:NFS

    2.文件系统的操作

    (1)查看当前磁盘容量:(一般用 df -h )
    df (disk free) -a 则多出/proc, 大小为0,放在内存中的 / -i 查看inode /df -h 文件名 查看文件使用情况
    (2)查看各个文件容量(du -k/m/a/)
    (3)创建连接文件 ln -s /bin/huhu /huhu ,则进入/huhu后实际读取的是/bin/huhu 下的内容
    (4)分区: fdisk -l 设备名称(不要加数字,分区针对整个硬盘设备,而不是某个分区)
    删除分区:d 选择分区号 p 查看分区信息
    (5)磁盘格式化:mke2fs 设备名称


    3.创建虚拟内存swap(/dev/zero,是一个输入设备,你可你用它来初始化文件.)
    (1)使用dd命令,在/tmp目录下创建一个64M的文件
    dd if=/tmp/zero of=/tmp/swap bs=4k count=16382
    [yuanyuan@localhost /]$ dd if=/dev/zero of=/tmp/swap bs=4k count=16382
    16382+0 records in
    16382+0 records out
    67100672 bytes (67 MB) copied, 9.66832 s, 6.9 MB/s
    dd:转换命令并且复制
    if:要转换的输入文件格式
    of:输出的文件
    bs:一个分区的大小
    count:有多少个分区,即bs
    (2)使用mkswap将/tmp/swap的文件格式转化为虚拟内存的格式
    mkswap /tmp/swap

    [yuanyuan@localhost /]$ mkswap /tmp/swap
    mkswap: /tmp/swap: warning: don't erase bootbits sectors
    on whole disk. Use -f to force.
    Setting up swapspace version 1, size = 65524 KiB
    no label, UUID=ce0a57a9-de6e-4714-bbd6-c4e81f8264de

    (3)使用swapon启动/tmp/swap (可以用free查看内存使用情况)
    swapon /tmp/swap
    (4)swapoff /tmp/swap 关闭swap文件

    二. 文件的压缩与打包(注意:当使用gzip或者bzip2不加参数压缩时,源文件都消失,但是tar时源文件和目的文件都存在)
    常见的压缩文件的名字:(tar主要是为了备份重要的文件,dd可以备份整个磁盘和分区)
    (1)*.bz2:bz2程序文件压缩的文件
    (2)*.gz:gzip程序压缩的文件
    (3)*.tar:tar程序打包的数据,并没有压缩过 (tar程序可以将多个文件打包成一个文件(或目录))
    (4)*.tar.gz:tar程序打包的数据而且用gzip压缩过。
    (5)*.Z:使用compress程序压缩的文件
    1. gzip/zcat
    gzip a(文件名) :将文件 a打包为a.gz,原来的不存在
    zcat a.gz:查看压缩文件的内容
    gzip -d a.gz (解压缩):将a.gz解压为a ,原来的压缩文件不存在
    gzip -c a(文件名)>新的压缩文件名 : 将文件 a打包为a.gz,原来的仍存在,以数据流重导向进行处理
    也可以用gzip -d a.gz >b 此时出现a和b两个文件
    gzip -(1-9) 文件名:压缩等级,9最好但慢,一般为6
    2. bzip2/bzcat/bunzip2
    (1)bzip2 文件名 > 新文件名 压缩并重命名
    (2)bzcat *.bz2 查看压缩文件内容
    [yuanyuan@localhost Desktop]$ bzcat d.txt.bz2
    i miss you ~
    (3)bzip2 -d *.bz2 解压缩 或者用 bunzip2 压缩文件 也可以
    3. tar (参数必须用f结尾,前三个参数不能同时存在,一般为 cvf,xvf,tvf)
    (1)-c 压缩
    (2)-x 解压
    (3)-t 查看tar的文件
    (4)-v 压缩的过程中显示文件名如下所示
    [root@localhost Desktop]# tar -cvf fee.txt.tar fee.txt
    fee.txt
    [root@localhost Desktop]# tar -cvf yy.tar yy
    yy/
    yy/d.txt
    (5)-f 使用文件名,一般后面直接加文件名
    (6)-z 用gzip方式压缩
    (7)-j 用bzip2的方式压缩
    (8)-p 使用源文件的原来属性
    (9)-P 使用绝对路径来压缩
    (10)-N '2016/02/14' 比时间新的才会打包
    (11)--exclude file 打包时不打包这个文件 --exclude 文件名 -gcvf
    例子:
    (1)把yy文件夹打包成yy.tar
    [yuanyuan@localhost Desktop]$ tar -cvf yy.tar yy
    yy/
    yy/fee.txt
    yy/y/
    yy/d.txt
    (2)查看已打包文件的内容
    [yuanyuan@localhost Desktop]$ tar tvf yy.tar
    drwxrwxr-x yuanyuan/yuanyuan 0 2016-01-26 17:49 yy/
    -rw-rw-r-- yuanyuan/yuanyuan 10240 2016-01-26 02:11 yy/fee.txt
    drwxrwxr-x yuanyuan/yuanyuan 0 2016-01-26 17:49 yy/y/
    -rwxrwxr-x yuanyuan/yuanyuan 47 2016-01-26 00:39 yy/d.txt
    (3)解压打包文件
    [yuanyuan@localhost Desktop]$ tar xvf yy.tar
    yy/
    yy/fee.txt
    yy/y/
    yy/d.txt
    (4)用gzip工具对yy进行打包
    [yuanyuan@localhost Desktop]$ tar -zcvf yy.tar.gz yy
    yy/
    yy/fee.txt
    yy/y/
    yy/d.txt
    (5)对gzip打包备份的文件解压
    [yuanyuan@localhost Desktop]$ tar -zxvf yy.tar.gz
    yy/
    yy/fee.txt
    yy/y/
    yy/d.txt
    (6)用bzip2工具对 yy 进行打包为 y1y.tar.gz
    [yuanyuan@localhost Desktop]$ tar -jcvf y1y.tar.gz yy
    yy/
    yy/fee.txt
    yy/y/
    yy/d.txt
    (7) 打包yy后直接解压,不产生中间文件
    tar -cvf - yy | tar -xvf -
    4.dd (除了复制,最大的用处是备份)
    dd if=输入文件 of =输出文件 bs=(块大小,默认为 512字节) count=bs数
    (1)备份/dev/hda的MBR
    dd if=/dev/hda of=/tmp/mbr.back bs=512 count=1
    (2)备份/dev/hda1整个分区
    dd if=/dev/hda1 of=/some/path/文件名
    of路径不能在if的目录中,要不然一直循环!!!

  • 相关阅读:
    机器学习:以分析红酒口感为例说明交叉验证的套索模型
    机器学习:分类算法性能指标之ROC曲线
    机器学习:最小二乘法实际应用的一个完整例子
    机器学习:Python中如何使用支持向量机(SVM)算法
    机器学习:python中如何使用朴素贝叶斯算法
    机器学习:Python实现lms中的学习率的退火算法
    机器学习:Python实现最小均方算法(lms)
    @Autowired 与@Resource选择(治好你的强迫症)
    @Resource 进行注入bean的过程
    @Autowired 进行注入bean的过程
  • 原文地址:https://www.cnblogs.com/alwayswyy/p/5162477.html
Copyright © 2020-2023  润新知