第二周作业

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

文件管理命令:cp、mv、rm

(1)cp命令:copy

    单源复制:cp [OPTION]... [-T] SOURCE DEST
    多源复制:cp [OPTION]... SOURCE... DIRECTORY
           cp [OPTION]... -t DIRECTORY SOURCE...

[OPTION]

    -i:交互式覆盖,即覆盖前提示
    -f:强制覆盖目标文件
    -r:递归复制目录
    -d:复制符号链接文件本身,而非其指向的源文件
    -a:-dR --preserve=all,archive
    --preserve=
        mode:权限
        ownership:属组和属主
        timestamps:时间戳
        context:安全标签
        xattr:扩展属性
        links:符号链接
        all:上述所有属性

示例1:拷贝/etc/fstab到/tmp目录下

    [root@UncleZ ~]# cp /etc/fstab /tmp
    [root@UncleZ ~]# ls /tmp
    fstab

示例2:拷贝/etc目录到/tmp目录下

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

(2)mv命令:move

源文件和目标文件在同一目录下,重命名
源文件和目标文件不在同一目录下,移动

        -i:交互式
        -f:force,强制

将123.txt重命名

[root@UncleZ tmp]# mv 123.txt 1234.txt

(3)rm命令:remove

        -i:interactive
        -f:force
        -r:recursive

        rm -rf

        注意:所有不用的文件建议不要直接删除,而是移动至某个专用目录;(模拟回收站)

示例:删除/tmp下的所有文件

[root@UncleZ tmp]# rm -rf /tmp/*

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

命令执行的状态结果:
    echo $?
        0:表示成功
        1~255:失败
    命令执行完成之后,其状态返回值保存于bash的特殊变量$?中

示例:

[root@UncleZ ~]# ls
a_c  anaconda-ks.cfg  b_d       initial-setup-ks.cfg  python  test2.sh  var2.sh
a_d  b_c              database  ni.sh                 ss.sh   test.sh   var.sh

[root@UncleZ ~]# echo $?
0

命令执行成功

3、请使用命令行展开功能来完成以下练习;

{}: 可承载一个以逗号分隔的路径列表,并能否将其展开为多个路径

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

[root@UncleZ ~]# touch /tmp/{a,b}_{c,d}

[root@UncleZ ~]# ls /tmp
a_c  a_d  b_c  b_d

(2)

[root@UncleZ ~]# mkdir -pv /tmp/mylinux/{bin,boot/grub,dev,etc/{rc.d/init.d,sysconfig/network-script},lib/modules,lib64,proc,sbin,sys,tmp,usr/local/{bin,sbin},var/{lock,log,run}}
略

[root@UncleZ ~]# tree /tmp/mylinux
/tmp/mylinux
|-- bin
|-- boot
|   `-- grub
|-- dev
|-- etc
|   |-- rc.d
|   |   `-- init.d
|   `-- sysconfig
|       `-- network-script
|-- lib
|   `-- modules
|-- lib64
|-- proc
|-- sbin
|-- sys
|-- tmp
|-- usr
|   `-- local
|       |-- bin
|       `-- sbin
`-- var
    |-- lock
    |-- log
    `-- run

24 directories, 0 files

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

(1)元数据指用来描述一个文件的特征的系统数据,诸如访问权限、文件拥有者以及文件数据块的分布信息(inode…)等等

时间戳:

    atime    (access time)    最近访问
    mtime    (modify time)    最近更改,文件内容发生改变的时间
    ctime    (change time)    最近改动,元数据发生改动的时间

(2)使用命令stat就可以看到元数据信息,例:

[root@UncleZ ~]# stat /tmp
  File: ‘/tmp’
  Size: 60            Blocks: 0          IO Block: 4096   directory
Device: fd01h/64769d    Inode: 133         Links: 3
Access: (1777/drwxrwxrwt)  Uid: (    0/    root)   Gid: (    0/    root)
Context: system_u:object_r:tmp_t:s0
Access: 2016-12-10 18:26:44.525844032 +0800
Modify: 2016-12-10 18:26:23.004928402 +0800
Change: 2016-12-10 18:26:23.004928402 +0800
 Birth: -

(3)使用touch修改文件的时间戳信息:

touch – change file timestamps

-c:指定的文件路径不存在时不予创建
-a:仅修改access time
-m:仅修改modify time
-t STAMP
        [[CC]YY]MMDDhhmm[.ss]

示例:修改mtime

[root@UncleZ ~]# touch -m -t 0212010303.03 /tmp/functions

[root@UncleZ ~]# stat /tmp/functions 
File: ‘/tmp/functions’
Size: 0             Blocks: 0          IO Block: 4096   regular empty file
Device: fd01h/64769d    Inode: 2360083     Links: 1
Access: (0644/-rw-r--r--)  Uid: (    0/    root)   Gid: (    0/    root)
Context: unconfined_u:object_r:user_tmp_t:s0
Access: 2016-12-06 21:06:48.151112808 +0800
Modify: 2002-12-01 03:03:03.000000000 +0800
Change: 2016-12-06 21:06:48.152115493 +0800
Birth: -

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

alias命令:

获取所有可用别名的定义
定义别名:
    ~]# alias NAME='COMMAND'
注意,仅对当前shell进程有效
撤销别名:
    ~]# unalias NAME

引用命令的执行结果:

    $(COMMAND)或 `COMMAND``

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

[root@UncleZ var]# ls -d /var/1*[0-9]*[[:lower:]]

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

[root@UncleZ ~]# ls -d /etc/[0-9]*[^0-9]

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

[root@UncleZ ~]# ls -d /etc/[^[:alpha:]][[:alpha:]]*

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

[root@UncleZ ~]# touch /tmp/tfile-$(date +%Y-%m-%d-%H-%M-%S)

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

[root@UncleZ ~]# mkdir /tmp/mytest1
[root@UncleZ ~]# cp -r /etc/p*[^0-9] /tmp/mytest1

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

[root@UncleZ ~]# mkdir /tmp/mytest2
[root@UncleZ ~]# cp -r /etc/*.d /tmp/mytest2

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

[root@UncleZ ~]# mkdir /tmp/mytest3
[root@UncleZ ~]# cp /etc/[1mn]*.conf /tmp/mytest3

原创文章,作者:N25-赵叔,如若转载,请注明出处:http://www.178linux.com/63154

(0)
上一篇 2016-12-10 19:04
下一篇 2016-12-11 00:46

相关推荐

  • 网络班N22期第三周博客作业

    一、列出当前系统所有已经登录的用户名,且同一个用户登录多次只显示一次 [root@bogon ~]# w  15:17:44 up 15:28,  2 users,  load average: 0.00, 0.00, …

    Linux干货 2016-08-29
  • 浅谈用户名和权限

        小编已经写了两篇博客了,却忘了自我介绍,咳咳咳(隆zhuang重qiang介zuo绍shi)一下:翠衣薄纱如花艳,柳眉凤眼俏佳人说的就是我!不扯了其实,小编拥有一个四口之家,那么小编今天就借家献佛给你们讲讲用户组和权限。     所属主(me):一般为文件的创建者,谁创建了该文件,就天然的成…

    Linux干货 2017-07-30
  • LAMP架构实验1

    LAMP架构实验 — 基础架构搭建 实验实验拓扑图与目的 实验过程 总结与问题 实验实验拓扑图与目的 1. 实验主框架LAMP采用编译安装。 2. 分离HTTPD,PHP,MARIADB。 3. 两台服务器能够各自被访问且内容相同。 实验过程 程序包准备: apr-1.5.2.tar.gz          …

    Linux干货 2016-05-10
  • keepalived的实验:主主模型

    修改配置文件 [root@proxy1 ~]# vim /etc/keepalived/keepalived.conf ! Configuration File for keepalived   global_defs { notification_email { root@localhost } notification_email_from k…

    2018-03-11
  • CentOS6 网卡bonding

    Bonding ;理念 将多块网卡绑定同一IP地址对外提供服务,可以实现高可用 或者负载均衡。直接给两块网卡设置同一IP地址是不可以的 。通过bonding,虚拟一块网卡对外提供连接,物理网卡的 被修改为相同的MAC地址 banding工作模式 Mode 0 (balance-rr) 轮转(Round-robin)策略: 从头到尾顺序的在每一个slave 接…

    Linux干货 2017-11-24
  • N27_第六周作业

    请详细总结vim编辑器的使用并完成以下练习题 基本模式:编辑模式(命令模式),输入模式,末行模式 模式转换: 编辑模式–输入模式: i:insert,在光标所在处前方输入 a:append,在光标所在处后方输入 o:在光标所在处的下方新建一行 I:在光标所在行行首输入 A:在光标所在处行尾输入 O:在光标所在处的上方打开一个新行 输入模式&#82…

    Linux干货 2017-10-26

评论列表(1条)

  • 马哥教育
    马哥教育 2016-12-16 23:31

    赞,总结的不错,建议可以根据这部分进行深入的扩展~继续加油~