1、Linux上的文件管理类命令都有哪些,其常用的使用方法及其相关示例演示
1.1、cp – copy files and directories
单源复制: cp [OPTION]... [-T] SOURCE DEST
如果DEST不存在:则事先创建此文件,并复制源文件的数据流至DEST中;
如果DEST存在:
如果DEST是非目录文件:则覆盖目标文件
如果DEST是目录文件:先在DEST目录下创建一个与源文件同名的文件,并复制其数据流
多源复制: cp [OPTION]... SOURCE... DIRECTORY
cp [OPTION]... -t DIRECTORY SOURCE...
如果DEST不存在:错误
如果DEST存在:
如果DEST是非目录文件:错误
如果DEST是目录文件:分别复制每个文件至目标目录中,并保持原名
常用选项:
-i : 交互式复制,即覆盖之前提醒用户确认
-f : 强制覆盖目标文件
-r : 递归复制目录;
-d : 如果源文件是符号链接,复制符号链接本身,而非其指向的源文件
-a : -dR --preserve=all 用于实现归档
--preserv=
mode : 权限
ownership: 属主和属组
timestamps:时间戳
context : 安全标签
xattr : 扩展属性
links: 符号链接
all: 上述所有属性
1.2、 mv – move (rename) files
命令格式:
mv [OPTION]... [-T] SOURCE DEST
mv [OPTION]... SOURCE... DIRECTORY
mv [OPTION]... -t DIRECTORY SOURCE...
常用选项:
-i : 交互式
-f : force(强制)
1.3、rm – remove files or directories
常用选项:
-i : 交互式
-f : force(强制)
-r : recursive(递归)
2、bash的工作特性之命令执行状态返回值和命令行展开所涉及的内容及其示例演示。
2.1、命令的执行状态结果:
bash通过状态返回值来输出此结果:命令执行后的状态返回值保存于特殊变量 $? 中
成功:0
失败:1-255
注意:只记录最近一次的
[root@localhost ~]# pwd
/root
[root@localhost ~]# echo $?
0
2.2、命令行展开:
~ :自动展开为用户的家目录,或指定的用户的家目录
~USERNAME : 展开为指定用户的家目录
{}:可承载一个以逗号分隔的路径列表,并能够将其展开为多个路径:
例如: /tmp/{a,b} 相当于/tmp/a /tmp/b
3、请使用命令行展开功能来完成以下练习:
3.1、创建/tmp目录下的:a_c, a_d, b_c, b_d
[root@localhost ~]#mkdir /tmp/{a,b}_{c,d}
[root@localhost ~]# ll /tmp/
total 24
drwxr-xr-x. 2 root root 6 Mar 18 10:26 a_c
drwxr-xr-x. 2 root root 6 Mar 18 10:26 a_d
drwxr-xr-x. 2 root root 6 Mar 18 10:26 b_c
drwxr-xr-x. 2 root root 6 Mar 18 10:26 b_d
3.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
[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
4、文件的元数据信息有哪些,分别表示什么含义,如何查看?如何修改文件的时间戳信息。
文件的元数据信息有:
- Size
- Blocks
- IO Block
- Device
- Inode
- Links
- Access
- Context
- access time
- modify time
- change time
查看方式:
[root@localhost ~]# stat /etc/issue
File: '/etc/issue'
Size: 23 Blocks: 8 IO Block: 4096 regular file
Device: 805h/2053d Inode: 67149976 Links: 1
Access: (0644/-rw-r--r--) Uid: ( 0/ root) Gid: ( 0/ root)
Context: system_u:object_r:etc_t:s0
Access: 2018-03-18 07:48:28.417267763 +0800
Modify: 2015-04-01 06:27:02.000000000 +0800
Change: 2018-03-16 01:27:14.433986745 +0800
Birth: -
修改方式文件的时间戳:使用touch命令
touch
touch - change file timestamps
-c :指定的文件路径不存在时不予创建;
-a : 仅修改atime
-m : 仅修改mtime
-t STAMP :
[[CC]YY]MMDDhhmm[.ss]
5、如何定义一个命令的别名,如何在命令中引用另一个命令的执行结果?
定义一个命令的别名使用 alias
定义别名:alias NAME=`COMMAND` 只对当前shell进程有效
例:[root@localhost ~]# alias tt='ls -al'
命令执行结果的引入:
$(COMMAND)或者 `COMMAND`
6、显示/var目录下所有以l开头,以一个小写字母结尾,且中间至少出现一位数字(可以有其它字符)的文件或目录。
[root@localhost ~]# ls -d /var/l*[0-9]*[[:lower:]]
7、显示/etc目录下,以任意一个数字开头,且以非数字结尾的文件或目录。
[root@localhost ~]# ls -d /etc/[0-9]*[^0-9]
8、显示/etc目录下,以非字母开头,后面跟了一个字母以及其它任意长度任意字符的文件或目录。
[root@localhost ~]# ls -d /etc/[^[:alpha:]][[:alpha:]]*
9、在/tmp目录下创建以tfile开头,后跟当前日期和时间的文件,文件名形如:tfile-2016-05-27-09-32-22。
[root@localhost ~]# touch /tmp/ftile-$(date +%Y-%m-%d-%H-%M-%S)
10、复制/etc目录下所有以p开头,以非数字结尾的文件或目录到/tmp/mytest1目录中。
[root@localhost mytest1]# cp -a /etc/p*[^0-9] /tmp/mytest1
11、复制/etc目录下所有以.d结尾的文件或目录至/tmp/mytest2目录中。
[root@localhost mytest1]# cp -a /etc/*.d /tmp/mytest2
12、复制/etc/目录下所有以l或m或n开头,以.conf结尾的文件至/tmp/mytest3目录中。
[root@localhost mytest1]# cp -a /etc/{l,m,n}*.conf /tmp/mytest3
本文来自投稿,不代表Linux运维部落立场,如若转载,请注明出处:http://www.178linux.com/92760