马哥教育网络第21期-第二周课程练习

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

   linux中经常使用的文件管理命令主要有cp,mv,rm这三个命令。
    复制命令:cp
    cp [option] SRC DEST
        SRC是文件:
            如果目标不存在:新建DEST,将SRC的内容填充到DEST中。
            目标存在:将SRC的内容覆盖到DESC中。
[root@localhost mnt]# cp -i /etc/passwd /mnt
[root@localhost mnt]# ls
lineout.sh  passwd  spaceline.sh  useridsum.sh
[root@localhost mnt]#
[root@localhost mnt]# cp -i /etc/passwd /mnt/abc
[root@localhost mnt]# ls
abc

        SRC为多个文件:

            DESC必须存在且为目录。

[root@localhost mnt]# cp  -i /etc/shadow /etc/group /mnt
[root@localhost mnt]# ls
group  lineout.sh  passwd  shadow  spaceline.sh  useridsum.sh
[root@localhost mnt]#

        SRC是目录:  

            使用选项:-r

            DESC不存在则自动创建,DESC存在时必须是目录,文件会报错。

[root@localhost home]# ls
jtah
[root@localhost home]# cp -r jtah/ /mnt
         常用选项:  
    -i:交互式
            -r, -R: 递归复制目录及内部的所有内容;
            -a: 归档,相当于-dR --preserv=all
        -d:--no-dereference --preserv=links
        --preserv[=ATTR_LIST]
        mode: 权限
        ownership: 属主属组
        timestamp: 
        links
        xattr
        context
        all
        -p: --preserv=mode,ownership,timestamp
        -v: --verbose
        -f: --force
    移动文件:mv
        mv [option] SRC DESC
        常用选项:
        -i: 交互式
        -f: 强制
    删除文件:rm
        rm [option] FILE
        常用选项:
    -i: 交互式
    -f: 强制删除
    -r: 递归

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

bash命令执行的结果有两种成功或失败,成功的返回值用0表示,1-255表示失败。bash使用echo $?来保存最近一条命令的执行结果。

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

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

root@localhost tmp]# mkdir {a,b}_{c,d}
[root@localhost tmp]# ls -l
总用量 76
drwxr-xr-x. 2 root root     6 7月  16 22:18 a_c
drwxr-xr-x. 2 root root     6 7月  16 22:18 a_d
drwxr-xr-x. 2 root root     6 7月  16 22:18 b_c
drwxr-xr-x. 2 root root     6 7月  16 22:18 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
[root@localhost tmp]# mkdir -p 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 tmp]# tree mylinux/
mylinux/
├── bin
├── boot
│   └── grub
├── dev
├── etcrc.d
│   └── init.d
├── etcsysconfig
│   └── network-scripts
├── lib
│   └── modules
├── lib64
├── proc
├── sbin
├── sys
├── tmp
├── usr
│   ├── localbin
│   └── localsbin
└── var
    ├── lock
    ├── log
    └── run

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

文件系统中的数据分为数据和元数据,数据是指普通文件的实际数据,元数据是用来描述一个文件特征的系统数据,如访问权限,文件拥有者等等。
[root@localhost tmp]# ls -l /etc/passwd
-rw-r--r--. 1 root root 3355 7月  15 11:17 /etc/passwd
第1行代表文件的格式主要有一下几种
    1.-:普通文件
    2.d:目录文件
    3.l:符号连接文件
    4.s:套接字文件
    5.p:管道文件
    6.b:块设备文件
    7.c:字设备文件
第2-9代表文件的拥有者,属组,其他用户对文件的访问权限
    r:读    w:写    x:执行
    使用stat和touch可以修改和查看文件的时间戳信息
    
[root@localhost tmp]# stat /etc/passwd
文件:"/etc/passwd"
大小:3355      	块:8          IO 块:4096   普通文件
设备:fd00h/64768d	Inode:34137289    硬链接:1
权限:(0644/-rw-r--r--)  Uid:(    0/    root)   Gid:(    0/    root)
环境:system_u:object_r:passwd_file_t:s0
最近访问:2016-07-16 22:42:49.602895353 +0800
最近更改:2016-07-16 22:42:49.602895353 +0800
最近改动:2016-07-16 22:42:49.602895353 +0800
创建时间:-

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

使用aliase可以查看当前shell的的别名。aliase=value可以定义命令别名
        (1) alias
	显示当前shell进程所有可用的命令别名;
        (2) alias NAME='VALUE'
	定义别名NAME,其相当于执行命令VALUE;

        注意:在命令行中定义的别名,仅对当前shell进程有效;如果想永久有效,要定义在配置文件中;
	仅对当前用户:~/.bashrc
	对所有用户有效:/etc/bashrc

	Note: 编辑配置给出的新配置不会立即生效;

	bash进程重新读取配置文件:
	source /path/to/config_file
	./path/to/config_file

	撤消别名:unalias
	unalias [-a] name [name ...]

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

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

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

[root@localhost var]# ls  /etc/[0-9]*[^0-9]

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

[root@localhost var]# ls /etc/[^[:alpha:]][[:alpha:]]*

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

[root@localhost tmp]# touch /tmp/tfile`date +%F-%H-%M-%S`

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

[root@localhost tmp]# cp -rf /etc/p*[^0-9] /tmp/mytest1

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

[root@localhost tmp]# cp -rf /etc/*.d /tmp.mytest2

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

[root@localhost tmp]# cp /etc/{l.m,n}*.conf /tmp/mytest3

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

(0)
N21_619463772N21_619463772
上一篇 2016-07-17 21:50
下一篇 2016-07-19 09:06

相关推荐

  • 搭建一套LVS-DR模型的高性能集群(LVS-DR+Nginx+Mariadb+Nfs+php-fpm+wordpress)

    架构简介 参加马哥linux培训一周了,自己感觉每天都进步很多,现在来说说这个架构,也是架构师第一周的作业第二题。搭建一套LVS-DR模型的高性能集群,做了两天终于完成并实现了这个架构,我设计的架构图如下所示: 此架构主要是用ipvsadm来实现高性能集群,Realserver(RS1,RS2)安装配置nginx,RS服务器分别配置了一个内网,一个外网。正常…

    Linux干货 2016-12-06
  • 一切皆文件

    Linux Linux内一切皆文件;表现之一:硬件设备也通过文件表示 物理终端:/dev/console 虚拟终端: /dev/tty#[1,6] 串行终端:/dev/ttyS# 伪终端: /dev/pts/# 注意:在启动设备之后,在其上关联一个用户接口程序,即可实现与用户交互,交互式程序有两类:GUI(图形化界面)和CLI(命令行界面)。 查看终端设备:…

    Linux干货 2017-04-01
  • N25第三周总结

    linux   bassic The third week of blogging 1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。  ~]# who | cut -d' ' -f1 | uniqr…

    Linux干货 2016-12-17
  • Linux用户和组管理

    使用对象:Linux初学者   Linux系统中用户和组管理是很重要的一部分内容。许多初学者在学习或刚接触到用户管理的时候会觉得很难理解,命令多、选项多、配置文件也多,用命令可以修改,用配置文件也可以修改,三两下就被绕进去了。其实完全没必要晕,只要了解了用户管理的方式,就会很容易理解命令选项与配置文件之间的关系。下面我们就来了解下用户管理命令与配置…

    Linux干货 2016-10-23
  • varnish

    Web Page Cache: squid –> varnish程序的运行具有局部性特征:时间局部性:一个数据被访问过之后,可能很快会被再次访问空间局部性:一个数据被访问时,其周边的数据也有可能被访问到 cache:命中 热区:局部性;时效性:缓存空间耗尽:LRU过期:缓存清理 缓存命中率:hit/(hit+miss)(0,1)页面命中率:…

    Linux干货 2017-05-22
  • Http实践

    练习:搭建虚拟主机     (1)基于主机名实现三个虚拟主机     (2) 每虚拟主机使用独立的访问日志和错误日志     (3) 第三个虚拟主机的/admin要进行用户访问认证     (4) 在…

    Linux干货 2016-09-30

评论列表(1条)

  • 马哥教育
    马哥教育 2016-07-17 21:55

    写的很好,排版也很漂亮,加油