Linux快速入门02-文件系统管理

继续进入Linux文件系统的学习,加油,早日突破MS压在自己身上的那道束缚。

 

文件属性基本概念:文件所有者,文件组,其他人。

对上图来说,-rw-r—r—表示文件的权限,1表示连接数,两个root分别表示所有者和用户组,264表示文件大小(单位为B),之后信息为文件修改日期和文件名(.开头表示隐藏文件)。

这部分最终要的概念就是文件权限,可以将文件权限部分内容分为之后的4个部分来理解,例如对于[-][rwx][r-x][r--],有:

部分 诠释
第一部分[-] 文件类型,d表示目录,-表示文件,l表示连接文件(linkfile),b,c等表示设备
第二部分[rwx] 文件所有者的权限,可读、可写、可执行
第三部分[r-x] 文件用户组的权限,可读、可执行
第四部分[r--] 其他用户的权限,可读

权限相关常见命令

命令 诠释
chgrp 改变文件所属用户组
chown 改变文件所有者
chmod 改变文件权限,rwx=4+2+1, chmod 764
cd 访问目录(需要x权限),cd .., ~, .表示相对路径, cd /xxx表示绝对路径
Uname –t 查看内核版本

Linux目录配置标准FHS(FileSystem Hierarchy Standard)如下所示

  可分享的 不可分享的
不可变的 /usr软件放置处 /etc配置文件
/opt第三方软件 /boot开机和内核文件
可变动的(跟随distribution变动) /var/mail用户邮件信箱 /var/run程序相关
/var/spool/news新闻组 /var/lock程序相关

本文最后的附录中,可以看到Linux中根目录(/)、/usr目录(放置可分享但不可变动数据),/var目录中主要的目录结构(主要针对常态性变动的文件)。

 

这部分基本上会介绍最为常见的Linux命令,需要熟练掌握。

命令 诠释
cd Change Directory切换目录
pwd Print Working Directory显示当前目录
mkdir 新建一个目录, -p自行创建多层目录
rmdir 删除一个空的目录, -p连同上层某目录一起删除,需要注意这只能删除空目录
echo $PATH 执行文件路径
ls 查看文件和目录, ls –a显示全部文件,包括隐藏;-d,仅列出目录本身;-l,显示详细信息,包括文件的属性和权限
cp 复制,cp [参数] 源文件 目标文件。参数-a表示-pdr;-i若目标文件存在,覆盖时会询问;-r递归持续复制,用于目录的复制行为
rm 删除文件/目录,参数-r递归删除,非常危险
mv 移动文件和目录,或更名,mv 文件1 [,文件2] 目录,可以通过mv 文件 新文件名改名
basename 以及dirname 文件,用于获取文件名和完整目录名
文件内容查阅 方式比较多,包括cat,tac(逆序),nl显示时输出行号,more,less向后向前翻页,head,tail只看首尾几行,od以二进制方式读取
touch 修改文件时间或创建新文件
umask 新建一个文件的的默认权限,默认为0022,这时新建文件的权限时-rw-r—r--,目录为drwxr-xr-x。注意mask掩码其实就是对权限的异或操作,022代表去除组和其他用户的写权限。
文件隐藏属性 是9个权限外的权限,对于安全有很大帮助,参数a表示文件只能增加而不能删除修改,参数i表示文件不能被删除、改名,设置连接也无法写入或添加数据,只有root可用 设置文件隐藏属性:chattr +i attrtest, chattr –i attrtest 显示文件隐藏属性:lsattr 文件
文件特殊属性 比如ls –ld /tmp ; ls –l /usr/bin/passwd,可以看到除rwx外的s和t 简单来说,就是用户执行这个2进制文件是会获得额外的权限,SUID所有者权限,SGID组权限,SBIT目录权限,其对应的值分别为4,2,1
file 查看文件类型
which 脚本文件名查询,which ifconfig
whereis 文件名的查找whereis ifconfig, 文件名模糊查找locate ifconfig
find

功能更强大的文件查找,参数-uid id,-gid id,这个id可以在/etc/passwd中看到 -user name, -group name, -nouser, -nogroup

查找目录:find -name dirname -type d

 

 

Linux的默认文件系统Ext3的基础结构主要包括3个主要的概念。

super block:记录此文件系统的整体信息,包括inode/block的总量、使用量、剩余量,以及文件系统的格式和相关信息。

inode:记录文件的属性,一个文件占用一个inode,同时记录此文件的数据所在的block号码。

block:实际记录文件的内容,若文件太大,会占用多个block。

比较有意思的是,Linux文件系统使用异步处理方式来保存数据,比如系统加载一个文件到内存并设置其状态为clean,如果修改了文件就设置为dirty。此时操作都还在内存中,并未写入到磁盘,系统会不定时的异步写入,此外Linux VFS虚拟文件系统功能也非常不错,可以兼容多种不同的文件系统。

 

文件系统操作

命令 诠释
df 文件系统整体磁盘使用量,参数-h以人们易阅读的方式GB,MB显示,-i显示inode数量
du 评估文件系统的磁盘使用量,-d列出总量
ln 连接文件,连接包括两种:类似快捷方式的软连接(符号连接);通过文件系统inode连接来产生新文件名的硬连接。 Hardlink: ln /etc/crontab . Symbolic link: ln –s /etc/corntab crontab2
fdisk 磁盘分区:df /, fdisk /dev/vda1, 可以使用m查看命令,d用于删除分区,n用于新增分区,p显示分区,q退出,w写入刚才操作到分区表
mkfs 磁盘格式化,mkfs –t ext3 /dev/hdc6    
fsck,badblocks 磁盘检测,fsck –C –f –t ext3 /dev/hdc6, badblocks –sv /dev/hdc6
mount 磁盘挂载,mount –a将未挂载的磁盘挂载 mount /dev/hdc6 /mnt/hdc6
umount 磁盘卸载,umount /dev/hdc6
磁盘参数修改 mknod,e2label修改卷标名,tune2fs,hdparm
开机挂载 /etc/fstab, /etc/mtab
Swap内存交换空间的建立 先进行分区并partprobe让内核更新分区表,创建hdc7,之后mkswap /dev/hdc7, free, swapon /dev/hdc7, free, swapon-s

 

Linux提供了很多不同的压缩文件和打包格式,但现在主要还在使用的主要为.tar和.tar.gz等。

命令

示例

gzip/bzip2 压缩:gzip –c node.config > node.config.gz 解压缩:gzip –d node.config.gz
tar打包命令 压缩:tar –jcv –f filename.tar.bz2 xxx目标压缩文件 查询:tar -jtv –f filename.tar.bz2 解压缩:tar –jxv –f filename.tar.bz2 –C xxx欲解压到的目录
备份/恢复文件系统 备份步骤: df –h 查看文件系统 dump –S/dev dump -0u –f /root/boot.dump/boot 恢复步骤: restore –t –f /root/boot.dump
dd备份磁盘或文件 dd if=/etc/passwd of=/tmp/passwd.back dd if=/dev/vda1 of=/tmp/mbr.back

通常来说,会使用tar来备份关键数据,而用dd来备份整块分区或磁盘。

此外还有一些备份工具,需要时再查询就好,比如:mkisofs新建镜像文件;cdrecord光盘刻录工具;

 

目录 应放置文件内容
/bin 执行文件,可以在单用户维护模式使用,主要有cat,chmod,mkdir,bash等命令
/boot 开机使用到的文件,包括linux内核文件和开机所需配置文件等,vmlinz,/boot/grub
/dev 任何设备和接口都是以文件的形式存放在该目录,/dev/nul,zero,tty,lp*,hd*,sd*
/etc 系统主要的配置文件,例如用户的账号密码,各种服务的init文件,比较重要的文件包括,/etc/inittab,init.d/,modprobe.conf,X11/,fstab,sysconfig/
/home 系统默认的用户主文件夹,~表示当前用户的主文件夹,~xionger则表示熊二的主文件夹
/lib 开机时会用到的函数库,以及/bin或/sbin下命令调用的函数库
/media, /mnt 放置可删除设备,如cdrom等; 放置临时需要挂载的设备
/opt 放置第三方软件的目录,也可以放在/usr/local中
/root 系统管理员root的主文件夹,需要和根目录放置在同一分区
/sbin 包括开机、修复、还原系统的命令,常见命令有fdisk,fsck,ifconfig,init,mkfs
/srv 一些网络服务启动,所需数据的目录,例如WWW服务需要/srv/www/
/tmp 临时文件,推荐定期删除
/lost+found 对于ext2/ext3文件系统格式来说,当系统出现错误时,会把丢失的片段放在该目录,此外,如果加一块硬盘到/disk中,那么系统会自动产生/disk/lost+found
/proc 虚拟文件系统,其数据放置在内存,包括系统内核、进程、外部设备和网络状态,重要的文件包括/proc/cpuinfo,dma,interrupts,ioports,net/*
/sys 和/proc内丝,也是一个虚拟文件系统,主要记录与内核有关的信息
/usr/bin 绝大部分的用于可使用命令都在这,不过不支持单用户维护模式
/usr/include C/C++等程序头文件放置处,当使用tarball方式安装数据时会用到这里的很多包含文件
/usr/lib 包含应用程序的函数库、目标文件和脚本,对于x86_64的linux还有/usr/lib64/产生
/usr/local 系统管理员自己下载的软件推荐安装在此
/usr/sbin 非系统正常运行需要的系统命令,例如某系网络服务软件的服务命令(daemon)
/usr/share 放置共享文件的地方
/usr/src 一般用来放置源码
/var/cache 应用程序运行时产生的暂存文件
/var/lib 程序本身执行需要使用的数据文件放置在这,比如mysql的数据库放置在/var/lib/mysql
/var/lock 对于某些系统资源来说,一次只能供一个应用使用,因此需要将其加锁
/var/log 登录文件放置的目录,比较重要的有/var/log/messages,wtmp
/var/mail 放置个人电子邮箱的目录,链接到/var/spool/mail
/var/run 某些程序或服务启动后,会将其PID放置在此
/var/spool 放置一些队列数据,"队列"就是排队等待其他程序使用的数据了,比如工作任务数据(crontab),就防止在/var/spool/cron/中

 

整个linux的学习,重在命令的熟练,加油!"天行健,君子以自强不息;地势坤,君子以厚德载物" -- 《周易》

 

参考资料:

  1. 鸟哥. 鸟哥的Linux私房菜基础学习篇(第三版)[M]. 北京:人民邮电出版社, 2010.
posted @ 2016-06-30 20:18  代码熊二  阅读(539)  评论(0编辑  收藏  举报