zoukankan      html  css  js  c++  java
  • if

          张贺,多年互联网行业工作经验,担任过网络工程师、系统集成工程师、LINUX系统运维工程师
          笔者微信:zhanghe15069028807,现居济南历下区
    

    if

    转换

    if语句可以转成一行由&&、|| 组成的的语句,例如:

    if [ -f /etc/passwd ];then
            echo "password file yes!"
    else
            echo "password file no!"
    fi
    

    可以转换成:

    [ -f /etc/passwd ] && echo "password file yes" || echo "password file no"
    

    或者转换成:

    [ ! -f /etc/passwd ] && echo "password file no" || echo "password file yes"
    

    文件比对

    参数 说明 示例
    r 文件存在且有读权限为真 [ -r file]
    w 文件存在且有写权限为真 [ -w file]
    x 文件存在且有执行权限为真 [ -x file]
    f 文件存在且是普通文件为真 [ -f file]
    d 目录存在则为真 [ -d file]
    e 如果文件或目录存在则为真 [ -e file]
    -s 文件非空为真 [ -s file]

    记忆说明:一共7个,前五个不用记忆,最后一个e就是-f和-d结合,-s就仅仅是探测文件是否为空。

    例子:交互式备份数据库

    #!/bin/bash
    #====================================
    #Date:2018/3/2
    #Author:zhanghe
    #Wechat:zhanghe@15069028807
    #Effect:interactive backup database
    #====================================
    
    DestPath=/backup/mysql
    M_User=root
    M_Pass="zhang@00"
    
    [ ! -d $DestPath ] && mkdir -p DestPath
    # [ -d DestPath ] || mkdir -p DestPath
    
    read -p "Please Input backup sql_name: " DB
    /usr/bin/mysqldump -u$M_User -p$M_Pass --single-transaction -R -B $DB > $DestPath/${DB}_$(date +%F).sql
    if [ $? -eq 0 ];then
    	echo "---------------------"
    	echo "backup $DB successful!"
    	echo "---------------------"
    fi
    

    整数数值比较

    参数 说明 示例
    -eq 等于为真 [ 1 -eq 9]
    -ne 不等于为真 [ 1 -ne 9]
    -gt 大于为真 [ 1 -gt 9]
    -lt 小于为真 [ 1 -lt 9]
    -ge 大于等于为真 [ 1 -ge 9]
    -le 小于等于为真 [ 1 -le 9]

    示例1:探测服务是否正在运行

    #!/bin/bash
    #====================================
    #Date:2018/3/2
    #Author:zhanghe
    #Wechat:zhanghe@15069028807
    #Effect:service run or down
    #====================================
    
    [ $# -ne 1 ] && echo "please input services name!" && exit 1
    systemctl status "$1" > /dev/null
    if [ $? -eq 0 ];then
            echo "$1 active!"
    elif [ $? -eq 4 ];then
            echo "no $1 services!"
    else
            echo "$1 is down!"
    fi
    

    示例2:探测磁盘/的用量,超时百分之八十就报警

    Disk_Free=$(df -h | grep "/$" | awk '{print $5}' | awk -F % '{print $1}')
    if [ $Disk_Free -gt 80 ];then
            echo "Disk Is Use:${Disk_Free}%" > /tmp/disk_use.txt
            mail -s "Disk_Free" 746620446@qq.com < /tmp/disk_use.txt
    fi
    

    示例3:探测内存使用量,超时百分之八十就报警

    Mem_Use=$(free -m | sed -n 2p | awk '{print $3/$2*100}')
    if [ ${Mem_Use%.*} -ge 80 ]
    then
            echo "Memory IS ERROR ${Mem_Use%.*}%"
    else
            echo "Memory IS OK ${Mem_Use%.*}%"        
    fi
    
  • 相关阅读:
    任何抛开业务谈大数据量的sql优化都是瞎扯
    关于优化for循环的注意的事项
    sql调优《二》
    页面加载通过javascript来修改控件属性
    。net内存优化
    oracle调优使用到相关sql
    oracle插入或更新某一个指定列来执行触发器
    webpack4基础入门操作(二)(讲解下webpack的配置内容)
    webpack4基础入门操作(一)
    关于一个WCF调用的服务端和客户端的配置信息集合
  • 原文地址:https://www.cnblogs.com/yizhangheka/p/12562246.html
Copyright © 2011-2022 走看看