全新Linux+Python高端运维班-Linux基础命令文件管理类及目录创建

简介:

周二作业内容:

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

文件管理类命令:cp(复制)mv(移动)rm(删除)

1) cp:   cp [OPTION]... [-T] SOURCE DEST

       cp [OPTION]... SOURCE... DIRECTORY

       cp [OPTION]... -t DIRECTORY SOURCE...

           cp SRC DEST

如果目标不存在,新建DEST,并将SRC中的内容填充至DEST

                                  wKiom1exT2PzKpJRAAAJ7qsps-o919.png

如果目录存在

如果DEST是文件,将SRC中的内容覆盖至DEST;

此时建议为cp命令行使用-i选项

                wKioL1exT2TAY8byAAA6rrOMrPY579.png

 

如果DEST是目录,在DEST下新建与原文件同名的文件,并将SRC中内容填充至新文件中;

                wKiom1exT2WTBPcyAABdT5z1FUc793.png


cp SRC...DEST

SRC..:多个文件

DEST必须存在,且必须是目录其他情况均会出错;

                wKioL1exT2aSe5JXAAAjyYy2oIY833.png


cp SRC DEST

SRC是目录:

此时使用选项: -r


如果DEST不存在,创建指定目录,复制SRC目录中的所有文件至DEST

如果DEST存在

如果DEST是文件:报错

如果DEST是目录:

                wKioL1exT2ayB1vWAAAV7ii-bss671.png

常用选项:

-i:交互式

-r -R;递归复制目录及内部所有内容

-a:--archive归档,相当于-dR --presserv=all

-d:--no-dereference --preserv=links

--presserve[=ATTR_LIST]

node:权限

ownership:属主属组

timestamp:时间戳

links:链接关系

xattr:扩展属性

context:安全上下文

all


-p:--presrv=node,ownship,timestamp

-v:--verbose  //显示详细过程

-f:--force

2) mv:move ,移动文件

mv [OPTION]... [-T] SOURCE DEST

mv [OPTION]... SOURCE... DIRECTORY

mv [OPTION]... -t DIRECTORY SOURCE...


-i:交互式

-f:--force

            wKiom1exT2qhPg9CAAAfZB5nxXU398.png

 

3) rm:rmove 删除


常用选项:

-i;交互式

-r;递归

-f:强制

wKioL1exT22DwNkoAAAlA12YHWA014.png

 

 

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

1) bash命令执行状态:

bash使用特殊变量$?保存最近一条命令的执行状态结果:

0:成功

1-255:失败

wKiom1exT26CW0ZbAAAXzC8UXOY221.png

 

wKiom1exT27BrRtSAAAQ9FEH34M766.png

 


程序执行有两类结果:

程序的返回值:

程序的执行状态结果:

2) 命令行展开

~:展开为用户的主目录

~USERNAME:展开为指定用户的主目录

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

/tmp/{a,b} = /tmp/a, /tmp/b

/tmp/{tom,jerry}/hi = /tmp/tom/hi,/tmp/jerry/hi

wKioL1exT2-iY-09AAApXGC7u7E622.png

 

 

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

 

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

wKioL1exT2_w3It2AAAZS_YS7rU481.png

 

(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@liu ~]#  mkdir -pv /tmp/mylinux/{bin,boot/grup,dev,etc/{rc.d/init.d,sysconfig/network-scripts},lib/modules,lib64,proc,sbin,sys,tmp,usr/local/{bin,sbin},var/{lock,log,run}}

mkdir: 已创建目录 "/tmp/mylinux"

mkdir: 已创建目录 "/tmp/mylinux/bin"

mkdir: 已创建目录 "/tmp/mylinux/boot"

mkdir: 已创建目录 "/tmp/mylinux/boot/grup"

mkdir: 已创建目录 "/tmp/mylinux/dev"

mkdir: 已创建目录 "/tmp/mylinux/etc"

mkdir: 已创建目录 "/tmp/mylinux/etc/rc.d"

mkdir: 已创建目录 "/tmp/mylinux/etc/rc.d/init.d"

mkdir: 已创建目录 "/tmp/mylinux/etc/sysconfig"

mkdir: 已创建目录 "/tmp/mylinux/etc/sysconfig/network-scripts"

mkdir: 已创建目录 "/tmp/mylinux/lib"

mkdir: 已创建目录 "/tmp/mylinux/lib/modules"

mkdir: 已创建目录 "/tmp/mylinux/lib64"

mkdir: 已创建目录 "/tmp/mylinux/proc"

mkdir: 已创建目录 "/tmp/mylinux/sbin"

mkdir: 已创建目录 "/tmp/mylinux/sys"

mkdir: 已创建目录 "/tmp/mylinux/tmp"

mkdir: 已创建目录 "/tmp/mylinux/usr"

mkdir: 已创建目录 "/tmp/mylinux/usr/local"

mkdir: 已创建目录 "/tmp/mylinux/usr/local/bin"

mkdir: 已创建目录 "/tmp/mylinux/usr/local/sbin"

mkdir: 已创建目录 "/tmp/mylinux/var"

mkdir: 已创建目录 "/tmp/mylinux/var/lock"

mkdir: 已创建目录 "/tmp/mylinux/var/log"

mkdir: 已创建目录 "/tmp/mylinux/var/run"

[root@liu ~]# tree /tmp/mylinux/

/tmp/mylinux/

├── bin

├── boot

   └── grup

├── dev

├── etc

   ├── rc.d

      └── init.d

   └── sysconfig

       └── network-scripts

├── lib

   └── modules

├── lib64

├── proc

├── sbin

├── sys

├── tmp

├── usr

   └── local

       ├── bin

       └── sbin

└── var

    ├── lock

    ├── log

    └── run

 

24 directories, 0 files

 

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


三个时间戳

access time访问时间 简写:atime 读取文件内容

modify time:修改时间,mtime 改变文件内容

change time:改变时间,ctime 元数据发生改变


touch 命令:

touch [option...] [file]...

-aonly atime

-monly mtime

    -t STANP

[[CC]YY]MMDDhhmm[.ss]

-c:如果文件卜存在,则不予创建

[root@liu ljohn]# touch test1

[root@liu ljohn]# stat test1

  File: "test1"

  Size: 6               Blocks: 8          IO Block: 4096   普通文件

Device: 803h/2051d      Inode: 280265      Links: 1

Access: (0644/-rw-r--r--)  Uid: (    0/    root)   Gid: (    0/    root)

Access: 2015-02-14 00:04:29.989931722 +0800

Modify: 2015-02-14 00:04:29.989931722 +0800

Change: 2015-02-14 00:04:29.989931722 +0800

[root@liu ljohn]# touch -t 201608151150.33 test1

[root@liu ljohn]# stat test1

  File: "test1"

  Size: 6               Blocks: 8          IO Block: 4096   普通文件

Device: 803h/2051d      Inode: 280265      Links: 1

Access: (0644/-rw-r--r--)  Uid: (    0/    root)   Gid: (    0/    root)

Access: 2016-08-15 11:50:33.000000000 +0800

Modify: 2016-08-15 11:50:33.000000000 +0800

Change: 2015-02-14 00:08:36.134927058 +0800

 

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

alise命令

(1)alise

显示当前shell进程所有可用的命令别名;

[root@liu ljohn]# alias

alias cp='cp -i'

alias l.='ls -d .* --color=auto'

alias ll='ls -l --color=auto'

alias ls='ls --color=auto'

alias mv='mv -i'

alias rm='rm -i'

alias which='alias | /usr/bin/which --tty-only --read-alias --show-dot --show-tilde'

(2)alise NAME='VALUE'

定义别名NAME,器相当于执行命令VALUE

[root@liu ljohn]#  alias cdnet='/etc/sysconfig/network-scripts/'

[root@liu ljohn]# cdnet

-bash: /etc/sysconfig/network-scripts/: is a directory

[root@liu ljohn]# unalias cdnet

[root@liu ljohn]# alias cdnet='cd /etc/sysconfig/network-scripts/'

[root@liu ljohn]# cdnet

[root@liu network-scripts]# ls

ifcfg-eth0   ifdown-isdn    ifup-aliases  ifup-plusb     init.ipv6-globa

注意:在命令行中定义的别名,仅对当前的shell进程有效,如果想永久有效,要定义在配置文件中

也可以将alias cdnet='cd /etc/sysconfig/network-scripts/'写入以下配置文件中

仅对当前用户:~/.bashrc

对所有用户生效:/etc/bashrc


重新读取配置文件:

source  /etc/bashrc

/etc/bashrc


撤销别名:

unalise NAME

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

[root@liu network-scripts]# ls -d /var/l*[0-9]*[a-z]

ls: 无法访问/var/l*[0-9]*[a-z]: 没有那个文件或目录

 

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

[root@liu network-scripts]# ls -d /etc/[0-9]*[^0-9]

ls: 无法访问/etc/[0-9]*[^0-9]: 没有那个文件或目录

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

[root@liu network-scripts]# ls -d /etc/[^[:graph:]][[:graph:]]*

ls: 无法访问/etc/[^[:graph:]][[:graph:]]*: 没有那个文件或目录

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

[root@liu ljohn]# touch tfile-`date +%F-%H-%M-%S`

[root@liu ljohn]# ls

a    a_c  asb  b_c  fstab  tfile-                     yum.log

abc  a_d  b    b_d  test1  tfile-2015-02-14-00-42-21

[root@liu ljohn]# date

2015年 02月 14日 星期六 00:42:37 CST

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

[root@liu tmp]# mkdir mytest1

[root@liu tmp]# cp  -a /etc/p*[0-9]  /tmp/mytest1

[root@liu tmp]# ll

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

[root@liu tmp]# mkdir mytest2

[root@liu tmp]# cp -a /etc/*.d /tmp/mytest2

[root@liu tmp]# ls /tmp/mytest2

bash_completion.d  latrace.d       popt.d          rc5.d          statetab.d

chkconfig.d        ld.so.conf.d    prelink.conf.d  rc6.d          sudoers.d

cron.d             logrotate.d     profile.d       rc.d           xinetd.d

depmod.d           lsb-release.d   rc0.d           request-key.d  yum.repos.d

dnsmasq.d          makedev.d       rc1.d           rsyslog.d

dracut.conf.d      modprobe.d      rc2.d           rwtab.d

event.d            oddjobd.conf.d  rc3.d           sane.d

init.d             pam.d           rc4.d           setuptool.

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

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

[root@liu tmp]# ls /tmp/mytest3/

latrace.conf   libuser.conf    mke2fs.conf    nsswitch.conf

ld.so.conf     logrotate.conf  mtools.conf    ntp.conf

libaudit.conf  ltrace.conf     nfsmount.conf

 



本文转自 ljohnmail 51CTO博客,原文链接:http://blog.51cto.com/ljohn/1838216,如需转载请自行联系原作者

相关文章
|
8天前
|
运维 监控 网络安全
自动化运维的魔法:如何用Python简化日常任务
【10月更文挑战第9天】在数字时代的浪潮中,运维人员面临着日益增长的挑战。本文将揭示如何通过Python脚本实现自动化运维,从而提高效率、减少错误,并让运维工作变得更具创造性。我们将探索一些实用的代码示例,这些示例将展示如何自动化处理文件、监控系统性能以及管理服务器配置等常见运维任务。准备好让你的运维工作升级换代了吗?让我们开始吧!
|
15天前
|
安全 Linux 开发者
|
27天前
|
机器学习/深度学习 人工智能 运维
自动化运维的魔法:如何利用Python脚本提升工作效率
【9月更文挑战第29天】在数字时代的浪潮中,IT运维人员面临着前所未有的挑战和机遇。本文将通过深入浅出的方式,介绍自动化运维的基本概念、核心价值以及使用Python脚本实现自动化任务的方法。我们将从实际案例出发,探讨如何利用Python简化日常的系统管理任务,提高运维效率,并展望自动化运维的未来趋势。无论你是初学者还是有经验的运维专家,这篇文章都将为你开启一扇通往高效工作方式的大门。
41 2
|
1月前
|
Java Linux Python
Linux环境下 代码java调用python出错
Linux环境下 代码java调用python出错
38 3
|
1月前
|
Linux Python
linux 封装 python
linux 封装 python
12 0
|
1月前
|
Linux Python
Linux 下封装 Python
Linux 下封装 Python
15 0
|
19天前
|
机器学习/深度学习 人工智能 运维
构建高效运维体系:从自动化到智能化的演进
本文探讨了如何通过自动化和智能化手段,提升IT运维效率与质量。首先介绍了自动化在简化操作、减少错误中的作用;然后阐述了智能化技术如AI在预测故障、优化资源中的应用;最后讨论了如何构建一个既自动化又智能的运维体系,以实现高效、稳定和安全的IT环境。
46 4
|
10天前
|
运维 Linux Apache
,自动化运维成为现代IT基础设施的关键部分。Puppet是一款强大的自动化运维工具
【10月更文挑战第7天】随着云计算和容器化技术的发展,自动化运维成为现代IT基础设施的关键部分。Puppet是一款强大的自动化运维工具,通过定义资源状态和关系,确保系统始终处于期望配置状态。本文介绍Puppet的基本概念、安装配置及使用示例,帮助读者快速掌握Puppet,实现高效自动化运维。
32 4
|
6天前
|
存储 运维 监控
高效运维:从基础架构到自动化管理的全面指南
【10月更文挑战第11天】 本文将深入探讨如何通过优化基础架构和引入自动化管理来提升企业IT运维效率。我们将从服务器的选择与配置、存储解决方案的评估,到网络的设计与监控,逐一解析每个环节的关键技术点。同时,重点讨论自动化工具在现代运维中的应用,包括配置管理、持续集成与部署(CI/CD)、自动化测试及故障排除等方面。通过实际案例分析,展示这些技术如何协同工作,实现高效的运维管理。无论是IT初学者还是经验丰富的专业人员,都能从中获得有价值的见解和实操经验。
17 1
|
8天前
|
运维 监控 测试技术
构建高效运维体系:从监控到自动化的实践之路
【10月更文挑战第9天】 在当今信息技术飞速发展的时代,运维作为保障系统稳定性与效率的关键角色,正面临前所未有的挑战。本文将探讨如何通过构建一个高效的运维体系来应对这些挑战,包括监控系统的搭建、自动化工具的应用以及故障应急处理机制的制定。我们将结合具体案例,分析这些措施如何帮助提升系统的可靠性和运维团队的工作效率。
23 1