BASH Shell 对文件进行管理

本站所有内容来自互联网收集,仅供学习和交流,请勿用于商业用途。如有侵权、不妥之处,请第一时间联系我们删除!Q群:迪思分享

免费资源网 – https://freexyz.cn/

创建、复制、删除、移动、查看、编辑、压缩、查找

内容提要:

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 varcgroup home lost+found mnt proc selinux tmp

注:下图为Centos7目录结构

BASH Shell 对文件进行管理插图

bin 普通用户使用的命令 /bin/ls,/bin/date sbin 管理员使用的命令 /sbin/service 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

mAI

l: /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@tianyun ~]# ls -l install.log-rw-r–r– 1 root root 34793 10-23 13:49 install.log [root@tianyun ~]# stat install.logFile: “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@tianyun ~]# ll -d /root/anaconda-ks.cfg /bin/ls /home /dev/sda /dev/tty1 /etc/grub.conf /dev/log -rwxr-xr-x 1 root root 117024 417 2012/bin/ls srw-rw-rw-1 root root 0 414 13:29 /dev/log brw-rw—- 1 root disk 8, 0 414 13:30/dev/sda crw–w—-1 root tty 4, 1 414 13:29 /dev/tty1 lrwxrwxrwx. 1 root root 22 413 15:10/etc/grub.conf -> ../boot/grub/grub.conf drwxr-xr-x.5 root root 4096 414 13:40 /home -rw——-. 1 root root 4001 414 14:12 /root/anaconda-ks.cfg

方法二:file

[root@tianyun ~]# file anaconda-ks.cfg anaconda-ks.cfg: ASCII English text [root@tianyun ~]# file /bin/ls /bin/ls: ELF 64-bit LSB executable, x86-64, version 1 (SYSV), dynamically linked (uses shared libs) [root@tianyun ~]# file /home /home/: directory [root@tianyun ~]# file /dev/sda /dev/sda: block special 块设备 [root@tianyun ~]# file /dev/tty1 /dev/tty1: character special (4/1) 字符设备 [root@tianyun ~]# file /etc/grub.conf /etc/grub.conf: symbolic link to `../boot/grub/grub.conf 符号连接 [root@tianyun ~]# file /dev/initctl /dev/initctl: fifo (named pipe) 管道 RHEL6没有该文件[root@tianyun ~]# file /dev/log /dev/log: socket 套接字 二、路径 (定位文件)

你要在哪儿创建文件?

你要将什么文件复制到什么地方?

你要删除什么地方的什么文件? BASH Shell 对文件进行管理插图1

/home/alice/file1 和 /home/bob/file1 不是同一文件!!!

/abc/file5 和 abc/file5 有可能是不一样的!!!

绝对路径: 从/开始的路径 /home/alice/file1

相对路径: 相对于当前目录开始a.txt./a.txt ../bob/b.txt [假如:此时在目录/home/alice]

# useradd alice

# touch /home/alice/file1

# touch ~/file2

# touch ~alice/file3

# pwd

# mkdir abc

# touch ../file3

# touch file4

# touch abc/file5三、文件管理

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@tianyun ~]# type -a cp cp is aliased to `cp -i cp is /bin/cp [root@tianyun ~]# cp -rv /etc/sysconfig/network-scripts/{ifcfg-eth0,ifcfg-eth0.bak} [root@tianyun ~]# cp -rv /etc/sysconfig/network-scripts/ifcfg-eth0{,-org} [root@tianyun ~]# 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@tianyun ~]# mkdir /home/dir10 [root@tianyun ~]# touch /home/dir10/{file2,file3,.file4} [root@tianyun ~]# rm -rf /home/dir10/* //不包括隐藏文件 [root@tianyun ~]# ls /home/dir10/ -a . .. .file4

示例3:

[root@tianyun ~]# rm -rf file* [root@tianyun ~]# 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/grub.conf

/etc/resolv.conf

/etc/profile //设置系统环境变量

/etc/bashrc //影响bash shell环境

/var/log/messages //系统主日志文件

/var/log/secure //跟安全相关的日志如ssh登录,本地登录…

cat

-n 显示行号

-A 包括控制字符(换行符/制表符)

linux $

Windows ^M$

========================================================

扩展知识:

dos2unix 将Windows格式的文件转换成Unix格式

unix2dos 将Unix格式的文件转换成Windows格式 [root@tianyun ~]# wget ftp://172.16.8.100/centos.repo -O /etc/yum.repos.d/centos.repo [root@tianyun ~]# yum -y install unix2dos dos2unix

例如:

[root@tianyun ~]# unix2dos file1 [root@tianyun ~]# dos2unix file2

========================================================

less more head tail tailf

[root@tianyun ~]# head /etc/passwd [root@tianyun ~]# head -2 /etc/passwd [root@tianyun ~]# tail /etc/passwd [root@tianyun ~]# tail -1 /etc/passwd [root@tianyun ~]# tail /var/log/messages [root@tianyun ~]# tail -20 /var/log/messages [root@tianyun ~]# tail -f /var/log/secure //-f 动态查看文件的尾部 [root@tianyun ~]# tail -F /var/log/secure //-F 动态查看文件的尾部

注:vim, gedit编辑文件时,索引号会改变

grep 针对文件内容进行过滤

# grep ‘root’ /etc/passwd

# grep –color ‘root’ /etc/passwd

# grep –color ‘^root’ /etc/passwd

# grep –color ‘bash$’ /etc/passwd

# grep ‘failure’ /var/log/secure

[root@tianyun ~]# gedit ~/.bashrc

alias grep=’grep –color’

4. 文件管理之:修改文件内容

[root@tianyun ~]# ll > list.txt

文件编辑器 gedit

文件编辑器 vi, vim, nano BASH Shell 对文件进行管理插图2

命令模式:

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 进入替换模式

插入模式:

^p 唯一补齐

可视块模式:

块插入(在指定块前加入字符): 选择块,I 在块前插入字符, ESC

块替换: 选择块,r 输入替换的字符

块删除: 选择块,d | x

块复制: 选择块,y

扩展命令模式:

a. 保存退出

:10 进入第10行

:w 保存

:q 退出

:wq 保存并退出

:w! 强制保存

:q! 不保存并退出

:wq! 强制保存退出

😡 保存并退出

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 /aaa.txt 另存为/aaa.txt

:1,3 w/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 [root@tianyun ~]# vim -O /etc/hosts /boot/grub/grub.conf ^ww切换 [root@tianyun ~]# vimdiff grub.conf /boot/grub/grub.conf ^ww切换
免费资源网 – https://freexyz.cn/


© 版权声明
THE END
★喜欢这篇文章吗?喜欢的话,麻烦动动手指支持一下!★
点赞14 分享
评论 抢沙发

请登录后发表评论

    暂无评论内容