Linux基础知识(二)-bash基础特性,文件管理命令

1、Linux上的文件管理类命令都有哪些,其常用的使用方法及相关示例演示。

ls命令

列出制定目录下的文件
ls:list

ls [OPTION]… [FILE]…

OPTION:
-a : 显示所有文件,包括.开头的隐藏文件
-A: 显示除.和..意外的所有文件
-l : –long 长格式列表, 显示文件的详细属性信息.
-rw-r–r–. 1 root root   8531 Sep 18 14:54 boot.log

  • : 文件类型. – , d ,b , c , l,s p
    rw-r–r– :
    rw-:文件属主的权限
    r–:文件属组的权限
    r–:其他用户()的权限
    1: 数字表示文件被硬连接的次数
    root:文件的属主
    root:文件的属组
    8531 : 文件大小,单位是字节
    Sep 18 14:54 : 最后一次修改时间,
    boot.log: 文件名
    -h: –human–readable , 对文件大小单位换算.转换后可能不准确(损失精度)
    -d:常看目录自身而非其内部的文件列表
    -r:reverse , 逆序显示
    -R : recursive  , 递归显示

文件管理工具:cp, mv, rm

cp命令

copy

单源复制:cp [OPTION]… [-T] SOURCE DEST
多源复制:cp [OPTION]… SOURCE… DIRECTORY
cp [OPTION]… -t DIRECTORY SOURCE…

SOURCE:源文件
DEST:目标文件

单源复制:cp [OPTION]… [-T] SOURCE DEST
如果DEST不存在:则事先创建此文件,并复制源文件的数据流至DEST中;
如果DEST存在

  • 如果DEST是非目录文件:则覆盖目标文件;(危险操作)

  • 如果DEST是目录文件:则先在DEST目录下创建一个与源文件同名的文件,并复制其数据流;

[root@localhost ~]# echo 1231231 >> /tmp/hello.txt
[root@localhost ~]# cat /tmp/hello.txt
1231231
[root@localhost ~]# cp /etc/fstab /tmp/hello.txt
cp: overwrite ‘/tmp/hello.txt’? y       #是否确认覆盖?
[root@localhost ~]# cat /tmp/hello.txt

#
# /etc/fstab
# Created by anaconda on Sun Sep 18 14:47:41 2016
#
# Accessible filesystems, by reference, are maintained under '/dev/disk'
# See man pages fstab(5), findfs(8), mount(8) and/or blkid(8) for more info
#
/dev/mapper/centos-root /                       xfs     defaults        0 0
UUID=fe676930-4def-488f-ad61-eb0c8e108afc /boot                   xfs     defaults        0 0
/dev/mapper/centos-home /home                   xfs     defaults        0 0
/dev/mapper/centos-swap swap                    swap    defaults        0 0

多源复制:cp [OPTION]… SOURCE… DIRECTORY
cp [OPTION]… -t DIRECTORY SOURCE…

如果DEST不存在:错误;
如果DEST存在

  • 如果DEST是非目录文件:错误;

  • 如果DEST是目录文件:分别复制每个文件至目标目录中,并保持原名;

常用选项:
-i:交互式复制,即覆盖之前提醒用户确认;
-f:强制覆盖目标文件;
-r, -R:递归复制目录;
-d:复制符号链接文件本身,而非其指向的源文件;相当于–no-dereference –preserve=links
-a:-dR –preserve=all, archive,用于实现归档;
–preserve=

  • mode:权限

  • ownership:属主和属组

  • timestamps: 时间戳

  • context:安全标签

  • xattr:扩展属性

  • links:符号链接

  • all:上述所有属性

eg:

[root@localhost ~]# cp /etc/system-release /tmp     #/etc/system-release是快捷方式,使用cp复制到/tmp下,是把system-release指向的内容复制过来
[root@localhost ~]# cat /tmp/system-release
CentOS Linux release 7.2.1511 (Core) 
[root@localhost ~]# cp -d /etc/system-release /tmp/system.rel       #加上-d 选项 则是复制链接文件本身.
[root@localhost ~]# ls -l /tmp
lrwxrwxrwx. 1 root root  14 Sep 21 02:33 system.rel -> centos-release

mv命令

move
mv [OPTION]… [-T] SOURCE DEST
mv [OPTION]… SOURCE… DIRECTORY
mv [OPTION]… -t DIRECTORY SOURCE..

常用选项:
-i:交互式;
-f:force

rm命令

remove
rm [OPTION]… FILE…

常用选项:
-i:interactive 交互式,删除前提示
-f:force       强制删除
-r: recursive   递归删除

删除目录:rm -rf /PATH/TO/DIR
危险操作:
rm -rf /*
rm -rf /

注意:所有不用的文件建议不要直接删除,而是移动至某个专用目录;(模拟回收站)

2、bash的工作特性之命令执行状态返回值和命令行展开所涉及的内答及其示例演示

命令的执行状态结果

命令的执行状态结果

命令执行的状态结果
bash通过状态返回值来输出此结果:
成功:0
失败:1-255

命令执行完成之后,其状态返回值保存于bash的特殊变量$?中;

命令正常执行时,有的还回有命令返回值:
根据命令及其功能不同,结果各不相同;

引用命令的执行结果
$(COMMAND)
或`COMMAND`    反引号

[root@localhost ~]# echo $?
0
15-20-1474226454  mysysroot  x
[root@localhost ~]# mkdir /tmp/$(date +%H-%M-%S)
[root@localhost ~]# ls /tmp
15-21-12  mysysroot  x

命令行展开

~:自动展开为用户的家目录,或指定的用户的家目录;
{}:可承载一个以逗号分隔的路径列表,并能够将其展开为多个路径;
例如:/tmp/{a,b} 相当于 /tmp/a /tmp/b

问题1:如何创建/tmp/x/y1, /tmp/x/y2, /tmp/x/y1/a, /tmp/x/y1/b?
问题2:如何创建a_c, a_d, b_c, b_d;
问题3:创建如下目录结构:

            /tmp/mysysroot/
                |-- bin
                |-- etc
                |   `-- sysconfig
                |       `-- network-scripts
                |-- sbin
                |-- usr
                |   |-- bin
                |   |-- lib
                |   |-- lib64
                |   |-- local
                |   |   |-- bin
                |   |   |-- etc
                |   |   |-- lib
                |   |   `-- sbin
                |   `-- sbin
                `-- var
                    |-- cache
                    |-- log
                    `-- run

问题1:mkdir -pv /tmp/x/{y1/{a,b},y2}
问题2:mkdir -v {a,b}_{c,d}

[root@localhost ~]# mkdir -pv /tmp/x/{y1/{a,b},y2}
mkdir: created directory ‘/tmp/x/y1’
mkdir: created directory ‘/tmp/x/y1/a’
mkdir: created directory ‘/tmp/x/y1/b’
mkdir: created directory ‘/tmp/x/y2’

问题3:mkdir -pv /tmp/mysysroot/{bin,sbin,etc/sysconfig/network-scripts,usr/{bin,sbin,local/{bin,sbin,etc,lib},lib,lib64},var/{cache,log,run}}

3、请使用命令行展开功能来完成以下练习:

(1).创建/tmp目录下的:a_c,a_d,b_c,b_d
(2).创建/tmp/mylinux目录下的:

mylinux/
├── bin
├── boot
│   └── grub
├── dev
├── etc
│   ├── rc.d
│   │   └── init.d
│   └── sysconfig
│       └── network-scripts
├── lib
│   └── modules
├── lib64
├── proc
├── sbin
├── sys
├── tmp
├── usr
│   └── local
│       ├── bin
│       └── sbin
└── var
    ├── lock
    ├── log
    └── run

问题1:

[root@localhost ~]# mkdir -pv /tmp/{a,b}_{c,d}
mkdir: created directory ‘/tmp/a_c’
mkdir: created directory ‘/tmp/a_d’
mkdir: created directory ‘/tmp/b_c’
mkdir: created directory ‘/tmp/b_d’

问题2:

[root@localhost ~]# mkdir -pv /tmp/mylinux/{bin,boot/grub,dev,etc/{rc.d/init.d,sysconfig/network-scripts},lib/modules,lib64,proc,sbin,sys,tmp,usr/local/{bin,sbin},var/{lock,log,run}}
[root@localhost ~]# tree /tmp/mylinux
/tmp/mylinux
├── bin
├── boot
│   └── grub
├── dev
├── etc
│   ├── rc.d
│   │   └── init.d
│   └── sysconfig
│       └── network-scripts
├── lib
│   └── modules
├── lib64
├── proc
├── sbin
├── sys
├── tmp
├── usr
│   └── local
│       ├── bin
│       └── sbin
└── var
    ├── lock
    ├── log
    └── run

24 directories, 0 files

4、文件的元数据信息有哪些,分别表示什么含义,如何査看?如何修改文件的时间戳信息。

stat命令

stat – display file or file system status
显示文件或文件系统的状态

stat FILE…

文件:两类数据
元数据:metadata:access(最后访问),modify(最后修改),change(最后改变)
数据: data

时间戳:
access time:2015-12-10 16:12:22.776423693 +0800
modify time:2015-12-10 16:12:22.776423693 +0800
change time:2015-12-10 16:12:22.776423693 +0800

eg:使用stat查看文件元数据

[root@localhost ~]# echo 123 >> /tmp/functions
[root@localhost ~]# stat /tmp/functions
  File: ‘/tmp/functions’
  Size: 4           Blocks: 8          IO Block: 4096   regular file
Device: fd00h/64768d    Inode: 134         Links: 1
Access: (0644/-rw-r--r--)  Uid: (    0/    root)   Gid: (    0/    root)
Context: unconfined_u:object_r:user_tmp_t:s0
Access: 2016-09-18 15:38:47.104522265 -0400     #最近访问
Modify: 2016-09-18 15:38:47.104522265 -0400     #最近更改:数据修改
Change: 2016-09-18 15:38:47.104522265 -0400     #最近改动:元数据修改&数据修改

touch命令

touch – change file timestamps
修改文件时间戳

touch [OPTION]… FILE…
-c: 指定的文件路径不存在时不予创建;
-a: 仅修改access time;
-m:仅修改modify time;
-t STAMP
[[CC]YY]MMDDhhmm[.ss]

eg:touch命令给文件指定时间戳

[root@localhost ~]# touch -m -t 0212010810.00 /tmp/functions  #修改文件Modify为2012-12-01 08:00.00

直接touch FILE… 修改文件Access,Modify,Change 时间

5、如何定义一个命令的别名,如何在命令中引用另一个命令的执行结果?

定义命令别名使用alias命令

alias命令

别名

获取所有可用的别名定义
~]# alias
定义别名
~]# alias NAME='COMMAND'
仅对当前shell进程有效
撤销别名:
~]# unalias NAME

eg:

[root@localhost ~]# alias
alias cp='cp -i'
alias egrep='egrep --color=auto'
alias fgrep='fgrep --color=auto'
alias grep='grep --color=auto'
alias l.='ls -d .* --color=auto'
alias ll='ls -l --color=auto'
alias ls='ls --color=auto'
alias mv='mv -i'
alias rm='rm -i'
alias which='alias | /usr/bin/which --tty-only --read-alias --show-dot --show-tilde'
[root@localhost ~]# type alias      
alias is a shell builtin
[root@localhost ~]# alias cls=clear
[root@localhost ~]# cls
[root@localhost ~]# unalias cls
[root@localhost ~]# cls
bash: cls: command not found...

在命令中引用另一个命令的执行结果,使用管道 |

管道

连接程序,实现将前一个命令的输出直接定向给后一个程序当作输入数据流
COMMAND1 | COMMAND2 | COMMAND3 | …

globbing:文件名通配

(整体文件名匹配,而非部分)

匹配模式:元字符
*:匹配任意长度的任意字符
pa*, *pa*, *pa, *p*a*

  • pa, paa, passwd

?:匹配任意单个字符
pa?, ??pa, p?a, p?a?

  • pa, paa, passwd

[]:匹配指定范围内的任意单个字符
有几种特殊格式:
[a-z], [A-Z], [0-9], [a-z0-9]
[[:upper:]]:所有大写字母
[[:lower:]]:所有小写字母
[[:alpha:]]:所有字母
[[:digit:]]:所有数字
[[:alnum:]]:所有的字母和数字
[[:space:]]:所有空白字符
[[:punct:]]:所有标点符号

pa[0-9][0-9], 2[0-9][0-9]
[^]:匹配指定范围外的任意单个字符

[^[:upper:]]  所有非大写字母
[^0-9]        所有非数字
[^[:alnum:]]  所有非字母和数字

6、显示/var目录下所有以l开头,以一个小写字母结尾,且中间至少出现一位数字(可以有其它字符)的文件或目录。

[root@localhost ~]# ls -d /var/l*[0-9]*[[:lower:]]
/var/l100abc

7、显示/etc目录下,以任意一个数字开头,且以非数字结尾的文件或目录。

ls -d /etc/[0-9]*[^0-9]

8、显示/etc目录下,以非字母开头,后面跟了一个字母以及其它任意长度任意字符的文件或目录。

ls -d [^a-z][a-z]*

9、在/tmp目录下创建tfile开头,后跟当前日期和时间的文件,文件名形如:tfile-2016-05-27-09-32-220

mkdir /tmp/tfile-$(date +%Y-%m-%d-%H-%M-%S )

10、复制/etc目录下所有以p开头,以非数字结尾的文件或目录到/tmp/mytest1目录中。

cp -r /etc/p*[^0-9] /tmp/mytest1

11、复制/etc目录下所有以.d结尾的文件或目录至/tmp/mytest2目录中

cp -r /etc/*.d /tmp/mytest2

12、复制/etc目录下所有以l或m或n开头,以.conf结尾的交件至/tmp/mytest3目录中.

cp -r /etc/[lmn]*.conf /tmp/mytest3

原创文章,作者:luoluo,如若转载,请注明出处:http://www.178linux.com/48951

(0)
luoluoluoluo
上一篇 2016-09-26 07:41
下一篇 2016-09-26 07:41

相关推荐

  • 8月20日软件包管理

    软件包管理 本章内容 软件运行环境 软件包基础 Rpm包管理 yum管理 定制yum仓库 编译安装 软件运行环境 API:Application Programming Interface     POSIX:Portable OS 程序源代码–>预处理–>编译–>…

    Linux干货 2016-08-21
  • 聊聊CentOS6的启动过程

    前言:     作为一个合格的运维人员,系统的启动过程我们需要牢记在心,此文不深入探讨,只求大致理解CentOS6的启动过程。 一张图带你了解CentOS6的启动过程 注意:图片放大查看效果更佳 上图各阶段详解 POST:计算机开机时BIOS对其各硬件的简单测试,测试各硬件的完整性 BootSqunce:加电自检后根据…

    Linux干货 2016-03-14
  • Linux的哲学思想

    Linux的哲学思想 一切皆文件 在linux中所有的一切,都是可以通过ls进行查询的到的,甚至可以说ll查看详细信息时表现形式为文件,所有的设备,所有的文件不论后缀,只是一个单纯文件通过vim可以编辑一切 单一目的的小程序,组合小程序完成复杂任务 在linux中,每一个命令都是对应一个功能,通过不同的参数来完成不同的要求,通过繁多的小的命令来完成大型的要求…

    Linux干货 2016-10-30
  • Linux系统上命令的使用格式与十二个常用命令详解

    Linux系统上命令的使用格式 命令的语法通用格式: ~]# COMMAND OPTIONS ARGUMENTS 例如: ls -ld /var COMMAND(命令): ls ls命令用来显示目标列表 OPTIONS(选项): -ld -ld 是 -l -d 的简写 -l 以详细格式列表 -d 仅列目录 ARGUMENTS(参数): /var 命令对这个/…

    2018-02-26
  • 正则表达式以及Linux文本搜索工具grep

    一正则表达式 regual Expression  简称REGEXP 定义:由一类特殊字符以及文本字所编写的模式,其中有些字符不表示其字面意义,而用于统配和统配功能 分类:     基本正则表达式:BRE 贪婪模式(尽可能长地去匹配符合模式的内容     扩展表达式:E…

    Linux干货 2016-08-07
  • 马哥教育网络班21期+第14周课程练习

    iptables关键点 表:filter(过滤,防火墙);nat(网络地址转换);mangle(拆解报文,做出修改,封装报文);raw(关闭nat表启用的链接追踪机制);上述是根据功能来区分的,写规则要明白要实现的功能 链:PREROUTING,INPUT,FORWARD,OUTPUT,POSTROUTING 数据流向:流入PREROUTING–…

    Linux干货 2016-08-26