此篇文字linux记录文档word更加详细
内容介绍:centos6,centos7按照拿到一个新硬盘开始,其使用方法及具体细节
第一步、磁盘分区类型,命令等
第二步、文件系统(即格式化为什么文件系统)类型及创建命令,文件系统标签,索引节点,文件系统检测与修复
第三步、在linux上需要挂载才能使用,mount命令的使用,磁盘卸载命令
其它应用:拿磁盘空间做swap,磁盘阵列,逻辑卷LVM的使用;交换文件和分区,raid,lvm,软硬链接,暂时记录于word
第一步:管理分区
• 列出块设备
• lsblk
• 创建分区使用:
• fdisk 创建MBR分区 fdisk - manipulate disk partition table
• gdisk 创建GPT分区 gdisk - Interactive GUID partition table (GPT) manipulator
• parted 高级分区操作
• partprobe-重新设置内存中的内核分区表版本
分区命令1:parted命令
• parted的操作都是实时生效的,小心使用
• 用法:parted [选项]... [设备 [命令 [参数]...]...]
parted /dev/sdb mklabel gpt|msdos mklabel使用何种类型分区gpt还是mbr(msdos),用fdisk -l 查看,可以看到gpt分区或者msdos。用hexdump -C /dev/sda -n 512 -v查看,会有55 aa表示磁盘分区结束标识
parted /dev/sdb print 查看分区表
parted /dev/sdb mkpart primary 1 200 (默认M) 主分区,1到200M
parted /dev/sdb rm 1 删除sdb1
parted -l 查看分区
hexdump -C /dev/sda -n 512 -v
上述都是非交互式,且实时生效的。parted命令不跟参数可以非交互式分区
分区工具fdisk和gdisk
• gdisk /dev/sdb 类fdisk 的GPT分区工具
• fdisk -l [-u] [device...] 查看分区
• fdisk /dev/sdb 内存分区表 lsblk,cat /proc/partitions,ls /dev/sda* ;fdisk /dev/sdb查看硬盘分区表。centos6上面还是柱面为分区单位,建议用扇区(c),不会出现提醒。centos6同步分区表用partx -a /dev/sda
• 子命令:
– p 分区列表
– t 更改分区类型
– n 创建新分区
– d 删除分区
– v 校验分区
– u 转换单位
– w 保存并退出
– q 不保存并退出
同步分区表
• 查看内核是否已经识别新的分区:
cat /proc/partations #process进程管理
• centos6通知内核重新读取硬盘分区表
新增分区用
partx -a /dev/DEVICE
kpartx -a /dev/DEVICE -f: force
删除分区用
partx -d --nr M-N /dev/DEVICE 如partx -d --nr 6-8 /dev/sda
• CentOS 5,7: 使用partprobe
partprobe [/dev/DEVICE]
————————————————分区实验————————————————————
dd命令
skip=xxx 是在备份时对if后面的部分也就是原文件跳过多少块
seek=xxx 是在备份时对of后面的部分也就是目标文件跳过多少块开始写
实验一:备份mbr,并破坏,再恢复
1.备份mbr
dd if=/dev/sda of=/app/mbr.img bs=1 count=512
2.将mbr.img 复制到其他主机 sz /app/mbr.img
3.破坏mbr
dd if=/dev/zero of=/dev/sda bs=1 count=512
4.关机
5.在另一个主机上将被破坏的硬盘添加
6.在vmware虚拟机,新加硬盘不用重启的生效方法
echo '- - -' > /sys/class/scsi_host/host0/scan
7.恢复
dd if=mbr.img of=/dev/sdb
8.poweroff
9.开启被恢复的主机
10.从恢复机中删除故障硬盘.
实验二:仅破坏分区表,并恢复.
dd if=/dev/zero of=/dev/sda bs=1 count=64 seek=446
dd if=/app/mbr.img of=/dev/sda bs=1 count=64 skip=446 seek=446
实验三:新增硬盘sdb,并使用sda的mbr备份来恢复sdb的分区表
dd if=/app/mbr.img of=/dev/sdb bs=1 count=66 skip=446 seek=446
count=66多了两个字节,表示分区结束符55aa
parted 支持msdos和gpt
交互和非交互
parted /dev/sda
parted -l 列出所有硬盘的分区信息
parted /dev/sda print 列出指定硬盘的分区
parted /dev/sdb mklabel msdos 设置硬盘的分区类型
或gpt
parted /dev/sdb mklabel msdos -s 自动回答yes
parted /dev/sdb mkpart primary 1 2G
parted /dev/sdb mkpart primary 2G 4G
parted /dev/sdb mkpart primary 4G 6.5G
parted /dev/sdb mkpart extended 6.5G 21.5G
parted /dev/sdb mkpart logical 6.5G 7G
fdisk 支持msdos,在centos7中也支持gpt(不建议使用),gtp改为msdos改不了,fdisk bug
fdisk -l 查看所有硬盘的分区信息
fdisk -l /dev/sda 查看指定硬盘的分区信息
fdisk /dev/sdb
o 设置msdos分区表
g 设置gpt分区表(不建议使用)
m 帮助
n 创建分区
p 主分区
e 扩展分区 (请把所有空间分给扩展)
起始的扇区数 一般直接回车,取可用的最小扇区
结束的扇区数 一般用+XX K/M/G 来指定具体分多少大小的分区
q 退出不保存
w 退出并保存
t 设置分区的类型
L 查看分区的类型所对应的代码表示方式
d 删除指定分区
a 设置该分区为启动分区,或设置为非启动
p 显示分区表
u 更新显示分区起止的单位,在扇区和柱面之间切换
非交互方式
echo -e "n\np\n\n\n+1G\nw\n" |fdisk /dev/sdb &> /dev/null
gdisk 只能划分gpt分区
gdisk -l 列出所有硬盘分区表
gdisk -l /dev/sdb 列出指定硬盘的分区表
gdisk /dev/sdb 对分区进行划分
o 创建gpt分区表
m 帮助
n 创建分区
起始的扇区数 一般直接回车,取可用的最小扇区
结束的扇区数 一般用+XX K/M/G 来指定具体分多少大小的分区
q 退出不保存
w 退出并保存
t 设置分区的类型
L 查看分区的类型所对应的代码表示方式
d 删除指定分区
p 显示分区表
非交互方式
echo -e "n\n\n\n+2G\n\nw\ny\n" |gdisk /dev/sdb
多行重定向 fdisk /dev/sdc << EOF
cat /proc/partitions 当前内核所加载的分区表
lsblk
对于非系统所在硬盘,内核自动更新分区表,而对于系统所在硬盘,不能直接列新,要使用以下命令
通知内核读取分区表
cenots5\centos7: partprobe (centos6不可用)
centos6:partx -a /dev/sda 添加
partx -d --nr /dev/sda7 删除
———————————————————分区实验到此结束———————————————————————
第二部:文件系统
• 文件系统是操作系统用于明确存储设备或分区上的文件的方法和数据结构;即在存储设备上组织文件的方法。操作系统中负责管理和存储文件信息的软件结构称为文件管理系统,简称文件系统
• 从系统角度来看,文件系统是对文件存储设备的空间进行组织和分配,负责文件存储并对存入的文件进行保护和检索的系统。具体地说,它负责为用户建立文件,存入、读出、修改、转储文件,控制文件的存取,安全控制,日志,压缩,加密等
• 支持的文件系统:/lib/modules/`uname –r`/kernel/fs
文件系统类型
• Linux文件系统:ext2(Extended file system), ext3, ext4, xfs(SGI), btrfs(Oracle),
reiserfs, jfs(AIX), swap
• 光盘:iso9660
• Windows:FAT32, exFAT,NTFS
• Unix: FFS(fast), UFS(unix), JFS2
• 网络文件系统:NFS, CIFS CIFS协议如windows10网上邻居 不支持并发
• 集群文件系统:GFS2, OCFS2(oracle)
• 分布式文件系统: fastdfs,ceph, moosefs, mogilefs, glusterfs, Lustre
• RAW:未经处理或者未经格式化产生的文件系统
文件系统分类
• 根据其是否支持"journal"功能:
日志型文件系统: ext3, ext4, xfs, ...
非日志型文件系统: ext2, vfat #ext2加上日志功能即变为ext3
• 文件系统的组成部分:
内核中的模块:ext4, xfs, vfat
用户空间的管理工具:mkfs.ext4, mkfs.xfs,mkfs.vfat
• Linux的虚拟文件系统:VFS
• 查前支持的文件系统:cat /proc/filesystems
——————————————————————————————————
/var/log/httpd/access_log 网站访问记录日志
redo log 数据恢复日志记录
VFS
buffer 缓冲(内存中的数据先放到buffer中,等系统不忙或者数据到达一直值的时候,再读入硬盘) cache缓存 (磁盘把数据先读到硬盘缓存中,再读到内存中,下次如果读取一样的数据,从硬盘缓存可以快速读取,其中有个命中率hit的概念)
文件系统选择
创建文件系统mkfs
• mkfs命令:
• (1) mkfs.FS_TYPE /dev/DEVICE 如:mkfs.ext4 /dev/sda make -t ext4 /dev/sda
ext4
xfs
btrfs
vfat
• (2) mkfs -t FS_TYPE /dev/DEVICE
L 'LABEL': 设定卷标
• mke2fs:ext系列文件系统专用管理工具 (可以只记住mkfs命令即可)
-t {ext2|ext3|ext4}
-b {1024|2048|4096}
-L 'LABEL' 卷标,简单说明注释信息,类似window中的盘符名称
-j: 相当于 -t ext3
mkfs.ext3 = mkfs -t ext3 = mke2fs -j = mke2fs -t ext3
-i #: 为数据空间中每多少个字节创建一个inode;此大小不应该小于 block的大小
-N #:指定分区中创建多少个inode
-I 一个inode记录占用的磁盘空间大小,128---4096
-m #: 默认5%,为管理人员预留空间占总空间的百分比
-O FEATURE[,...]:启用指定特性 如:
-O ^FEATURE:关闭指定特性
文件系统标签blkid,e2lable,findfs
• 指向设备的另一种方法
• 与设备无关
• blkid:块设备属性信息查看
blkid [OPTION]... [DEVICE]
-U UUID: 根据指定的UUID来查找对应的设备
-L LABEL:根据指定的LABEL来查找对应的设备
• e2label:管理ext系列文件系统的LABEL
e2label DEVICE [LABEL]
• findfs :查找分区
findfs [options] LABEL=<label>
findfs [options] UUID=<uuid>
——————————————————————————————
[root@centos6 ~ ]#blkid -U `grep /boot /etc/fstab|sed -r "s/UUID=([^ ]*) .*/\1/"`
/dev/sda1
[root@centos6 ~ ]#grep /boot /etc/fstab|cut -d" " -f1
UUID=22b056f8-1c4f-4f94-84e4-af12c8ff6e74
[root@centos6 ~ ]#findfs `grep /boot /etc/fstab|cut -d" " -f1`
/dev/sda1
[root@centos6 ~ ]#grep /boot /etc/fstab|cut -d" " -f1|findfs
Usage: findfs LABEL=<label>|UUID=<uuid>
[root@centos6 ~ ]#grep /boot /etc/fstab|cut -d" " -f1|xargs findfs
/dev/sda1
tune2fs
• tune2fs:重新设定ext系列文件系统可调整参数的值
-l:查看指定文件系统超级块信息;super block
-L 'LABEL':修改卷标
-m #:修预留给管理员的空间百分比
-j: 将ext2升级为ext3
-O: 文件系统属性启用或禁用, –O ^has_journal
如:tune2fs -O has_journal /dev/sdb2 ; tune2fs -O ^has_journal /dev/sdb2
-o: 调整文件系统的默认挂载选项,–o ^acl
-U UUID: 修改UUID号 uuidgen 命令可以生成一个uuid号
tune2fs -U `uuidgen` /dev/sdb2
————————————————————
acl权限在centos7上分区默认就有,centos6操作系统所在分区有acl,而手动创建的是没有acl权限
dumpe2fs:
块分组管理,32768块
-h:查看超级块信息,不显示分组信息
dumpe2fs /dev/sdb2 | less
超级块和inode table
文件系统检测和修复
• 常发生于死机或者非正常关机之后
• 挂载为文件系统标记为“no clean”
• 注意:一定不要在挂载状态下修复
• fsck: File System Check
fsck.FS_TYPE
fsck -t FS_TYPE
-p: 自动修复错误
-r: 交互式修复错误
FS_TYPE一定要与分区上已经文件类型相同
• e2fsck:ext系列文件专用的检测修复工具
-y:自动回答为yes
-f:强制修复
________________________________________________
用fsck /dev/sda3 时,如果文件系统类型为xfs,会自动提示xfs需要用到命令
see xfs_repair(8)
xfs_info /dev/sda3
第三步:挂载mount
• 挂载:将额外文件系统与根文件系统某现存的目录建立起关联关系,进而使得此目录做为其它文件访问入口的行为
• 卸载:为解除此关联关系的过程
• 把设备关联挂载点:mount Point
mount
• 卸载时:可使用设备,也可以使用挂载点
umount
• 挂载点下原有文件在挂载完成后会被临时隐藏
• 挂载点目录一般为空,空目录下一般挂载一个设备(即使挂载多个只有一个生效,这样做也没意义),一个设备可以挂载到多个目录
用mount命令挂载文件系统
• 挂载方法:mount DEVICE MOUNT_POINT
• mount:通过查看/etc/mtab文件显示当前已挂载的所有设备 /etc/mtab自动更新
• mount [-fnrsvw] [-t vfstype] [-o options] device dir
device:指明要挂载的设备;
(1) 设备文件:例如/dev/sda5 设备名不稳定,有新设备挂载时,名称可能改变
(2) 卷标:-L 'LABEL', 例如 -L 'MYDATA' | mount LABEL=/data/sdb2 /app/sdb2
(3) UUID, -U 'UUID':例如 -U '0c50523c-43f1-45e7-85c0- a126711d406e'
(4) 伪文件系统名称:proc, sysfs, devtmpfs, configfs
dir:挂载点
事先存在;建议使用空目录,如果目录下有文件,挂载后,目录下文件会被隐藏,当卸载挂载设备时,目录下隐藏的文件就又可以看见了
进程正在使用中的设备无法被卸载
挂载设备时,用uuid挂载比较好
mount常用命令选项
• -t vsftype:指定要挂载的设备上的文件系统类型
• -r: readonly,只读挂载
• -w: read and write, 读写挂载
• -n: 不更新/etc/mtab,mount不可见,但cat /proc/mounts可以看到。 centos7不起作用,原因如下:
[root@centos6 ~ ]#ll /proc/mounts
lrwxrwxrwx. 1 root root 11 Jul 6 21:19 /proc/mounts -> self/mounts
[root@centos7:~ ]# ll /etc/mtab
lrwxrwxrwx. 1 root root 17 Jun 28 16:18 /etc/mtab -> /proc/self/mounts
• -a:自动挂载所有支持自动挂载的设备(定义在了/etc/fstab文件中,且挂载选项中有auto功能)
• -L 'LABEL': 以卷标指定挂载设备
• -U 'UUID': 以UUID指定要挂载的设备
• -B, --bind: 绑定目录到另一个目录上
• 查看内核追踪到的已挂载的所有设备
cat /proc/mounts
• -o options:(挂载文件系统的选项),多个选项使用逗号分隔
async:异步模式
sync:同步模式,内存更改时,同时写磁盘
atime/noatime:包含目录和文件
diratime/nodiratime:目录的访问时间戳
auto/noauto:是否支持自动挂载,是否支持-a选项
exec/noexec:是否支持将文件系统上运行应用程序
mount -o remount,noexec /data/sdb2,则/data/sdb2下的脚本按照/data/sdb2/*.sh时不可执行。但可以用bash /data/sdb2/*.sh,仍可以执行
dev/nodev:是否支持在此文件系统上使用设备文件
suid/nosuid:是否支持suid和sgid权限
remount:重新挂载 mount -o remount,ro /app/data/ 有些场景umount显示设备忙,则remount可以代替umount,mount
ro:只读
rw:读写
user/nouser:是否允许普通用户挂载此设备,是否允许写入/etc/fstab中的挂载项目让普通用户使用,默认为nouer
acl:启用此文件系统上的acl功能
loop: 使用loop设备
• defaults:相当于rw, suid, dev, exec, auto, nouser, async
卸载命令
• 查看挂载情况
findmnt MOUNT_POINT|device findmnt /data/sdb1
• 查看正在访问指定文件系统的进程 (sleep 10000s &) 后台执行
lsof MOUNT_POINT
fuser -v MOUNT_POINT
• 终止所有在正访问指定的文件系统的进程
fuser -km MOUNT_POINT m是递归子目录。lsof默认具有递归功能
• 卸载
umount DEVICE
umount MOUNT_POINT
挂载点和/etc/fstab
• 配置文件系统体系
• 被mount、fsck和其它程序使用
• 系统重启时保留文件系统体系
• 可以在设备栏使用文件系统卷标
• 使用mount -a 命令挂载/etc/fstab中的所有文件系统
______________________________________________________________________
[root@centos6 ~ ]#tune2fs -l /dev/sda1
tune2fs 1.41.12 (17-May-2010)
*******
Mount count: 47 挂载次数,每挂载mount一次,就增加1
Maximum mount count: -1 -1表示不检查,如果为50就表示挂载次数达到50会检查此案,fsck
Last checked: Tue May 15 18:43:20 2018
Check interval: 0 (<none>) 检查周期,此处表示不检查,列如:如果为15552000(6 months),则6个月检查一次
******
[root@centos6 ~ ]#
每挂一个文件,会消耗一个loop
centos6 :dd if=/dev/zero of=/root/p1 bs=1M count=100
mkfs.ext4 p1 -y ;blkid p1 ;mount -o loop /root/p1 /mnt
umount /mnt ;scp p1 192.168.30.100:/data 拷到centos7/data下
mount /data/p1 /mnt centos7中可以不加-o选项 ;;df 查看/dev/loop0,文件模拟分区;loseup -a查看loop设备是哪个文件
centos7中的loop设备无限制,而centos6中默认有8个。
losetup /dev/loop8 p2 把loop8映射到p2文件 cp p1 p2
mkdir /data/loop8;mount /dev/loop8 /data/loop8 ;df ; ls /data/loop8 下有一个f1;mount ;
修改内核参数,使生成100个loop vim /boot/grub/grub.conf ; 找到kernel最后一行,添加max_loop=100;重启生效。而centos7无限制,使用一个自动创建一个
实验2:
——————————————————————————————————————
仅限Vmware中,分配一个磁盘空间,用echo '- - -' > /sys/class/scsi_host/host2/scan命令可以是识别到磁盘,或者用echo '- - -' > /sys/class/scsi_host/host0/scan
[root@centos7:/app ]# mkfs.ext4 /dev/sdb 格式化硬盘分区sdb
[root@centos7:/app ]# mount /dev/sdb /app/aaa 挂载到/app/aaa
vim /etc/fstab 永久添加磁盘sdb的配置信息到/etc/fstab配置文件里
:r! blkid | grep sdb | cut -d" " -f2
更改/dev/sdb的UUID号码,如下图:而配置表/etc/fstab并没有改变。此操作会导致从起后启动不起来
上述操作完,重启,esc键查看重启界面。如下图,无法启动
输入root的密码后的两种解决方法:一:把/etc/fstab 中的/dev/sdb的开机检查由3改为0即可。二:/etc/fstab中把UUID改为正确的,然后重启。但输入密码后,是只读的,不可写。解决方法如下:
上图中,磁盘是读写,但其实写入不了 :执行mount -o rw,remount / 即可
文件挂载配置文件
• /etc/fstab每行定义一个要挂载的文件系统
• 要挂载的设备或伪文件系统
设备文件
LABEL:LABEL=""
UUID:UUID=""
伪文件系统名称:proc, sysfs
• 挂载点
• 文件系统类型
• 挂载选项:defaults
• 转储频率:0:不做备份 1:每天转储 2:每隔一天转储
• 自检次序: 0:不自检
1:首先自检;一般只有rootfs才用1
dump实现,0表示开机不检查

3516

被折叠的 条评论
为什么被折叠?



