标签:第二周作业
1、Linux上的文件管理类命令都有哪些,其常用的使用方法及其相关示例演示。
Linux上的文件管理类命令:
cp命令;复制文件或目录
单源复制:cp [OPTION]...[-T] SRC DEST
多源复制:cp [OPTION]...SRC...DIRECTORY
cp [OPTION]...[-T] SRC DEST
其常用选项为:-i 交互式,提醒目标存在,是否覆盖。
-r,-R:递归复制源目录下所有目录与文件
-a 归档复制,保留所有的文件的元数据,相当于-dR --preserv=all
-p --preserv=mode,ownership,timestamp
-v --verbose
[root@localhost ~]# cp -r /etc/passwd /tmp [root@localhost ~]# ls /tmp passwd
mv命令为移动文件或目录
格式: mv [OPTION]... [-T] SOURCE DEST
mv [OPTION]... SOURCE... DIRECTORY
mv [OPTION]... -t DIRECTORY SOURCE...
常用选项:类似于cp命令
-f 强制执行
[root@localhost tmp]# mkdir /tmp/mycentos [root@localhost tmp]# mv /tmp/passwd /tmp/mycentos [root@localhost tmp]# ls /tmp/mycentos/ passwd
` 注意:在同一目录下使用mv命令相当于重命名;
[root@localhost mycentos]# mv ./passwd ./passwd.bat [root@localhost mycentos]# ls passwd.bat
rm:删除文件
格式:rm [OPTION]... FILE...
-i 交互式
-f 强制删除
-r 递归删除
[root@localhost mycentos]# rm passwd.bat rm: remove regular file ‘passwd.bat’? y [root@localhost mycentos]# ls [root@localhost mycentos]#
2、bash的工作特性之命令执行状态返回值和命令行展开所涉及的内容及其示例演示。
bash的基础特性之状态值返回:在bash中使用一个特殊的变量$?来保存上一个命令的执行状态结果。0表示成功,1-255表示失败
成功实例:
[root@localhost mycentos]# cd [root@localhost ~]# echo $? 0
失败示例:
[root@localhost ~]# cdd -bash: cdd: command not found [root@localhost ~]# echo $? 127
bash的基础特性之命令行展开:~ username:展开指定用户的主目录;{}:可承载一个以逗号为分隔符的列表,并将其展开为多个路径。
3、请使用命令行展开功能来完成以下练习:
(1)、创建/tmp目录下的:a_c, a_d, b_c, b_d
mkdir /tmp/{a,b}_{c,d}
演示结果如下:
[root@localhost ~]# mkdir /tmp/{a,b}_{c,d} [root@localhost ~]# ls /tmp a_c a_d b_c b_d mycentos [root@localhost ~]#
(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
mkdir -p /tmp/mylinux/{bin,boot/grub,dev,etc/{rc.d/init.d,sysconfig/ne
twork-scripts},lib/modules,lib64,proc,sbin,sys,tmp,usr/local/{bin,sbin},var,lock,log,run}
演示结果如下:
[root@localhost ~]# mkdir -p /tmp/mylinux/{bin,boot/grub,dev,etc/{rc.d/init.d,sysconfig/network-scripts},lib/modules,lib64,proc,sbin,sys,tmp,usr /locl/{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 ├── lock ├── log ├── proc ├── run ├── sbin ├── sys ├── tmp ├── usr │ └── locl │ ├── bin │ └── sbin └── var 24 directories, 0 files
4、文件的元数据信息有哪些,分别表示什么含义,如何查看?如何修改文件的时间戳信息。
元数据由下面以下几个方面组成:文件类型、文件相关权限(属主权限、属组权限、其他用户权限)、链接数、属主、属组、文件大小、最后一次修改的时间。可以使用 ls -dl /filename来查看相关的信息或者stat /filename来查看;可以通过touch 命令来修改时间戳信息,[OPTION] -a atime 修改访问时间,-m mtime 只更改文件修改时间,-t TAMP 使用指定的时间来修改;
ls -ld :
[root@localhost ~]# ls -ld /etc drwxr-xr-x. 76 root root 8192 Aug 12 10:42 /etc
stat:可以查看更详细的元数据
[root@localhost ~]# stat /etc File: ‘/etc’ Size: 8192 Blocks: 24 IO Block: 4096 directory Device: fd00h/64768d Inode: 33554561 Links: 76 Access: (0755/drwxr-xr-x) Uid: ( 0/ root) Gid: ( 0/ root) Context: system_u:object_r:etc_t:s0 Access: 2016-08-12 13:02:16.744187506 -0400 Modify: 2016-08-12 10:42:46.392998847 -0400 Change: 2016-08-12 10:42:46.392998847 -0400 Birth: -
touch:修改时间戳
[root@localhost ~]# touch -t 201607301305.20 /tmp/file20160813 [root@localhost ~]# stat /tmp/file20160813 File: ‘/tmp/file20160813’ Size: 0 Blocks: 0 IO Block: 4096 regular empty file Device: fd00h/64768d Inode: 67972116 Links: 1 Access: (0644/-rw-r--r--) Uid: ( 0/ root) Gid: ( 0/ root) Context: unconfined_u:object_r:user_tmp_t:s0 Access: 2016-07-30 13:05:20.000000000 -0400 Modify: 2016-07-30 13:05:20.000000000 -0400 Change: 2016-08-12 14:44:03.740595553 -0400 Birth: -
5、如何定义一个命令的别名,如何在命令中引用另一个命令的执行结果?
使用alias命令来实现,格式为 alias NAME="需定义的原命令",可以通过管道来实现,格式为COMMAND1 | COMMAND2 | ...
命令别名示例:
[root@localhost ~]# alias mkdp=‘mkdir -p‘ [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 mkdp=‘mkdir -p‘ 此处,别名创建成功
管道示例:
[root@localhost ~]# cat /etc/passwd | wc -l 21
6、显示/var目录下所有以l开头,以一个小写字母结尾,且中间至少出现一位数字(可以有其它字符)的文件或目录。
ls -d /var/l*[[:digit:]]*[[:lower:]]
[root@yang ~]# mkdir /var/l45ab [root@yang ~]# ls -d /var/l*[[:digit:]]*[[:lower:]] /var/l45ab: /var/l4ad:
7、显示/etc目录下,以任意一个数字开头,且以非数字结尾的文件或目录。
ls -d /etc/[[:digit:]]*[^[:digit:]]
演示:由于初始查询无可以匹配的文件,故先创建一个目录,便于显现结果。
[root@yang ~]# mkdir /etc/51cto.com [root@yang ~]# ls -d /etc/[[:digit:]]*[^[:digit:]] /etc/51cto.com
8、显示/etc目录下,以非字母开头,后面跟了一个字母以及其它任意长度任意字符的文件或目录。
ls -d /etc/[^[:alpha:]][[alpha]]*
[root@yang ~]# ls -d /etc/[^[:alpha:]][[:alpha:]]* /etc/5cto
9、在/tmp目录下创建以tfile开头,后跟当前日期和时间的文件,文件名形如:tfile-2016-08-06-09-32-22。
mkdir /tmp/tfile-$(date +%Y-%m-%d-%H-%M-%S)
root@localhost ~]# mkdir /tmp/tfile-$(date +%Y-%m-%d-%H-%M-%S) [root@localhost ~]# mkdir /tmp/tfile-$(date +%Y-%m-%d-%H-%M-%S) [root@localhost ~]# mkdir /tmp/tfile-$(date +%Y-%m-%d-%H-%M-%S) [root@localhost ~]# mkdir /tmp/tfile-$(date +%Y-%m-%d-%H-%M-%S) [root@localhost ~]# ls /tmp tfile-2016-08-12-15-19-33 tfile-2016-08-12-15-19-35 tfile-2016-08-12-15-19-37 tfile-2016-08-12-15-19-40 tfile-2016-08-12-15-19-48 [root@localhost ~]#
10、复制/etc目录下所有以p开头,以非数字结尾的文件或目录到/tmp/mytest1目录中。
mkdir /tmp/mytest1 ; cp -r /etc/p*[^[:digit:]] /tmp/mytest1
[root@localhost ~]# mkdir /tmp/mytest1;cp -r /etc//p*[^[:digit:]] /tmp/mytest1 [root@localhost ~]# ls /tmp/mytest1 pam.d passwd passwd- pki plymouth pm popt.d postfix ppp prelink.conf.d printcap profile profile.d protocols python [root@localhost ~]#
11、复制/etc目录下所有以.d结尾的文件或目录至/tmp/mytest2目录中。
mkdir /tmp/mytest2 ; cp -r /etc/*.d /tmp/mytest2
[root@localhost ~]# mkdir /tmp/mytest2 ; cp -r /etc/*.d /tmp/mytest2 [root@localhost ~]# ls /tmp/mytest2 bash_completion.d depmod.d init.d modules-load.d prelink.conf.d rc2.d rc6.d statetab.d xinetd.d binfmt.d dnsmasq.d ld.so.conf.d my.cnf.d profile.d rc3.d rc.d sudoers.d yum.repos.d chkconfig.d dracut.conf.d logrotate.d pam.d rc0.d rc4.d rsyslog.d sysctl.d cron.d grub.d modprobe.d popt.d rc1.d rc5.d rwtab.d tmpfiles.d [root@localhost ~]#
12、复制/etc/目录下所有以l或m或n开头,以.conf结尾的文件至/tmp/mytest3目录中。
mkdir /tmp/mytest3 ; cp /etc/{l,m,n}*.conf /tmp/mytest3
root@localhost ~]# mkdir /tmp/mytest3 ; cp /etc/{l,m,n}*.conf /tmp/mytest3 [root@localhost ~]# ls /tmp/mytest3 ld.so.conf libaudit.conf libuser.conf locale.conf logrotate.conf man_db.conf mke2fs.conf nsswitch.conf [root@localhost ~]#
本文出自 “小憩清风” 博客,请务必保留此出处http://xiaoqiqingfeng.blog.51cto.com/3720264/1837634
标签:第二周作业
原文地址:http://xiaoqiqingfeng.blog.51cto.com/3720264/1837634