2019-07-29
文件管理 ====》创建 移动 删除 复制
cp命令:复制
选项:# -v :详细显示目录执行的操作
# -r :递归处理目录与子目录
# -p :保留源文件或者目录的属性
案例:1.将当前目录下的file文件,复制到/tmp/目录下并重新命名为file_copy
[root@oldboyedu ~]# cp file /tmp/file_copy
[root@oldboyedu ~]# ls /tmp/file_copy
/tmp/file_copy
2.将file复制到/tmp目录下
[root@oldboyedu ~]# cp file1 /tmp/
[root@oldboyedu ~]# cp file1 /tmp/file1 #这种很少使用
3.在拷贝文件的过程中,如何保持文件原有的属性不发生变化
-rw-r--r--. 1 root root 0 Jul 29 10:07 file #第一次修改
-rwxrwxrwx. 1 root root 0 Jul 29 10:03 file #第二次修改
-rwxrwxrwx. 1 adm adm 0 Jul 29 10:03 file #在拷贝的过程中,文件权限和身份都发生了变化
[root@oldboyedu ~]# cp file /tmp/
[root@oldboyedu ~]# ll /tmp/file
-rw-r--r--. 1 root root 0 Jul 29 10:11 /tmp/file
在拷贝过程中加上-p参数,保存文件原有的属性
[root@oldboyedu ~]# cp -p file /tmp/
[root@oldboyedu ~]# ll /tmp/file
-rwxrwxrwx. 1 adm adm 0 Jul 29 10:03 /tmp/file
如何拷贝一个文件夹,并且文件夹中有很多的子文件,-r递归复制(文件夹===目录)
[root@oldboyedu ~]# cp /etc/ /tmp/
cp: omitting directory ‘/etc/’ (报错:/etc是一个目录)
[root@oldboyedu ~]# cp /etc/ /tmp/ -r
拷贝不同路径下的不同文件+不同的目录到同一位置。
[root@oldboyedu ~]# cp -rp file1 oldboy1/ file /etc/ /mnt/ /opt/
[root@oldboyedu ~]# ls /opt/ etc file file1 mnt oldboy1
在复制过程中频繁触发重复复制,提示确认操作?
[root@oldboyedu ~]# \cp -r /etc/ /opt/
[root@oldboyedu ~]# /bin/cp -r /etc/ /opt/
拓展项(复制文件并且改名)
[root@oldboyedu ~]# cp {file5,file5-bak} -v
‘file5’ -> ‘file5-bak’
[root@oldboyedu ~]# cp /etc/sysconfig/networkscripts/{ifcfg-ens32,ifcfg-ens32-bak}
cat:查看文件内容(适合看小文件)
-n:查看一个文件有多少行(显示行号)
-A:查看文件内容的特殊字符,比如文件中存在tab键
扩展使用(新建文件并且写入内容)
案例:[root@oldboyedu ~]# cat >> test.txt <<EOF #EOF代表开始
test1
test2
test3
EOF #EOF 代表结束
[root@oldboyedu ~]# cat test.txt
test1
test2
test3
【less】 【more】:查看大文件,行数成千上万的。
less:#使用光标上下翻动,空格进行翻页,q退出
more:#使用回车上下翻动,空格进行翻页,q退出,显示百分比。
【head】:查看头部文件,默认十行
[root@oldboyedu ~]# head pass #查看头部内容,默认前十行
[root@oldboyedu ~]# head -n5 pass #查看头部5行,使用-n指定
[root@oldboyedu ~]# ps aux | head -5 #了解
【tail】:查看尾部文件内容,默认十行
[root@oldboyedu ~]# tail -20 /var/log/secure
[root@oldboyedu ~]# tail -f /var/log/messages # -f 查看文 件尾部的变化
[root@oldboyedu ~]# tailf /var/log/messages #查看文件 尾部的变化
[root@oldboyedu ~]# ps aux | tail -5 #了解(通道)
【grep】:过滤文件内容
案例:过滤出pass文件中的root相关的行
[root@oldboyedu ~]# grep "root" pass
root:x:0:0:root:/root:/bin/bash
operator:x:11:0:operator:/root:/sbin/nologin
过滤pass文件中,匹配以root开头的行
[root@oldboyedu ~]# grep "^root" pass
root:x:0:0:root:/root:/bin/bash
过滤pass文件中,匹配以bash结尾的行
[root@oldboyedu ~]# grep "bash$" pass
root:x:0:0:root:/root:/bin/bash
jack:x:1000:1000::/home/jack:/bin/bash
显示行号
[root@oldboyedu ~]# grep -n "bash$" pass
1:root:x:0:0:root:/root:/bin/bash
23:jack:x:1000:1000::/home/jack:/bin/bash
扩展了解
# grep -n -A 2 "Failed" /var/log/secure #匹配/var/log/secure文件中Failed字符串,并打印它的下2行
# grep -n -B 2 "Failed" /var/log/secure #匹配/var/log/secure文件中Failed字符串,并打印它的上2行
# grep -n -C 2 "Failed" /var/log/secure #匹配/var/log/secure文件中Failed字符串并打印他的上下两行
过滤出包含ftp的行
[root@oldboyedu ~]# grep "ftp" pass
ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin
过滤除了ftp的行,其他的全部显示
[root@oldboyedu ~]# grep -v "ftp" pass
忽略大小写方式
[root@oldboyedu ~]# grep -i "ftp" pass
ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin
过滤pass文件中以sync结尾的,或者ftp相关的行,打印出来,同时不区分大小写.
# grep -Ei "sync$|ftp" pass
grep筛选的目标,会将整行打印出来.
##grep相关练习题
0、显示当前pass文件中,root、adm或ftp用户相关的信息
[root@oldboyedu ~]# grep -E "^root|^ftp|^adm" pass
root:x:0:0:root:/root:/bin/bash adm:x:3:4:
adm:/var/adm:/sbin/nologin
ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin
1、显示/proc/meminfo文件中以不区分大小的s开头的行;
[root@oldboyedu ~]# grep -i "^s" /proc/meminfo
2、显示/etc/passwd中以nologin结尾的行;
[root@oldboyedu ~]# grep "nologin$" /etc/passwd
3、显示/etc/inittab中以#开头,而后又跟了任意字符的行;
[root@oldboyedu ~]# grep -n "^# .*" /etc/inittab
注释:.======代表任意单个字符 [a-z] [A-Z] [0-9]
* ====== 表示所有
.* ======代表所有的任意字符