shell编程之条件判断和find查询

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

-p 指定要显示的提示

-t TIMEOUT

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

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

read -p “Enter a filename: “ FILE

 

条件选择if语句  多分支

if  CONDITION1 ; then

if-true

elif CONDITION2 ; then

if-ture

elif CONDITION3 ; then

if-ture

else

all-false

fi

逐条 件进行判断,第一次遇为“真”条件时,执行其分支,而后结束整个if

 

条件判断:case

case 用 变量引用 in

PAT1)

分支1

;;

PAT2)

分支2

;;

*)

默认分支

;;

esac

 

1.写一个脚本/root/bin/createuser.sh ,实现如下功能:使用一个用户名做为参数,如果指定参数的用户存在,就显示其存在,否则添加之;显示添加的用户的id

#!/bin/bash

read -p "please input a username: "  user

id $user &>/dev/null

if [ $? -eq 0 ];then

    echo "$user is exists"

else

    useradd $user

    echo "$user already created "

    id $user

fi

注意:红色的地方不能带$号

blob.png

 

2.写一个脚本/root/bin/yesorno.sh ,提示用户输入yes或no, 并判断用户输入的是yes 还是no

#!/bin/bash

read -p "Please input yes/no: " yesorno

case $yesorno in

[Yy][Ee][Ss]|[Yy])

echo yes

;;

[Nn][Oo]|[Nn])

echo no

;;

*)

  echo other

  ;;

esac 

blob.png

 

3.写一个脚本/root/bin/filetype.sh, 判断用户输入文件路径,显示其文件类型(普通,目录,链接,其它文件类型)

#!/bin/bash

read -p "Input a file path: " file

file $file

if [ -h $file ];then

     echo "$file is a symbolic link"

elif [ -f $file ];then

    echo "$file is a common file"

elif [ -d $file ];then

    echo "$file is a directory"

elif [ -p $file ];then

    echo "$file is a pipe file"

elif [ -S $file ];then

    echo "$file is a socket file"

elif [ -b $file ];then

    echo "$file is a block file"

else

    echo "please enter a correct file"

fi

blob.png

 

4. 写一个脚本/root/bin/checkint.sh, 判断用户输入的参数是否为正整数

[root@localhost 0815]# vim checkint.sh

#!/bin/bash                          

read -p "please input a number: " number

[ -z $number ] && echo echo "you must input a number " && exit

echo $number|egrep -q '^[-[:digit:]]*$'

if [ $? -eq 0 ];then

    if [ $number -gt 0 ];then

        echo "$number is a positive number"

    elif [ $number -eq 0 ];then

                                echo "Input is zero"                                    

    else

        echo "$number is a negative number"

    fi

else

    echo Input is not a number!

fi

blob.png

 


 

 

 

locate命令

快速、模糊、非实时查询,搜索未必精确,其依赖文件索引数据库/var/lib/mlocate/mlocate.db

linux有内容变动时,执行updatedb命令手动更新数据库,经实验加-v参数观察/tmp目录不在更新范围,因此/tmp内的文件无法被搜到,可采用find命令

locate常用选项:

-i:忽略大小写

blob.png

-r:正则匹配,例:locate -r '\.exe$'  // 搜索以.exe结尾的文件

blob.png

 

find命令

find [option] [path] [conditon] [action]

根据文件名和inode 查找:

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

blob.png

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

blob.png

-inum n 按inode号查找

blob.png

-samefile name 相同inode号的文件

blob.png

-links n 链接数为n的文件

blob.png

-regex "PATTERN":以PATTERN 匹配整个文件路径字符串,而不仅仅是文件名称

blob.png

根据属主、属组查找:

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

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

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

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

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

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

 

根据文件类型查找:

-type TYPE:

f: 普通文件

d: 目录文件

l: 符号链接文件

s: 套接字文件

b: 块设备文件

c: 字符设备文件

p: 管道文件

 

组合条件:

与:-a

或:-o

非:-not, !

德·摩根 定律:

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

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

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

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

记忆:非运算进出括号 -a与-o互换

blob.png

实例

find / -user wang –o –uid 33213

blob.png

 

找出/tmp 目录下,属主不是root ,且文件名不是fstab

find /tmp -not \( -user root -o -name 'fstab' \) 等价于

find /tmp \( -not -user root -a -not -name 'fstab' \)

注意: \( …… \) 格式,中间的空格不能省

 

排除目录

例: find /usr/local/tomcat/ -path '/usr/local/tomcat/conf' -a -prune -o -name *.xml –print   //排除conf目录

blob.png


 

根据文件大小来查找:

-size [+|-]#UNIT

常用单位:k, M, G

#UNIT: (#-1, #] ,如:6k 范围为5k~6k

-#UNIT :[0,#-1],  如:-6k 范围为0~5k

+#UNIT :(#, ∞ ), 如:+6k 范围为6k~∞

 

根据时间戳:

以“天”为单位;

-atime [+|-]#,

#: [#,#+1)

+#: [#+1,∞]

-#: [0,#)

-mtime

-ctime

以“分钟”为单位:

-amin

-mmin

-cmin

 

根据权限查找:

-perm [/|-]MODE

MODE:  精确权限匹配

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

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

表示不关注

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

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

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

只有当other有写权限时,find -perm -002才会匹配

记忆:"与"是求交集,结果少,用减号();"或"是求并集,结果多,用正斜线(/


 

处理动作

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

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

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

-fls file :查找到的所有文件的长格式信息保存至指定文件中,也开用>,重定向

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

COMMAND 指定的命令;

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

blob.png

blob.png

实验得-ok rm {} \; 可以交互式删除文件

-ok delete {} \; 会报文件目录不存在

-delete 无提示直接删除

 

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

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

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

有些命令不能接受过多参数,此时命令执行可能会失败,下面方式可规避此问题

find | xargs COMMAND

 

实例:

find /root/shellscripts/ -type f -perm 644 -name *.sh -exec chmod 755 {} \;

//找到sh文件并添加执行权限

blob.png

find -name *.xml -exec cp {} {}.org \;   //配置文件做备份

blob.png

find /tmp -ctime +3 -user root -ok rm {} \;  //删除root存在时间超过3天以上的临时文件 

find ~ -perm -002 -exec chmod o-w {} \;

blob.png

 

 

实战:

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

find /var -user root -group mail

2.查找/var 目录下不属于root.lp.的所有文件

  find /var -not -user root -not -user lp

3.查找/var 目录下最近一周内其内容修改过,同时属主不为root ,也不是postfix 的文件

  find /var -not \( -user root -o -user postfix \) -mtime -7

4.查找当前系统上没有属主或属组,且最近一个周内曾被访问过的文件

  find / \( -nouser -o -nogroup -atime -7 \) -ls

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

  find /etc -size +1M -type f

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

  find /etc/ -not -perm /222

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

  find /etc/ -not -perm /111

8.查找/etc/init.d 目录下,所有用户都有执行权限,且其它用户有写权限的文件

  find /etc/ -perm -111 -perm /002


 

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

(1)
上一篇 2016-08-18 10:10
下一篇 2016-08-18 10:10

相关推荐

  • Linux软件包管理器—rpm

    rpm 最开始是Red Hat Package Manager 之意,原用在Red Hat Linux一款软件包管理器,先在已被许多其他Linux 发行商使用,成为主流包管理器,rpm包的文件格式也写进Linux标准库中,所以rpm 现在递归意为RPM Package Manager。rpm的诞生使得在Linux上管理软件包变得方便许多,rpm功能强大,可完成构建、安装、查询、校验、升级和卸载软件包。

    Linux干货 2016-08-26
  • DNS and BIND 配置指南

    前言     说来接触Linux也有一年了,BIND是我曾经学习RH系Linux接触的第一个服务,对我有着莫大的意义,当初差点因为这个服务难以配置而放弃Linux,今天学完马哥的bind相关系列视频之后,写一篇DNS and BIND的基础到进阶。 一、DNS的基础知识 DNS是什么? DNS(Domain Name …

    Linux干货 2016-03-21
  • MySQL Fabric 安装部署

    MySQL Fabric  是一个用于管理 MySQL 服务器群的可扩展框架。该框架实现了两个特性 — 高可用性 (HA) 以及使用数据分片的横向扩展。这两个特性既可以单独使用,也可以结合使用。 环境: 安装MySQL Fabric 配置MySQL Fabric MySQL Fabric 安装管理数据库fabric 启动MySQL Fab…

    数据库运维 2016-06-03
  • Linux的文件系统的基础目录、帮助、部分命令介绍

    Linux的文件系统的基础目录、帮助、部分命令介绍 目录 linux基础目录 Linux获取帮助 相关控制命令,翻屏等 部分命令介绍 linux的基础目录 Bin: 共所有用户使用的基本命令,就是二进制程序 Sbin:系统的二进制程序。供管理员使用的 Boot:基本的加载器,引导加载器所依赖的各种静态文件 Dev:设备文件和特殊文件 其中设备分为两种类型,字…

    Linux干货 2016-10-29
  • loganalyzer——日志分析工具

    Loganalyzer是一款syslog日志和其他网络事件数据的Web前端。它提供了对日志的简单浏览、搜索、基本分析和一些图表报告的功能。数据可以从数据库或一般的syslog文本文件中获取,所以LogAnalyzer不需要改变现有的记录架构。基于当前的日志数据,它可以处理syslog日志消息,Windows事件日志记录,支持故障排除,使用户能够快速查找日志数…

    Linux干货 2016-10-18
  • 浅谈技术管理(转载,讲的非常不错,技术和产品都值得一看)

      针对这些年旁观和经历过的技术产品场景,做一些个人的总结和判定,尽量不涉及争议性话题,比如对一个互联网公司而言,技术重要还是产品重要之类的,这种话题一扯开,各有道理,谁也别指望说服谁。     此外,加一个前缀,主要针对非技术领导者所面临的技术管理困境,在很多从传统企业转型或个人站转型的互联网企业里,这个问…

    Linux干货 2015-04-04

评论列表(1条)

  • 马哥教育
    马哥教育 2016-08-19 14:51

    文章写的很认真,对细节方面有了一些明显的标识,通过实践操作将自己遇到的问题记录下来写成博客是个很好的习惯。