Linux_Bash常用脚本

  • 时间:4年前
  • 浏览:1059次
  • 网赌被黑找腾龙D哥出黑【微信:JLYL78999 QQ:840093333】

    目录

    从用户列表中过滤用户名并创建用户

    ######################### name.sh  
    #!/bin/bash
    n=0
    userName=`echo $(cat /root/name.txt | tr -s " " | cut -d " " -f2 )`
    for userN in $userName
    do
            let ++n
            dirName=`echo $(cat /root/name.txt | awk -F " " '{print $1}')| cut -d " " -f$n`
            useradd -d /home/$dirName $userN
            echo 123456 | passwd --stdin $userN
    done

    awk、tr、cut 指令的文本处理

    awk、tr、cut 指令可以很好的进行文本信息处理

    tr指令

    一般用于文本或字符串编辑处理,可以替换、删除、合并重复字符。

    tr -s "Str" textString #将testString中的重复的"Str"合并为一个
    #如:
    tr -s " " 将标准输入的Text中的连续的" " 合并重一个空格符

    cut指令

    以分割的方式来编辑文本

    cut -d " " -f2
        -d 定义分隔符,将标准输入的文本信息以" "作为分隔符
        -f-d配合指定分割后要显示的区域
        -c numberRange <==>(2-5) 将Text中的2-5范围的字符截取出来

    awk指令

    awk就是把文件逐行的读入,以空格为默认分隔符将每行切片,切开的部分再进行分析处理。
    工作原理:读入并分割有’\n’换行符的的一条记录,再将这条记录以-F " "指定的特定分割符来划分出域,填充域,最后使用$Number 来选择需要显示第几个域并最终使用{print $Number}显示。没有-F指定特定分隔符时,默认分隔符为”空白键” 或 “[tab]键”。

    备份文件

    #############################Backups.sh  
    #!/bin/bash
    read -p "请输入要备份的内容:" backupName
    read -p "请输入要备份的文件名及路径:" backupUrl
    read -p "请输入要备份的文件的存放路径:" backupCpUrl
    read -p "请输入要使用的压缩算法:" backupAlg
    alg=0
    algName=0
    case $backupAlg in
    gzip)
            alg=z
            algName=gz
            ;;
    bzip2)
            alg=j
            algName=bz2
            ;;
    xz)
            alg=J
            algName=xz
            ;;
    *)
            echo "请输入正确的压缩算法类型!"
    esac
    
    tar ${alg}cvf ${backupCpUrl}/${backupName}.tar.${algName} ${backupUrl}
    if [ $? -eq 0 ]
            then echo "打包备份文件成功!"
    else
            echo "打包备份失败!"
    fi
    ########################################## SCRIPT END 

    测试LFTPServer权限设定

    ########################################## Lftp.sh 
    #!/bin/bash
    lftp 192.168.8.248 -u user1,fanguiju -e "cd share;ls;exit" &> /dev/null
    if [ $? -eq 0 ]
            then echo "user1用户可以读取share目录,符合要求!"
    else
            echo "user1用户不可以读取share目录,不符合要求!"
    fi
    lftp 192.168.8.248 -u user1,fanguiju -e "cd share;mkdir testSaDir_user1;exit" &> /dev/null
    if [ $? -eq 1 ]
            then echo "user1用户不可以写入share目录,符合要求!"
    else
            echo "user1用户可以写入share目录,不符合要求!"
    fi
    lftp 192.168.8.248 -u user1,fanguiju -e "cd data;ls;exit" &> /dev/null
    if [ $? -eq 0 ]
            then echo "user1用户可以读取data目录,符合要求!"
    else
            echo "user1用户不可以读取data目录,不符合要求!"
    fi
    lftp 192.168.8.248 -u user1,fanguiju -e "cd data;mkdir testDaDir_user1;exit" &> /dev/null
    if [ $? -eq 0 ]
            then echo "user1用户可以写入data目录,符合要求!"
    else
            echo "user1用户可以不写入data目录,不符合要求!"
    fi
    
    lftp 192.168.8.248 -u user2,fanguiju -e "cd share;ls;exit" &> /dev/null
    if [ $? -eq 0 ]
            then echo "user2用户可以读取share目录,符合要求!"
    else
            echo "user2用户不可以读取share目录,不符合要求!"
    fi
    lftp 192.168.8.248 -u user2,fanguiju -e "cd share;mkdir testSaDir_user2;exit" &> /dev/null
    if [ $? -eq 1 ]
            then echo "user2用户不可以写入share目录,符合要求!"
    else
            echo "user2用户可以写入share目录,不符合要求!"
    fi
    lftp 192.168.8.248 -u user2,fanguiju -e "cd data;ls;exit" &> /dev/null
    if [ $? -eq 0 ]
            then echo "user2用户可以读取data目录,符合要求!"
    else
            echo "user2用户不可以读取data目录,不符合要求!"
    fi
    lftp 192.168.8.248 -u user2,fanguiju -e "cd data;mkdir testDaDir_user2;exit" &> /dev/null
    if [ $? -eq 1 ]
            then echo "user1用户不可以写入data目录,符合要求!"
    else
            echo "user1用户可以写入data目录,不符合要求!"
    fi
    #FTP(File Transfer Protocol) lftp FTPServerIP -u userName,Password -e "command1;command2;exit" &> /dev/null 是编写LFTP服务脚本的方法
    ##################################################  SCRIPT END

    开启Httpd

    ################################################## HttpStatus.sh  
    #!/bin/bash
    while true
    do
            netstat -lputn | grep :80 &> /dev/null
            if [ $? -eq 0 ]
                    then echo "httpd running!"
                    exit
            else
                    echo "httpd stop"
                    echo "正在尝试重启httpd服务..."
                    echo `date +"%Y-%m-%d %H:%M:%S"` >> /var/log/mylog
                    tail -n 1 /etc/httpd/logs/error_log >> /var/log/mylog
                    service httpd start
            fi
            netstat -lputn | grep :80 &> /dev/null
            if [ $? -eq 0 ]
                    then
                    echo "httpd 重启启动成功!"
                    break
            fi
    done
    exit 0
    ################################################## SCRIPT END

    安装Httpd

    ################################################## InstallHttp.sh  
    #!/bin/bash
    rpm -q httpd
    if [ $? -eq 0 ]
            then echo "httpd已经安装!"
            exit 0
            else
            echo -n "正在安装httpd..."
    fi
    yum install -y httpd &> /dev/null
    rpm -q httpd
    if [ $? -eq 0 ]
            then echo "安装成功!"
    else
            echo -n "安装失败!" >> /var/log/mylog
            date >> /var/log/mylog
    fi
    ################################################# SCRIPT END

    批量创建用户

    ################################################# UserAdd.sh  
    #!/bin/bash
    while true
    do
    read -p "请输入要添加的用户数目(100以内):" userNum
    if [ $userNum -le 0 ] || [ $userNum -ge 100 ]
            then
            echo "请输入正确的数目范围!"
    else
            break
    fi
    done
    read -p "请输入用户名前缀:" userName
    read -p "请输入用户帐号的失效时间(MM/DD/YY):" userTime
    read -p "请输入用户的初始密码:" userPwd
    num=0
    for (( num=0;num<=$userNum;num++ ))
    do
    if [ $num -lt 10 ]
            then
            name=${userName}0${num}
            else
            name=${userName}$num
    fi
    useradd -e $userTime $name
    echo $userPwd | passwd --stdin $name
    done
    echo "你成功创建了${userNum}个用户!"
    ########################################### SCRIPT END

    批量删除用户

    ###########################################  UserDel.sh   
    #!/bin/bash
    if [ $# -ne 1 ]
            then echo "语法错误!"
            echo "用法:$0 用户名前缀"
    fi
    num=`echo $(cat /etc/passwd | grep -v ^root$ | cut -d ":" -f1 | grep -v ^root$ | grep $1 )`
    if [ -z $num ]
            then echo "没有以$1为前缀的用户"
            else
            for userName in $num
            do
            echo -n "正在删除用户$userName..."
            userdel -r $userName
            echo "完成"
            done
    fi
    # $# 脚本后接参数的个数 $# -ne 1 脚本后参数的个数!=1
    ############################################ SCRIPT END
    网赌被黑找腾龙D哥出黑【微信:JLYL78999 QQ:840093333】

    留言反馈

    网赌被黑找腾龙D哥出黑【微信:JLYL78999 QQ:978107219】鲁ICP备13008445号-3||Theme by Cn+网络, Soft by ZBlogPHP
  • 网赌被黑