N31第二周作业

本周(6.25–7.1)第2周

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

目录管理类命令:cd pwd ls mkdir rmdir tree

cd:change directory

cd [/PATH/TO/SOMEDIR]

cd:切换回家目录

注意:bash中,~表示家目录

cd~:切换回自己的家目录

cd~username:切换回指定用户的家目录

cd -:在上一次所在目录与当前目录之间来回切换

相关的环境变量

$PWD:当前的工作目录 echo $PWD

$OLDPWD:上一次的工作目录 echo $OLDPWD

[a@localhost ~]$ cd /etc/opt/

[a@localhost opt]$ cd ..

[a@localhost etc]$ cd –

/etc/opt

[a@localhost opt]$ cd ~

[a@localhost ~]$

 

pwd:printing working directory 显示工作目录

[a@localhost ~]$ pwd

/home/a

 

ls:list列出指定目录下内容

ls [OPTION]…[FILE]…

-a 显示所有文件,包括隐藏文件

-A 显示除.和..之外的所有文件

-l :–long 长格式列表,及显示文件的详细属性信息

-h :–human-readable 对文件大小单位换算

-d 查看目录自身而非其内部文件

-r 逆序显示 -r递归显示

[a@localhost ~]$ ls -a

. .bashrc .gnupg p a tree-1.7.0.tgz

.. .cache .ICEauthority Pictures Videos

1.txt .config .lesshst Public .viminfo

2.txt .dbus .local read.txt .viminfo.tmp

4.txt Desktop .mozilla .serverauth.3309

.bash_history Documents Music .ssh

.bash_logout Downloads .mysql_history Templates

.bash_profile .esd_auth pa tree-1.7.0

[a@localhost ~]$ ls -l

total 68

-rw-rw-r–. 1 a a 342 Jul 1 11:20 1.txt

-rw-rw-r–. 1 a a 51 Jul 1 11:38 2.txt

-rw-rw-r–. 1 a a 100 Jul 1 11:47 4.txt

drwxr-xr-x. 2 a a 6 Jun 12 14:04 Desktop

drwxr-xr-x. 2 a a 6 Jun 12 14:04 Documents

drwxr-xr-x. 2 a a 6 Jun 12 14:04 Downloads

drwxr-xr-x. 2 a a 6 Jun 12 14:04 Music

-rw-rw-r–. 1 a a 0 Jun 29 14:02 pa

-rw-rw-r–. 1 a a 0 Jun 29 14:02 p a

drwxr-xr-x. 2 a a 6 Jun 12 14:04 Pictures

drwxr-xr-x. 2 a a 6 Jun 12 14:04 Public

-rw-rw-r–. 1 a a 12 Jun 13 11:21 read.txt

drwxr-xr-x. 2 a a 6 Jun 12 14:04 Templates

drwxrwxr-x. 3 a a 4096 Jun 21 15:00 tree-1.7.0

-rw-rw-r–. 1 a a 47082 Apr 24 2014 tree-1.7.0.tgz

drwxr-xr-x. 2 a a 6 Jun 12 14:04 Videos

 

mkdir:创建目录

mkdir [option]…directory…

-p:不存在是各自创建目录

-v:显示创建过程下详细信息

-m:创建目录是直接指定权限

[a@localhost ~]$ mkdir -pv /tmp/a/b/c

mkdir: created directory ‘/tmp/a’

mkdir: created directory ‘/tmp/a/b’

mkdir: created directory ‘/tmp/a/b/c’

 

rmdir:删除目录

rmdir [option]…directory…

-p:删除某目录后,如果父目录为空则一并删除

-v:显示执行过程

[a@localhost ~]$ rmdir -pv /tmp/a/b/c

rmdir: removing directory, ‘/tmp/a/b/c’

rmdir: removing directory, ‘/tmp/a/b’

rmdir: removing directory, ‘/tmp/a’

rmdir: removing directory, ‘/tmp’

rmdir: failed to remove directory ‘/tmp’: Permission denied

 

tree:目录结构查看

tree参数:-d:只显示目录

-L level:指定显示的层级数目

-P pattern:只显示指定pattern匹配到的路径

[a@localhost ~]$ tree -L 1 ~

/home/a

├── 1.txt

├── 2.txt

├── 4.txt

├── Desktop

├── Documents

├── Downloads

├── Music

├── pa

├── p a

├── Pictures

├── Public

├── read.txt

├── Templates

├── tree-1.7.0

├── tree-1.7.0.tgz

└── Videos

9 directories, 7 files

 

文件查看命令:cat head tail less more

cat:concatenate

文件文本查看工具:

cat /etc/fstab

cat /etc/passwd

cat [options]…[FILE]…

-n 给显示的文本行编号

-E 显示行结束符

[a@localhost ~]$ cat -n 1.txt

1 ls: cannot access linuxprobe: No such file or directory

2 12345

3 TYPE=Ethernet

4 PROXY_METHOD=none

5 BROWSER_ONLY=no

6 BOOTPROTO=dhcp

7 DEFROUTE=yes

8 IPV4_FAILURE_FATAL=no

9 IPV6INIT=yes

10 IPV6_AUTOCONF=yes

 

head:查看文件前几行

head[OPTION]…[FILE]…

-n#:指定获取前#行,也可以-#

-c#:指定获取前#字节内容

[a@localhost ~]$ head -3 1.txt

ls: cannot access linuxprobe: No such file or directory

12345

TYPE=Ethernet

 

tail:查看文件后几行

tail[OPTION]…[FILE]…

-n#:指定获取后#行,也可以-#

-c#:指定获取后#字节内容

-f:动态显示文件新内容

[a@localhost ~]$ tail -3 1.txt

UUID=7cc8d718-464f-4a8b-b617-d742a2e82cd8

DEVICE=ens33

ONBOOT=yes

more :

more [options] file[…]

-d:翻页及退出提示

less:与more相反

 

文件管理命令:cp mv rm

cp命令:copy

单源复制 cp [OPTION]… [-T] SOURCE DEST

多源复制 cp [OPTION]… SOURCE… DIRECTORY

cp [OPTION]… -t DIRECTORY SOURCE…

单源复制 :

如果DEST不存在,则事先创建此文件,并复制源文件的数据流至DEST中

如果DEST存在,

如果DEST是非目录文件 ,则覆盖目标文件

如果DEST是目录文件,则事先在DEST目录下创造一个与源文件同名的文件,并复制其数据流

多源复制:

如果DEST不存在:错误

如果DEST存在:

如果DEST是非目录文件:错误

如果DEST是目录文件:分别复制每个文件至目标目录中,并保持原名

常用选项:

-i:交互式复制,即覆盖之前提醒用户确认

-f:强制覆盖目标文件

-r:递归复制目录

-d:复制符号链接文件本身,而非指向其源文件

-a:-dR –preserve=all , archive , 用于实现归档

–preserv=

mode:权限1.tc2

ownership:属主与属组

timestamps:时间戳

context:安全标签

xattr:扩展属性

links:符号链接

all:上述所有属性

[a@localhost ~]$ cp 1.txt 2.txt

[a@localhost ~]$ ll

total 64

-rw-rw-r–. 1 a a 342 Jul 1 11:20 1.txt

-rw-rw-r–. 1 a a 342 Jul 2 09:51 2.txt

drwxr-xr-x. 2 a a 6 Jun 12 14:04 Desktop

drwxr-xr-x. 2 a a 6 Jun 12 14:04 Documents

drwxr-xr-x. 2 a a 6 Jun 12 14:04 Downloads

drwxr-xr-x. 2 a a 6 Jun 12 14:04 Music

drwxr-xr-x. 2 a a 6 Jun 12 14:04 Pictures

drwxr-xr-x. 2 a a 6 Jun 12 14:04 Public

-rw-rw-r–. 1 a a 12 Jun 13 11:21 read.txt

drwxr-xr-x. 2 a a 6 Jun 12 14:04 Templates

drwxrwxr-x. 3 a a 4096 Jun 21 15:00 tree-1.7.0

-rw-rw-r–. 1 a a 47082 Apr 24 2014 tree-1.7.0.tgz

drwxr-xr-x. 2 a a 6 Jun 12 14:04 Videos

 

mv命令:move

mv [OPTION]… [-T] SOURCE DEST

mv [OPTION]… SOURCE… DIRECTORY

mv [OPTION]… -t DIRECTORY SOURCE…

常用选项:

-i:交互式

-f:force

[a@localhost ~]$ mv 2.txt /tmp/x

[a@localhost ~]$ cd /tmp/x/

[a@localhost x]$ ll

total 4

-rw-rw-r–. 1 a a 342 Jul 2 09:51 2.txt

drwxrwxr-x. 4 a a 24 Jun 22 14:35 y1

drwxrwxr-x. 4 a a 24 Jun 22 14:35 y2

[a@localhost x]$ ll ~

total 60

-rw-rw-r–. 1 a a 342 Jul 1 11:20 1.txt

drwxr-xr-x. 2 a a 6 Jun 12 14:04 Desktop

drwxr-xr-x. 2 a a 6 Jun 12 14:04 Documents

drwxr-xr-x. 2 a a 6 Jun 12 14:04 Downloads

drwxr-xr-x. 2 a a 6 Jun 12 14:04 Music

drwxr-xr-x. 2 a a 6 Jun 12 14:04 Pictures

drwxr-xr-x. 2 a a 6 Jun 12 14:04 Public

-rw-rw-r–. 1 a a 12 Jun 13 11:21 read.txt

drwxr-xr-x. 2 a a 6 Jun 12 14:04 Templates

drwxrwxr-x. 3 a a 4096 Jun 21 15:00 tree-1.7.0

-rw-rw-r–. 1 a a 47082 Apr 24 2014 tree-1.7.0.tgz

drwxr-xr-x. 2 a a 6 Jun 12 14:04 Videos

 

rm命令:remove

rm [OPTION]… FILE…

常用选项:

-i:interactive

-f:force

-r:recuresive

删除目录:rm -rf /PATH/TO/DIR

[a@localhost ~]$ rm /tmp/x/2.txt

[a@localhost ~]$ ll /tmp/x

total 0

drwxrwxr-x. 4 a a 24 Jun 22 14:35 y1

drwxrwxr-x. 4 a a 24 Jun 22 14:35 y2

 

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

命令的执行结果状态

成功:0

失败:1-255

命令行展开

~:展开为用户的主目录

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

[a@localhost ~]$ mkdir -pv /tmp/{a,b}

mkdir: created directory ‘/tmp/a’

mkdir: created directory ‘/tmp/b’

[a@localhost ~]$ mkdir -pv /tmp/{a,b}/c

mkdir: created directory ‘/tmp/a/c’

mkdir: created directory ‘/tmp/b/c’

[a@localhost ~]$ echo $?

0

 

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

(1)、创建/tmp目录下的:a_c, a_d, b_c, 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

[a@localhost ~]$ mkdir -pv /tmp/{a,b}_{c,d}
mkdir: created directory ‘/tmp/a_c’
mkdir: created directory ‘/tmp/a_d’
mkdir: created directory ‘/tmp/b_c’
mkdir: created directory ‘/tmp/b_d’
[a@localhost ~]$ ll /tmp
total 12
drwxrwxr-x. 2 a a 6 Jul 2 10:12 a_c
drwxrwxr-x. 2 a a 6 Jul 2 10:12 a_d
drwxrwxr-x. 2 a a 6 Jul 2 10:12 b_c
drwxrwxr-x. 2 a a 6 Jul 2 10:12 b_d

[a@localhost ~]$ mkdir -pv /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}}
mkdir: created directory ‘/tmp/mylinux’
mkdir: created directory ‘/tmp/mylinux/bin’
mkdir: created directory ‘/tmp/mylinux/boot’
mkdir: created directory ‘/tmp/mylinux/boot/grub’
mkdir: created directory ‘/tmp/mylinux/dev’
mkdir: created directory ‘/tmp/mylinux/etc’
mkdir: created directory ‘/tmp/mylinux/etc/rc.d’
mkdir: created directory ‘/tmp/mylinux/etc/rc.d/init.d’
mkdir: created directory ‘/tmp/mylinux/etc/sysconfig’
mkdir: created directory ‘/tmp/mylinux/etc/sysconfig/network-scripts’
mkdir: created directory ‘/tmp/mylinux/lib’
mkdir: created directory ‘/tmp/mylinux/lib/modules’
mkdir: created directory ‘/tmp/mylinux/lib64’
mkdir: created directory ‘/tmp/mylinux/proc’
mkdir: created directory ‘/tmp/mylinux/sbin’
mkdir: created directory ‘/tmp/mylinux/sys’
mkdir: created directory ‘/tmp/mylinux/tmp’
mkdir: created directory ‘/tmp/mylinux/usr’
mkdir: created directory ‘/tmp/mylinux/usr/local’
mkdir: created directory ‘/tmp/mylinux/usr/local/bin’
mkdir: created directory ‘/tmp/mylinux/usr/local/sbin’
mkdir: created directory ‘/tmp/mylinux/var’
mkdir: created directory ‘/tmp/mylinux/var/lock’
mkdir: created directory ‘/tmp/mylinux/var/log’
mkdir: created directory ‘/tmp/mylinux/var/run’
[a@localhost ~]$ tree /tmp/mylinux
/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

24 directories, 0 files

 

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

stat:显示文件的状态

状态信息有三个时间戳

access time:访问时间,atime即通过cat,more读取内容

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

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

[a@localhost ~]$ stat 1.txt

File: ‘1.txt’

Size: 342 Blocks: 8 IO Block: 4096 regular file

Device: fd00h/64768d Inode: 35384159 Links: 1

Access: (0664/-rw-rw-r–) Uid: ( 1000/ a) Gid: ( 1000/ a)

Context: unconfined_u:object_r:user_home_t:s0

Access: 2018-07-01 11:20:16.031355883 +0800

Modify: 2018-07-01 11:20:11.226345159 +0800

Change: 2018-07-01 11:20:11.226345159 +0800

Birth: –

touch改变文件的时间戳

touch[OPTION]…FILE…

-a:修改atime

-m:修改mtime

-t:[[CC]YY]MMDDhhmm[.ss]:修改制定时间戳为某时间

 

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

命令别名:

获取所有可用别名的定义:

~]#alias

定义别名:

~]#alias NAME=COMMAND

注意:仅对当前的shell进程有效

撤销别名:

~]#unalias NAME

使用管道和输出重定向都可以引用命令的执行结果

[a@localhost ~]$ alias | tee 1.txt

alias egrep=’egrep –color=auto’

alias fgrep=’fgrep –color=auto’

alias grep=’grep –color=auto’

alias l.=’ls -d .* –color=auto’

alias ll=’ls -l –color=auto’

alias ls=’ls –color=auto’

alias vi=’vim’

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

[a@localhost ~]$ alias > 2.txt

[a@localhost ~]$ cat 2.txt

alias egrep=’egrep –color=auto’

alias fgrep=’fgrep –color=auto’

alias grep=’grep –color=auto’

alias l.=’ls -d .* –color=auto’

alias ll=’ls -l –color=auto’

alias ls=’ls –color=auto’

alias vi=’vim’

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

 

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

ls -d /var/l*[0-9]*[[:lower:]]

 

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

ls -d /etc/[0-9]*[^0-9]

 

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

ls -d /etc[^[:alpha:]][:alpha:]*

 

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

touch /tmp/tfile-`date +%Y-%m-%d-%H-%M-%S`

ls /tmp

 

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

mkdir /tmp/mytest1

cp -r /etc/p*[^0-9] /tmp/mytest1

 

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

mkdir /tmp/mytest2

cp /etc/*.d /tmp/mytest2

 

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

mkdir /tmp/mytest3

cp /etc/{l,m,n}*.conf /tmp/mytest3

 

 

 

 

 

 

 

 

本文来自投稿,不代表Linux运维部落立场,如若转载,请注明出处:http://www.178linux.com/102144

(0)
上一篇 2018-07-02 09:42
下一篇 2018-07-02 15:11

相关推荐

  • 第一标题

    第一摘要

    Linux笔记 2018-05-14
  • 总结_系统初始设置

    启动 自动联网 gedit /etc/sysconfig/network-scripts/ifcfg-ens33 /*图形界面 gedit*/ ONBOOT=yes 自动登录 nano /etc/gdm/custom.conf /*字符界面 nano*/ [daemon] AutomaticLoginEnable=Ture AutomaticLogin=XX…

    Linux笔记 2018-03-30
  • 第二周作业

    第二周

    Linux笔记 2018-05-20
  • 第4周作业

     1、复制/etc/shel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 [root@localhost ~]# cp -r /etc/shel /home/tuser1 [root@localhost ~]# chmod -R 700 /home/tuser1  2、编辑/etc/group文…

    Linux笔记 2018-06-04
  • grep、vim及用户和组练习

    grep
    chown
    chmod
    vim

    2018-07-23
  • 课堂实验

    实验:针对不同的用户设置不同的共享目录和权限 vim /etc/samba/smb.conf[global]workgroup = WANGGROUPsecurity = usernetbios name = smbsrv7passdb backend = tdbsamlog file = /var/log/samba/log.%Ilog level = 2…

    2018-07-01