shell编程、查找命令、压缩文件工具

shell编程、查找命令、压缩文件工具

 shell编程

一、条件测试

 1、判断某需求是否满足,需要由测试机制来实现。

   测试命令:

 ·test Expression

 ·[ EXPRESSION ]

 ·[[ EXPRESSION ]]

   需要注意的是:EXPRESSION前后必须有空白字符。&&代表and之意。||代表条件性OR

长格式的举例:

    $ test $A == $B && echo Strings are equal

2、数值测试

   -gt:是否大于

   -ge:是否大于等于

   -eq:是否等于

   -ne:是否不等于

   -lt:是否小于

   -le:是否小于等于

3、字符串测试

   ==:是否等于

   >:ascii码是否大于ascii

   <:是否小于

   !=:是否不等于

=~:左侧字符是否能够被右侧的PATTERN所匹配

    -z "STRING" :字符串是否为空,空为真,不空为假

    -n "STRING" :字符串是否不空,不空为真,空为假

     注意:用于字符串比较时的用到的操作数都应该使用引号

4、文件测试

   存在性测试

   -a FILE :同-e

   -e FILE:  文件存在性测试,存在为真,否则为假;

    存在性及类别测试

    -b FILE :是否存在且为块设备文件;

    -c FILE :是否存在且为字符设备文件;

    -d FILE :是否存在且为目录文件;

    -f FILE :是否存在且为普通文件;

    -h FILE -L FILE :存在且为符号链接文件;

    -p FILE :是否存在且为命名管道文件;

    -S FILE:是否存在且为套接字文件

5、文件权限测试

   文件权限测试:

   -r FILE :是否存在且可读

   -w FILE:  是否存在且可写

    -x FILE:  是否存在且可执行

   文件特殊权限测试:

    -g FILE :是否存在且拥有sgid 权限;

    -u FILE :是否存在且拥有suid 权限;

    -k FILE :是否存在且拥有sticky

6、文件大小测试:

    -s FILE:  是否存 在 且非空;

   文件是否打开:

    -t fd: fd 表示文件描述符是否已经打开且与某终端相关

    -N FILE :文件自动上一次被读取之后是否被修改过

    -O FILE :当前有效用户是否为文件属主

-G FILE :当前有效用户是否为文件属组

7、  双目测试:

      FILE1 -ef FILE2: FILE1 FILE2 是否指向同一个设

      备上的相同inode

      FILE1 -nt FILE2: FILE1 是否新于FILE2; ;

      FILE1 -ot FILE2: FILE1 是否旧于FILE2

8、组合测试条件

   第一种方式:

   COMMAND1 && COMMAND2  并且

   COMMAND1 || COMMAND2  或者

   ! COMMAND

   如:[ -e FILE ] && [ -r FILE ]

  第二种方式:

    EXPRESSION1 -a EXPRESSION2  并且

    EXPRESSION1 -o EXPRESSION2  或者

    ! EXPRESSION

必须使用测试命令进行;

9、使用read命令来接收输入

   使用read 来把输入值分配给一个或多个shell 变量:

   -p 指定要显示的提示

    -t TIMEOUT

     read 从标准输入中读取值,给每个单词分配一个变量

所有剩余单词都被分配给最后一个变量

举例:read  -p please input a number:“ FILE

二、流程控制

 1、条件选择if语句

  选择执行:

  注意: :if 语句可 嵌套

  单分支

if  判断条件:then

条件为真的分支代码

fi

  双分支

if  判断条件; then

条件为真的分支代码

else

条件为假的分支代码

fi

  多分支

if  CONDITION1 ; then

if-true

elif CONDITION2 ; then

if-ture

elif CONDITION3 ; then

if-ture

else

all-false

fi  

逐条 件进行判断,第一次遇为“真”条件时,执行其分支,

而后 结束整个if

举例:命令行输入: ]#if [ -r /etc/shadow ];then echo "the file is read "; fi

the file is read

 

2、条件判断:case 语句

case 用 变量引用 in

PAT1)

分支1

;;

PAT2)

分支2

;;

*)

默认分支

;;

esac

case 支持glob 风格的通配符:

*:  任意长度任意字符

?:  任意单个字符

[] :指定范围内的任意单个字符

a|b: a b

 

文件查找与压缩

 

 

1、locate命令

·查询系统上预建的文件索引数据库

     /var/lib/mlocate/mlocate.db

·依赖于事先构建的索引;

·索引的构建是在系统较为空闲时自动进行( 周期性任务) ;管理

员手动更新数据库(updatedb); ;

·索引构建过程需要遍历整个根文件系统,极消耗资源;

·工作特点:

查找速度快;

模糊查找;

非实时查找

搜索的是文件的全路径,不仅仅是文件名

可能只搜索用户具备读取和执行权限的目录

 locate的使用

locate KEYWORD

  有用的选项

-i 执行区分大小写的搜索

-n X 只列举前X 个匹配项目

 locate foo

• 搜索名称或路径中带有“foo ”的文件

 locate -r \.foo$

• 使用Regex 来搜索以“.foo

2、find命令

1find命令概述:实时查找工具,通过遍历指定路径完成文件查找;

工作特点:

查找速度略慢

精确查找

实时查找

可能只搜索用户具备读取和执行权限的目录

2find语法

find [OPTION]… [ 查找路径] [ 查找条件] [ 处理动作]

查找路径:指定具体目标路径;默认为当前目录

查找条件:指定的查找标准,可以文件名、大小、类型、

权限等标准进行;默认为找出指定路径下的所有文件

处理动作:对符合条件的文件做操作,默认输出至屏幕

3)查找条件

<1>根据文件名和inode 查找:

-name " 文件名称" :支持使用glob

*, ?, [], [^]

-iname " 文件名称" :不区分字母大小写

-inum n inode 号查找

-samefile name 相同inode 号的文件

-links n 链接数为n 的文件

举例:

 find / -name  “*.txt”记得需要加“”引号

<2>根据属主、属组查找:

-user USERNAME :查找属主为指定用户(UID) 的文件

-group GRPNAME:  查找属组为指定组(GID) 的文件

-uid UserID :查找属主为指定的UID 号的文件

-gid GroupID :查找属组为指定的GID 号的文件

-nouser :查找没有属主的文件

-nogroup:查找没有属组的文件

<3>  根据文件类型查找:

-type TYPE:

f:  普通文件

d:  目录文件

l:  符号链接文件

s :套接字文件

b:  块设备文件

c:  字符设备文件

p:  管道文件

<4>  组合条件:

与:-a

或:-o

非:-not, !

德 德· 摩根 定律:

非 非(P 且 且 Q) = (非 非 P) 或 或 (非 非 Q)

非 非(P 或 或 Q) = (非 非 P) 且 且 (非 非 Q)

!A -a !B = !(A -o B)

!A -o !B = !(A -a B)

<5>  根据文件大小来查找:

-size [+|-]#UNIT

常用单位:k, M, G

#UNIT: (#-1, #] ,如:6k

-#UNIT [0,#-1],  如:-6k

+#UNIT (#, ), 如:+6k

<6>根据时间戳:

以“天”为单位;

-atime [+|-]#,

#: [#,#+1)

+#: [#+1, ]

-#: [0,#)

-mtime

-ctime

以“分钟”为单位:

-amin

-mmin

-cmin

<7>  根据权限查找:

-perm [/|-]MODE

MODE:  精确权限匹配

/MODE :任何一类(u,g,o) 对象的权限中只要能一位匹配

即 可 ,或关系,+  centos7 开始淘汰

-MODE :每一类对象都必须同时拥有指定权限,与关系

0  表示不关注

find -perm 755 会匹配权限模式恰好是755 的文件

•  只要当任意人有写权限时,find -perm +222 就会匹配

•  只有当每个人都有写权限时,find -perm -222 才会匹配

•  只有当其它人(other )有写权限时,find -perm -002才 才

会匹配

<8> 处理动作

-print :默认的处理动作,显示至屏幕;

 -ls :类似于对查找到的文件执行“ls -l” 命令

 -delete :删除查找到的文件;

 -fls file :查找到的所有文件的长格式信息保存至指定文件中

 -ok COMMAND {} \;  对查找到的每个文件执行由

COMMAND 指定的命令;

对于每个文件执行命令之前,都会交互式要求用户确认

 -exec COMMAND {} \;  对查找到的每个文件执行由

COMMAND 指定的命令

 {}:  用于引用查找到的文件名称自身

 find 传递查找到的文件至后面指定的命令时,查找到所有符合

条件的文件一次性传递给后面的命令

  有些命令不能接受过多参数,此时命令执行可能会失败,下

面方式可规避此问题

find | xargs COMMAND

 

压缩文件工具

一、comperss命令(不常用)

 compress [-dfvcVr] [-b maxbits] [file …]

-d:  解压缩,相当于

-c:  结果输出至标准输出, 不删除原文件

-v:  显示详情

 uncompress 解压缩

 zcat file.Z >file

二、gizp命令

 gzip [OPTION]… FILE …

-d:  解压缩,相当于gunzip

-c:  将压缩或解压缩的结果输出至标准输出

-# 1-9 ,指定压缩比,值越大压缩比越大

 zcat :不显式解压缩的前提下查看文本文件内容

  实例:

    gzip -c messages >messages.gz

    gzip -c -d messages.gz > messages

    zcat messages.gz > messages

三、bizp2命令

 bzip2 [OPTION]… FILE …

   -k: keep,  保留原文件

   -d :解压缩

   -# 1-9 ,压缩比,默认为6

 bzcat :不显式解压缩的前提下查看文本文件内容;

四、xz命令

 xz [OPTION]… FILE …

   -k: keep,  保留原文件;

   -d :解压缩

   -# 1-9 ,压缩比,默认为6; ;

 xzcat:  不显式解压缩的前提下查看文本文件内容

     

 

                  作业

1 、写一个脚本/root/bin/createuser.sh ,实现如下功能:

使用一个用户名做为参数,如果指定参数的用户存在,就显

示其存在,否则添加之;显示添加的用户的id 号等信息.

答:

图片1.png

 

2 、写一个脚本/root/bin/yesorno.sh ,提示用户输入yes或 或

no, 并判断用户输入的是yes 还是no, 或是其它信息

答:

图片2.png 

3 、写一个脚本/root/bin/filetype.sh, 判断用户输入文件路

径,显示其文件类型(普通,目录,链接,其它文件类型)

答:

图片3.png

4 、写一个脚本/root/bin/checkint.sh, 判断用户输入的参数

是否为正整数

答:判断一个数是否为正整数,我想到了使用grep去匹配数字

图片4.png 

5、查找/var 目录下属主为root ,且属组为mail 的所有文件

答:

图片5.png 

6 、查找/var 目录下不属于root lp gdm 的所有文件

答:

图片6.png 

7 、查找/var 目录下最近一周内其内容修改过,同时属主不为

root ,也不是postfix 的文件。

答: 图片7.png8 、查找当前系统上没有属主或属组,且最近一个周内曾被访

问过的文件。

答:

图片8.png

9 、查找/etc 目录下大于1M 且类型为普通文件的所有文件

答:

图片9.png 

10 、查找/etc 目录下所有用户都没有写权限的文件

答:

图片10.png 

11、查找/etc 目录下至少有一类用户没有执行权限的文件

答:全部都有执行权限,进行取反即可。

图片11.png

12、查找/etc/init.d/目录下,所有用户都有执行权限,且其它

用户有写权限的文件   

答:注意/etc/init.d后需要加/

# find  /etc/init.d/    -perm  -111 -a -perm  /002  -ls

# find  /etc/init.d/    -perm  -113  -ls

          

 

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

(0)
178babyhanggege178babyhanggege
上一篇 2016-08-15
下一篇 2016-08-15

相关推荐

  • 初学者通过VMware安装CentOS7并实现本机windows端Xshell远程登陆

    这是我这个菜鸟在学习Linux过程中写的第一篇Blog。内容主要是通过VMware安装CentOS7系统,并且在本机的Windows端通过Xshell5来远程登陆安装好的虚拟机CentOS7系统。 首先通过VMware安装完CentOS7并进入系统。 使用root权限操作,通过 ~]#ifconfig or ~]#ip addr list 命令查询到虚拟机系…

    2017-10-11
  • 利用ansible-playbook从测试环境获取tomcat中java项目新版本发布到生产环境

    一、环境描述 安装有ansible的服务器:192.168.13.45 测试环境服务器:192.168.13.49 /home/app/api-tomcat/webapps/api.war为测试环境新版本war包位置 生产环境服务器:192.168.13.51 /home/app/api-tomcat/webapps/api.war为生产环境war包位置 /…

    Linux干货 2016-12-18
  • Linux系统的软链接和硬链接

    Linux的链接是一种共享文件和访问它的用户的若干目录项之间建立联系的一种方法。一共分为两种链接,分别是软链接和硬链接。 一、硬链接 1、硬链接的本质上是一个文件,它们除了名字不一样,其他都一样,占用的空间是一个。硬链接会增加文件的链接数。如下图 (1)建立硬链集之前     (2)建立硬链接之后 2、删去一个链接名,链接数减一…

    Linux干货 2016-10-22
  • Linux无人值守安装

    前言     通常情况下,我们安装Linux操作系统的时候需要从光盘启动,通过系统光盘bootloader启动安装程序,进入交互式安装模式,由用户配置安装选项,如磁盘分区、选择安装包等操作;安装完毕后重启结束安装。在生产环境中,成百上千台服务器需要安装操作系统的时候如果也采用交互式安装模式,无疑是极其低效的。本文主要介…

    Linux干货 2015-05-18
  • ssh+rsync批量管理,批量分发

    现在我简单架设了一个7台服务器的集群集体如下,架设集群的过程我就省略了… [nfs存储一台]192.168.42.10[负载均衡2台]192.168.42.40192.168.42.41[web服务器2台]192.168.42.30192.168.42.31[备份1台]192.168.42.20[mysql 1台]192.168.42.50 我现…

    Linux干货 2017-04-22
  • 程序员小抄大全

    你是否会经常忘记一些CSS中的函数名或是一些属性名,那个时候,你一定觉得,如果手边有一个“小抄”(Cheat Sheet)就好了。当然,这个“小抄”不是给你作弊用的,这个“小纸条”就是可以让你马上知道那个你最想知道的东西。这个“小抄”上也不需要有所有的东西,就需要那些经常用的就行了。现在,网上有很多这样的“小抄”,它们可能是PDF格式的,可能是PNG格式的,…

    Linux干货 2015-04-03

评论列表(1条)

  • 马哥教育
    马哥教育 2016-08-19 10:24

    文章写的很用心,对当天所学的东西有了一个完整的人是和梳理,不过linux学习最重要是实际操作,希望下来多加练习,掌握当天所学的东西。