Linux-文件管理
文件管理
创建、复制、删除、移动、查看、编辑、压缩、查找
一、linux目录结构
windows: 以多根的方式组织文件 c:\ d:\ e:\
linux: 以单根的方式组织文件 /
/目录结构: fsh (filesystem hierarchy standard)
[root@tianyun ~]# ls / bin dev lib media net root srv usr boot etc lib64 misc opt sbin sys var cgroup home lost+found mnt proc selinux tmp
注:下图为centos7目录结构
bin 普通用户使用的命令 /bin/ls, /bin/date sbin 管理员使用的命令 /sbin/service dev 设备文件 /dev/sda,/dev/sda1,/dev/tty1,/dev/tty2,/dev/pts/1, /dev/zero, /dev/null, /dev/random root root用户的home home 存储普通用户家目录 lost+found fsck修复时,存储没有链接的文件或目录 proc 虚拟的文件系统,反映出来的是内核,进程信息或实时状态 usr 系统文件,相当于c:\windows /usr/local 软件安装的目录,相当于c:\program /usr/bin 普通用户使用的应用程序 /usr/sbin 管理员使用的应用程序 /usr/lib 库文件glibc /usr/lib64 库文件glibc boot 存放的系统启动相关的文件,例如kernel,grub(引导装载程序) etc 配置文件(系统相关如网络/etc/sysconfig/network,应用相关配置文件如/etc/ssh/sshd_config...) lib 库文件glibc lib64 库文件glibc tmp 临时文件(全局可写:进程产生的临时文件) var 存放的是一些变化文件,比如数据库,日志,邮件.... mysql: /var/lib/mysql vsftpd: /var/ftp mail: /var/spool/mail cron: /var/spool/cron log: /var/log 临时文件: /var/tmp(进程产生的临时文件)
==设备(主要指存储设备)挂载目录== media 移动设备默认的挂载点 mnt 手工挂载设备的挂载点 misc automount进程挂载 net automount进程挂载
命令存储位置:
/bin 普通用户使用的命令 /bin/ls, /bin/date rhel7淘汰 /sbin 管理员使用的命令 rhel7淘汰 /usr/bin 普通用户使用的应用程序 /usr/sbin 管理员使用的应用程序
库文件存储位置:
/lib 库文件glibc rhel7淘汰 /lib64 库文件glibc rhel7淘汰 /usr/lib 库文件glibc /usr/lib64 库文件glibc
***文件时间
ls -l 文件名 仅看的是文件的修改时间
linux文件有四种时间:
# stat anaconda-ks.cfg //查看文件的详细属性(其中包括文件时间属性)
访问时间:atime, 查看内容 //rhel6会延后修改atime
修改时间:mtime,修改内容
改变时间:ctime, 文件属性,比如权限
删除时间:dtime, 文件被删除的时间
[root@root ~]# ls -l install.log -rw-r--r-- 1 root root 34793 10-23 13:49 install.log
[root@root ~]# stat install.log file: “install.log” size: 34793 blocks: 80 io block: 4096 一般文件 device: 802h/2050d inode: 65282 links: 1 access: (0644/-rw-r--r--) uid: ( 0/ root) gid: ( 0/ root) access: 2012-10-23 16:53:20.000000000 +0800 modify: 2012-10-23 13:49:46.000000000 +0800 change: 2012-10-23 13:49:52.000000000 +0800
注:rhel6开始relatime,atime延迟修改,必须满足其中一个条件:
1. 自上次atime修改后,已达到86400秒;
2. 发生写操作时;
***文件类型:
通过颜色判断文件的类型是不一定正确的!!!
linux系统中文件是没有扩展名!!!
方法一:
ls -l 文件名 //看第一个字符 - 普通文件(文本文件,二进制文件,压缩文件,电影,图片。。。) d 目录文件(蓝色) b 设备文件(块设备)存储设备硬盘,u盘 /dev/sda, /dev/sda1 c 设备文件(字符设备)打印机,终端 /dev/tty1 s 套接字文件 p 管道文件 l 链接文件(淡蓝色)
[root@root ~]# ll -d /etc/hosts /bin/ls /home /dev/sda /dev/tty1 /etc/grub2.cfg /dev/log /run/dmeventd-client -rwxr-xr-x. 1 root root 117616 nov 20 2015 /bin/ls srw-rw-rw- 1 root root 0 mar 14 2017 /dev/log brw-rw---- 1 root disk 8, 0 mar 14 09:03 /dev/sda crw--w---- 1 root tty 4, 1 mar 14 09:03 /dev/tty1 lrwxrwxrwx. 1 root root 22 dec 21 01:40 /etc/grub2.cfg -> ../boot/grub2/grub.cfg -rw-r--r-- 1 root root 392 feb 22 15:51 /etc/hosts drwxr-xr-x. 10 root root 4096 mar 14 11:00 /home
方法二:file
[root@localhost ~]# file /etc/hosts /etc/hosts: ascii text [root@localhost ~]# file /bin/ls /bin/ls: elf 64-bit lsb executable, x86-64, version 1 (sysv), dynamically linked (uses shared libs), for gnu/linux 2.6.32, buildid[sha1]=aa7ff68f13de25936a098016243ce57c3c982e06, stripped [root@localhost ~]# file /dev/sda /dev/sda: block special [root@localhost ~]# file /dev/tty1 /dev/tty1: character special [root@localhost ~]# file /etc/grub2.cfg /etc/grub2.cfg: broken symbolic link to `../boot/grub2/grub.cfg' [root@localhost ~]# file /home /home: directory [root@localhost ~]# file /run/dmeventd-client /run/dmeventd-client: fifo (named pipe)
二、路径 (定位文件)
你要在哪儿创建文件?
你要将什么文件复制到什么地方?
你要删除什么地方的什么文件?
/home/alice/file1 和 /home/bob/file1 不是同一文件!!!
/abc/file5 和 abc/file5 有可能是不一样的!!!
绝对路径: 从/开始的路径 /home/alice/file1
相对路径: 相对于当前目录开始 a.txt ./a.txt ../bob/b.txt [假如:此时在目录/home/alice]
三、文件管理
1. 文件管理之:cd 改变目录
cd 绝对路径 cd /home/alice cd ~alice cd 相对路径 cd desktop/abc cd .. cd . ======================================================= cd 专用: cd - 返回上次目录 cd 直接回家 =======================================================
2. 文件管理之:创建/复制/移动/删除
==创建
文件 touch # touch file1.txt //无则创建,有则修改时间 # touch file3 file4 # touch /home/file10.txt # touch /home/file5 file6 # touch /home/{zhuzhu,gougou} # touch file{1..20} # touch file{a..c} # touch yang{a,b,c} //{}集合,等价touch yanga yangb yangc 目录 mkdir # mkdir dir1 # mkdir /home/dir2 /home/dir3 # mkdir /home/{dir4,dir5} # mkdir -v /home/{dir6,dir7} # mkdir -v /hoem/dir8/111/22 # mkdir -pv /hoem/dir8/111/222 //包括其父母的创建,不会有任何消息输出 # mkdir -pv /home/{yang/{dir1,111},tianyun}
==复制 cp
usage: cp [option]... [-t] source dest # cd # mkdir /home/dir{1,2} # cp -v install.log /home/dir1 # cp -v install.log /home/dir1/yang.txt # cp -rv /etc /home/dir1 # cp -v install.log /home/dir90 //没有/home/dir90 # cp -v install.log /home/dir2 # cp -v anaconda-ks.cfg !$ # cp -rv /etc/sysconfig/network-scripts/ifcfg-eth0 /etc/passwd /etc/grub.conf /home/dir2 //将多个文件拷贝到同一个目录 # cp -rv /etc/sysconfig/network-scripts/ifcfg-eth0 /etc/passwd /etc/grub.conf /etc/hosts . # cp -r /etc /tmp # cp -rf /etc /tmp # \cp -r /etc /tmp
[root@localhost ~]# type -a cp cp is aliased to `cp -i' cp is /bin/cp [root@localhost ~]# cp -rv /etc/sysconfig/network-scripts/{ifcfg-eth0,ifcfg-eth0.bak} [root@localhost ~]# cp -rv /etc/sysconfig/network-scripts/ifcfg-eth0{,-org} [root@localhost ~]# cp -rv /etc/sysconfig/network-scripts/{ifcfg-eth0,yang-eth0}
==移动 mv
usage: mv [option]... [-t] source dest # mv file1 /home/dir3 将file2移动到/home/dir3 # mv file2 /home/dir3/file20 将file2移动到/home/dir3,并改名为file20 # mv file4 file5 将file4重命名为file5,当前位置的移动就是重命名
==删除 rm
示例1:删除/home/dir1 # cd /home # rm -rf dir1 -r 递归 -f force强制 -v 详细过程 示例2: [root@localhost~]# mkdir /home/dir10 [root@localhost~]# touch /home/dir10/{file2,file3,.file4} [root@localhost~]# rm -rf /home/dir10/* //不包括隐藏文件 [root@localhost~]# ls /home/dir10/ -a . .. .file4 示例3: [root@localhost~]# rm -rf file* [root@localhost~]# rm -rf *.pdf
3. 文件管理之:查看文件内容
==文本文件 (cat tac less more head tail tailf grep ...) /bin/date /etc/hosts /etc/sysconfig/network /etc/sysconfig/network-scripts/ifcfg-eth0 /etc/passwd /etc/shadow /etc/group /etc/grub2.cfg /etc/resolv.conf /etc/profile //设置系统环境变量 /etc/bashrc //影响bash shell环境 /var/log/messages //系统主日志文件 /var/log/secure //跟安全相关的日志如ssh登录,本地登录...
cat -n 显示行号 -a 包括控制字符(换行符/制表符) linux $ windows ^m$ less more head tail tailf [root@localhost~]# head /etc/passwd [root@localhost~]# head -2 /etc/passwd [root@localhost~]# tail /etc/passwd [root@localhost~]# tail -1 /etc/passwd [root@localhost~]# tail /var/log/messages [root@localhost~]# tail -20 /var/log/messages [root@localhost~]# tail -f /var/log/secure //-f 动态查看文件的尾部 [root@localhost~]# tail -f /var/log/secure //-f 动态查看文件的尾部 注:vim, gedit编辑文件时,索引号会改变 grep 针对文件内容进行过滤 # grep 'root' /etc/passwd # grep '^root' /etc/passwd # grep 'bash$' /etc/passwd # grep 'failure' /var/log/secure
4. 文件管理之:修改文件内容
[root@localhost~]# ll -a > list.txt
文件编辑器 gedit
文件编辑器 vi, vim, nano
命令模式: a. 光标定位 hjkl 0 $ gg g 3g 进入第三行 /string (n n 可以循环的) 快速定位到某一行 /^d /txt$ b. 文本编辑(少量) y 复制 yy 3yy ygg yg (以行为单位) d 删除 dd 3dd dgg dg (以行为单位) p 粘贴 x 删除光标所在的字符 d 从光标处删除到行尾 u undo撤销 ^r redo重做 r 可以用来修改一个字符 c. 进入其它模式 a 进入插入模式 i 进入插入模式 o 进入插入模式 a 进入插入模式 : 进入末行模式(扩展命令模式) v 进入可视模式 ^v 进入可视块模式 v 进入可视行模式 r 进入替换模式 插入模式: 可视块模式: 块插入(在指定块前加入字符): 选择块,i 在块前插入字符, esc 块替换: 选择块,r 输入替换的字符 块删除: 选择块,d | x 块复制: 选择块,y 扩展命令模式: a. 保存退出 :10 进入第10行 :w 保存 :q 退出 :wq 保存并退出 :w! 强制保存 :q! 不保存并退出 :wq! 强制保存退出 :x 保存并退出 zz b. 查找替换 :范围 s/old/new/选项 :1,5 s/root/yang/ 从1-5行的root 替换为yang :5,$ s/root/yang/ $表示最后一行 :1,$ s/root/yang/g = :% s/root/yang/g %表示全文 g表示全局 :% s#/dev/sda#/var/ccc#g :,8 s/root/yang/ 从当前行到第8行 :4,9 s/^#// 4-9行的开头#替换为空 :5,10 s/.*/#&/ 5-10前加入#字符 (.*整行 &引用查找的内容) c. 读入文件/写文件(另存为) :w 存储到当前文件 :w /tmp/aaa.txt 另存为/tmp/aaa.txt :1,3 w /tmp/2.txt :r /etc/hosts 读入文件到当前行后 :5 r /etc/hosts 读入文件到第5行后 d. 设置环境 临时设置: :set nu 设置行号 :set ic 不区分大小写 :set ai 自动缩进 :set list 显示控制字符 :set nonu 取消设置行号 :set noic 永久的环境: /etc/vimrc 影响所有系统用户 ~/.vimrc 影响某一个用户 # vim ~/.vimrc set ic set nu
上一篇: 并发编程-概念部分-1
下一篇: cad怎么快速画窗户的平面图?