马哥教育网络班22期+第二周课程练习

1、Linux文件管理类命令

    cp:copy files and directories 复制文件和目录

        单源复制:cp [OPTION]… [-T] SOURCE DEST
            如果DEST不存在,则事先创建此文件,并复制源文件的数据流至DEST中;
            如果DEST存在:
                若DEST是非目录文件,则覆盖目标文件;普通用户下直接覆盖,管理员用户下则会提示是否覆盖
                若DEST是目录文件,则先在DEST目录下创建一个与源文件同名的文件,并复制其数据流
                    
        多源复制:cp [OPTION]… SOURCE… DIRECTORY
                         cp [OPTION]… -t DIRECTORY SOURCE…
             如果DEST不存在:错误
             如果DEST存在:
                 若DEST是非目录文件:错误
                 若DEST是目录文件:分别复制每个文件至目标目录中,并保持原名

        常用选项:
            -i:交互式复制,即覆盖前提醒用户确认
            -f,–force:强制覆盖目标文件
            -r,-R,–recursive:递归复制目录
            -d:复制符号链接本身,而非其指向的源文件
            -a:-dR –preserve=all,archive,用于实现归档,备份
            –preserve(保留)=
                mode:权限
                ownership:属主和属组
                timetamps:时间戳
                context:安全标签
                xattr:扩展属性
                links:符号链接
                all:上述所有属性

[xw@localhost ~]$ cp /var/log/boot.log test.txt

[root@localhost ~]# cp /var/log/boot.log /home/xw/test.txt
cp: overwrite ‘/home/xw/test.txt’? y

[xw@localhost ~]$ cp /etc/passwd /etc/group test.txt
cp: target ‘test.txt’ is not a directory
[xw@localhost ~]$ cp /etc/passwd /etc/group test

[root@localhost ~]# cp /var/log/ /home/xw/test
cp: omitting directory ‘/var/log/’
[root@localhost ~]# cp -rf /var/log/* /home/xw/test/

    mv:move (rename) files 移动或重命名文件
        语法格式:mv [OPTION]… [-T] SOURCE DEST
                         mv [OPTION]… SOURCE… DIRECTORY
                         mv [OPTION]… -t DIRECTORY SOURCE..

        常用选项:
                   -i:交互式移动
                   -f, –force:强制移动

    rm:remove files or directories 删除文件或目录
        语法格式:rm [OPTION]… FILE…

        常用选项:
            -i:交互式删除
            -f:强制删除
            -r:递归删除

            删除目录:rm -rf /PATH/TO/DIR
                !!!危险操作:rm -rf /*
        注意:所有不用的文件建议不要直接删除,而是移动至某个专用目录(模拟回收站功能)

2、bash的基础特性之:命令的执行状态结果和命令行展开

    命令的执行状态结果
        
bash通过状态返回值来输出结果:
            成功:0
            失败:1-255

            命令执行完成之后,其状态返回值保存于bash的特殊变量 $? 中

[xw@localhost ~]$ ls /etc/passwd
/etc/passwd
[xw@localhost ~]$ echo $?
0
[xw@localhost ~]$ lss /etc/passwd
-bash: lss: command not found
[xw@localhost ~]$ echo $?
127

    命令行展开
        
~:自动展开为用户的家目录,或指定的用户的家目录
        {}:可承载一个以逗号分隔的路径列表,并能够将其展开为多个路径
            例如:/tmp/{a,b} 相当于 /tmp/a /tmp/b

3、使用命令行展开功能完成以下练习:
    (1) 创建/tmp目录下的:a_c,a_d,b_c,b_d

[xw@localhost ~]$ mkdir /tmp/{a,b}_{c,d}
[xw@localhost ~]$ ls /tmp/
a_c  a_d  b_c  b_d

    (2) 创建/tmp/mylinux目录下的如下目录:

[xw@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/local/{bin,sbin},var/{lock,log,run}}
[xw@localhost tmp]$ tree 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

4、文件的元数据
    元数据是指用来描述一个文件的特征的系统数据,包括文件大小,拥有者,所属的组,修改日期,访问权限以及文件数据块的分布信息(inode…)等等。使用 ls -l filename,stat filename 来查看文件的元数据。

[xw@localhost ~]$ ls -l 1.txt
-rw-rw-r--. 1 xw xw 8617 Aug 19 10:01 1.txt

[xw@localhost ~]$ stat 1.txt
  File: ‘1.txt’
  Size: 8617            Blocks: 24         IO Block: 4096   regular file
Device: fd02h/64770d    Inode: 136         Links: 1
Access: (0664/-rw-rw-r--)  Uid: ( 1000/      xw)   Gid: ( 1000/      xw)
Context: unconfined_u:object_r:user_home_t:s0
Access: 2016-08-19 10:01:09.000806088 +0800
Modify: 2016-08-19 10:01:09.000806088 +0800
Change: 2016-08-19 10:01:09.000806088 +0800
 Birth: -

        -:文件类型:-常规文件,d目录文件,b块设备文件,c字符设备文件,l符号链接文件,s套接字文件,p命令管道
        rw-(左三位):文件属主的权限
        rw-(中三位):文件属组的权限
        r–(右三位):其它用户(非属主、属组)的权限
        1:表示文件被硬链接的次数
        xw:文件的属主
        xw:文件的属组
        8617:表示文件的大小,单位是字节
        Aug 19 10:01:文件最近一次被修改的时间

        Access(最近访问): 2016-08-19 10:01:09.000806088 +0800
        Modify(最近修改): 2016-08-19 10:01:09.000806088 +0800
        Change(最近更改): 2016-08-19 10:01:09.000806088 +0800

        修改文件的时间戳信息—— touch 命令:
            语法格式:touch [OPTION]… FILE…
                -a:仅修改access time
                -m:仅修改modify time
                -t STAMP:修改为指定时间
                    格式:[[CC]YY]MMDDhhmm[.ss]

5、命令别名 alias:将一些需要频繁使用但又过于冗长的命令设置一个别名,这样只需输入简短的别名就可以达到同样的作用
        获取所有可用别名的定义:~]$ alias
        定义别名:~]$ alias NAME='COMMAND'
            注意:仅对当前shell进程有效
        撤销别名:~]$ unalias NAME

[xw@localhost ~]$ alias e='echo'
[xw@localhost ~]$ e 'hello'
hello

        在命令中引用另一个命令的执行结果:
            $(COMMAND) 或 `COMMAND`

[xw@localhost ~]$ echo now is $(date +"%F %T")
now is 2016-08-19 15:02:28
[xw@localhost ~]$ echo now is `date +"%F %T"`
now is 2016-08-19 15:02:42

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

[root@localhost var]# ls -d /var/l*[0-9]*[[:lower:]]
/var/l3%%d  /var/l_6gs  /var/l_6r1e  /var/l8d

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

[root@localhost etc]# ls -d /etc/[0-9]*[^0-9]
/etc/68ef%  /etc/8ef  /etc/90_f

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

[root@localhost etc]# ls -d /etc/[^[:alpha:]][[:alpha:]]*
/etc/8ef  /etc/9dfg%  /etc/9dfg1

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

[root@localhost tmp]# touch /tmp/tfile-$(date +"%Y-%m-%d-%H-%M-%S")
[root@localhost tmp]# ls
a_c  a_d  b_c  b_d  mylinux  tfile-2016-08-19-16-00-07

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

[root@localhost tmp]# cp -rf /etc/p*[^0-9] /tmp/mytest1
[root@localhost tmp]# ls mytest1/
pam.d   passwd-  plymouth  popt.d   ppp             printcap  profile.d  python
passwd  pki      pm        postfix  prelink.conf.d  profile   protocols

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

[root@localhost tmp]# cp -rf /etc/*.d /tmp/mytest2
[root@localhost tmp]# ls mytest2
bash_completion.d  grub.d          pam.d           rc3.d      statetab.d
binfmt.d           init.d          popt.d          rc4.d      sudoers.d
chkconfig.d        ld.so.conf.d    prelink.conf.d  rc5.d      sysctl.d
cron.d             logrotate.d     profile.d       rc6.d      tmpfiles.d
depmod.d           modprobe.d      rc0.d           rc.d       xinetd.d
dnsmasq.d          modules-load.d  rc1.d           rsyslog.d  yum.repos.d
dracut.conf.d      my.cnf.d        rc2.d           rwtab.d

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

[root@localhost tmp]# cp -rf /etc/[lmn]*.conf /tmp/mytest3
[root@localhost tmp]# ls mytest3
ld.so.conf     libuser.conf  logrotate.conf  mke2fs.conf
libaudit.conf  locale.conf   man_db.conf     nsswitch.conf

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

(0)
上一篇 2016-08-22 09:29
下一篇 2016-08-22 09:29

相关推荐

  • 第二周的作业

    1、Linux上的文件管理类命令都有哪些,其常用的使用方法及其相关示例演示。 命令:ls NAME:用于列出目录的内容; SYNOPSIS:ls [OPTION]… [FILE]… FILE: 如果FILE是个文件的话,则显示文件名; 如果FILE是个目录的话,则列出目录的内容; OPTION: -l:显示长格式的信息,一共包含了7个…

    Linux干货 2016-11-23
  • N22-℡浮生.若夢 ╮第九周作业

    1、写一个脚本,判断当前系统上所有用户的shell是否为可登录shell(即用户的shell不是/sbin/nologin);分别这两类用户的个数;通过字符串比较来实现; #!/bin/bash ## declare -i log_user declare -i notlog_user for i …

    Linux干货 2016-12-12
  • 文本处理工具

    文件 查看命令:cat, tac,revcat [OPTION]… [FILE]…-E: 显示行结束符$-n: 对显示出的每一行进行 编号-A :显示所有控制符-b: : 非空行编号-s :压缩连续的空行成一行 分页查看文件内容more: 分页查看文件more [OPTIONS…] FILE…-d: 显示翻页及…

    Linux干货 2017-03-17
  • Linux的常见文件类型

      在linux中,文件的类型和权限通常以【-rwxr-xr-x】来表示,文件以第一个字符来表示不同的文件类型,具体如下。   – :普通文件;颜色为灰白色   d :目录文件;颜色为蓝色   b :块设备文件;颜色为黄色   c :字符设备文件;颜色为黄色   p :管道文件;颜色为绿…

    Linux干货 2016-10-20
  • 用户组和用户权限的使用2

    touch /etc/nologin  echo system is maintanining >> /etc/nologin  可以控制非管理员root之外的所有普通用户不能登陆 7版本里面 cd /run/ touch /run/nologin 效果一样让普通用户不能登陆 ehho weihu > /run/nolo…

    Linux干货 2016-08-04
  • ansible 入门与进阶

    ansible 入门与进阶 Configuration、Command and Control 是什么 ? SSH-based configuration management, deployment, and task execution system 运维工具的分类: agent:基于专用的agent程序完成管理功能,puppet, func, zabb…

    2016-11-09

评论列表(1条)

  • 马哥教育
    马哥教育 2016-08-22 14:28

    写的很好,排版还可以在漂亮一点,加油,3大题2小题跟要求不一样