day4_文件管理相关命令

Linux文件管理相关管理命令

上周回顾:

1.Base怎么使用 :单条命令 效率低 适合管理 或者少量的任务

            shell脚本效率高 适合负责 重复性的工作

2.Bash 提示符

    [root@oldboyedu ~]#

      当前登录系统的用户 --->root                              当前系统的主机名称 --->oildboyedu 当前用户所在的家目录 ---> ~ 表示当前用户的家目录                                                                通常情况下是超级管理员 # 普通用户 $

3.Bash基础语法

命令[选项]  [参数]

命令(打针) 选项(轻重)参数(往哪里打)

ls -la /home/    以长格式显示/home/下所有内容,包括隐藏文件

4.Bash 常用特性

  tab补全    快捷键 ctrl +a, e,c,l    命令别名 alias unalias

历史记录 history  命令帮助  man --help

5.Windows C:\ D:\ E:\ Linux / ---> 单根组织结构 在Linux / 目录下有很多的二级目录,这么目录都是什么意思

/bin #存放都是二进制可执行的命令

/sbin #超级管理员可执行的二进制命令

/home #普通用户的家目录 /home/oldboy

/root # 超级管理员的家目录 (普通用户无权限) /etc # 系统的配置文件存放路径,包括后续安装的一些服务

/dev # 存放设备目录 /dev/null #黑洞设备, 只进不出 /dev/random # 随机设备 /dev/zero # 能源源不断的产生数据, 取款机

/proc # 虚拟系统文件 (显示系统当前进程正在运行的状态)

/usr # 存放系统文件 和Windows的C盘下的WIndows目录一样

/usr/local # /usr/bin # 和/bin一致,只不过/usr/bin才是真实的命令存放 路径 /usr/sbin # 和/sbin一致,只不过

/usr/sbin才是真实的命令存 放路径/usr/lib # 库文件, 命令所依赖的库文件

/usr/lib64 # 64库文件, 命令所依赖的库文件 /boot # 系统启动时的引导目录 , 存放的是kernel,grub菜单

/run # 存放进程锁文件 /opt #早起第三方厂商安装软件存放的目录

/mnt # 挂载, 将目录与设备进行关联, 比如 硬盘,光盘

6.文件路径定位

/etc/hostname 文件位置+文件名称=路径    换句话说:路径则是对文件定义的一种方式

绝对路径:只要以/开始的路径,都算是绝对路径。

相对路径:相对于当前目录来说的路径 ,    .当前目录  ..当前目录的上一级目录

没有明确的说法,取决你当前所在的位置

7.文件管理命令

mkdir 创建目录

  touch 创建文件

  mv 移动或重新命名

rm 删除文件

                              第四天内容

          -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.将file1复制到/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#4.如何拷贝一个文件夹,并且文件夹中有很多的子文件, -r递归复制  (文件夹===目录)

将一个目录复制到另一个目录下 用-r

[root@oldboyedu ~]# cp /etc/ /tmp/

cp: omitting directory ‘/etc/’

[root@oldboyedu ~]# cp /etc/ /tmp/ -r

5.拷贝不同路径下的不同文件至同一个目录下        -v是显示详细过程

[root@oldboyedu ~]# cp file1  /etc/hostname  /etc/hosts  /opt/ -v

将 当前目录下 file1 /etc/hostname  /etc/hosts 拷贝到  /opt/ 并显示详细过程

‘file1’ -> ‘/opt/file1’

‘/etc/hostname’ -> ‘/opt/hostname’

‘/etc/hosts’ -> ‘/opt/hosts’

6.拷贝不同路径下的不同文件+不同的目录 至同一个位置 怎么办?

[root@oldboyedu ~]# cp -rp file1 oldboy1/ file /etc/ /mnt/ /opt/

将当前目录下文件file1  oldboy1下的file  /etc/  /mnt/  拷贝到 /opt/下面保留原本属性,拷贝目录 用r

[root@oldboyedu ~]# ls /opt/

etc  file  file1  mnt  oldboy1

7..在复制过程中频繁触发重复复制,提示确认操作?

[root@oldboyedu ~]# \cp -r /etc/ /opt/

[root@oldboyedu ~]# /bin/cp -r /etc/ /opt/

8.扩展项

[root@oldboyedu ~]# cp {file5,file5-bak} -v 显示详细操作

‘file5’ -> ‘file5-bak’

将file5文件复制 改成叫file5-bak的文件 俩份都在

[root@oldboyedu ~]# cp /etc/sysconfig/networkscripts/{ifcfg-ens32,ifcfg-ens32-bak}

2文件管理之:查看文件内容(cat less more head tail grep)

cat

[root@oldboyedu ~]# cp /etc/passwd ./pass

[root@oldboyedu ~]# cat pass        #查看文件的所有内容,从 头到尾

[root@oldboyedu ~]# cat -n pass    #查看一个文件有多少行  -n

[root@oldboyedu ~]# cat -A pass    ##查看文件的特殊符号, 比如文件中存在tab键

cat扩展使用,创建一个文件,并往里面写入内容

[root@oldboyedu ~]# cat >> test.txt <<EOF    #EOF代表开 始

test1

test2

test3

EOF            #EOF 代表结束

[root@oldboyedu ~]# cat test.txt

test1

test2

test3

#------less、more # less /etc/services    #使用光标上下翻动,空格进行翻页,q退 出 # more /etc/services    #使用回车上下翻动,空格进行翻页,q退 出#------head

[root@oldboyedu ~]# head pass    #查看头部内容,默认前十行

[root@oldboyedu ~]# head -n5 pass #查看头部5行,使用-n指定

[root@oldboyedu ~]# ps  aux | head -5  #了解

#------tail # tail pass    #查看文件尾部默认十行[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过滤文件内容

#1. 过滤出pass文件中的root相关的行

[root@oldboyedu ~]# grep "root" pass

root​:x:​0:0:root:/root:/bin/bash                       

operator​:x:​11:0:operator:/root:/sbin/nologin

2过滤pass文件中,匹配以root开头的行

[root@oldboyedu ~]# grep "^root" pass

root​:x:​0:0:root:/root:/bin/bash

3.过滤pass文件中,匹配以bash结尾的行 $

[root@oldboyedu ~]# grep "bash$" pass

root​:x:0:0:root:/root:/bin/bash

jack​:x:1000:1000::/home/jack:/bin/bash

#4.显示行号  -n

[root@oldboyedu ~]# grep -n "bash$" pass

1:root​:x:0:0:root:/root:/bin/bash

23:jack​:x:1000:1000::/home/jack:/bin/bash

#5.扩展了解

#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字符串,并且打印上下俩行。

#9.过滤pass文件中以sync结尾的,或者ftp相关的行,打印出来.同时不 区分大小写

#grep  -Ei "sync$|ftp" pass

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/passwd3、显示/etc/inittab中以#开头,而后又跟了任意字符的行;

[root@oldboyedu ~]# grep -n  "^# .*" /etc/inittab

.  代表任意单个字符  [a-z]  [A-Z]  [0-9]

.表示所有

.* 代表所有的任意字符

包含命令 cp  cat  less  more  head  tail  tailf  grep

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

友情链接更多精彩内容