练习一:获得连通主机的ip和hostname
1.脚本编写

vim  checkhost.sh
#!/bin/bash
Auto_conn()
{
/usr/bin/expect << EOF
set timeout 2
spawn ssh root@$1 $2
expect {
"yes/no" {send "yes\r";exp_continue }
"password" {send "westos\r" }
}
expect eof
EOF
}
for i in {75..79}
do
    ping -w1 -c1 172.25.254.$i &>> /dev/null && {
        IP=172.25.254.$i
    hn=`Auto_conn  $IP hostname|grep -E "ECDSA|authenticity|connecting|Warning|password|spawn" -v`
    echo $hn $IP >> /mnt/dns_file

sed  's/^M//g ' -i  /mnt/dns_file
    }
done

2.测试结果 

 

练习二:有分针秒针的倒计时
vim  daojishi1.sh
#!/bin/bash
for ((i=70;i>0;i--))
do
        shi=$((i/60))
        miao=$((i%60))
        echo -ne "\r倒计时:还有$shi分 $miao 秒结束"
        sleep 2
done
echo -ne "\r倒计时:0分 0秒!!"
练习三:两个文件分别为userlist和passlist,每行作为对应的用户和密码并进行创建,并对各种情况做出说明!
[root@desktop5 mnt]# cat users_create.sh
#!/bin/bash
[ "$USER" = "root" ]||{
    echo -e "\033[31mplease use rootuser!!\033[0m"
    exit
}
[ -z "$1" -o -z "$2" ]&&{
    echo -e "\033[31mparamater is  not two!!\033[0m"
    exit
}
[ ! -e "$1" -o ! -e "$2" ]&&{
    echo -e "\033[31mfile  is not exist!!\033[0m"
    exit
}
num1=`wc -l $1|cut -d " " -f 1`
num2=`wc -l $2|cut -d " " -f 1`
[ "$num1" = "$num2" ]&&{
for i in `seq 1 $num1`
do
    user=`sed -n ${i}p $1`
    ps=`sed -n ${i}p $2`
    dge=`getent passwd $user`
    if [ -z  "$dge" ]
    then
    useradd $user
    echo $ps | passwd --stdin $user &> /dev/null
    else
    echo  -e "\033[31m$user is already  exit!!\033[0m"
    fi
done
}||{
    echo -e "\033[31m$1 和 $2 行数不一致!!\033[0m"
    exit
}
练习四:数据库的备份
[root@desktop5 mnt]# cat mariadb.sh
#!/bin/bash
[ -z "$1" ]&&{
    echo nopass
    exit
}

#用来判断mariadb是否安装

DBCHECK=`rpm -qa | grep mariadb-server`
if [  -z "$DBCHECK" ]
then
    echo database software no install!!
    exit 1
fi
#判断是否开启mariadb服务
DB_STATE=`mysql -uroot -p$1 -e "show databases;" 2>&1 | awk '/sock/{print}'`
if [ ! -z "$DB_STATE" ]
then
    echo DB not start!!
    exit 2
fi
#判断密码是否正确
DB_STATE=`mysql -uroot -p$1 -e "show databases;"`
if [ "$?" != "0" ]
then
        echo DB passwd erro!!
        exit 3
fi
#创建目录
until [ -e "/mnt/mysqldump" ]
do
    mkdir -p /mnt/mysqldump
done

for DB_NAME in `mysql -uroot -p$1 -e "show databases;" -NE | grep -E "\*|chema" -v `
do
    [ ! -e "/mnt/mysqldump/${DB_NAME}.sql" ]&&{
    mysqldump -uroot -p$1 $DB_NAME > /mnt/mysqldump/$DB_NAME.sql
    }||{
    echo "/mnt/mysqldump/${DB_NAME}.sql  is exist you can do this:"
    echo "[S]kip  [B]ackup [O]verwrite"
    read -p "please input action:" ACTION1
    ACTION=`echo $ACTION1 | tr 'a-z' 'A-Z'`
    case $ACTION in
        S)
        echo skip it!!
        ;;
        B)
        mv /mnt/mysqldump/${DB_NAME}.sql /mnt/mysqldump/${DB_NAME}_backup.sql
        mysqldump -uroot -p$1 $DB_NAME > /mnt/mysqldump/${DB_NAME}.sql
        echo backup file create success!!
        ;;
        O)
        mysqldump -uroot -p$1 $DB_NAME > /mnt/mysqldump/${DB_NAME}.sql
        echo overwrite is ok!!
        ;;
        *)
        echo no sign
    esac
    }
done

shell脚本实例三的更多相关文章

  1. 分享7个shell脚本实例--shell脚本练习必备

    概述 看多shell脚本实例自然就会有shell脚本的编写思路了,所以我一般比较推荐看脚本实例来练习shell脚本.下面分享几个shell脚本实例. 1.监测Nginx访问日志502情况,并做相应动作 ...

  2. shell脚本实例-系统监控

    shell脚本监控网站并实现邮件.短信报警shell进程监控脚本(发送邮件报警)Shell脚本监控服务器在线状态和邮件报警的方法 http://www.jbxue.com/jb/shell/ 11. ...

  3. shell脚本实例

    备注:一些与传递给shell的参数相关的变量:$# 命令行参数的个数$? 调用命令的返回值$$ 当前进程的进程号$! 最后一个后台命令的进程号$0 命令行的第一个参数,也就是命令名$n 命令行的第n个 ...

  4. Shell脚本的三种执行方式

    Shell脚本的执行方式可以有以下几种: 方式一:  ./script.sh # 利用小数点来执行 方式二:  sh script.sh 或 bash script.sh # 利用bash(sh)来执 ...

  5. Shell 脚本中调用另一个 Shell 脚本的三种方式

    主要以下有几种方式: Command Explanation fork 新开一个子 Shell 执行,子 Shell 可以从父 Shell 继承环境变量,但是子 Shell 中的环境变量不会带回给父 ...

  6. shell脚本实例一

    一. 什么是shell 脚本时一种解释性语言: shell脚本保存执行动作: 脚本判定命令的执行条件 脚本来实现动作的批量执行.二.如何创建 vim  test.sh     ##shell脚本一般都 ...

  7. shell脚本实例,通向shell脚本大师的必经之路

    概述 读书百遍其义自见,shell脚本也是,只要例子看得多了,自然就知道怎么写了.这里主要整理了20几个例子,因为内容比较多,所以分了几次来做介绍了.下面的实例最好先自己思考怎么去实现,然后再看下实现 ...

  8. Linux shell脚本编程(三)

    Linux shell脚本编程 流程控制: 循环语句:for,while,until while循环: while CONDITION; do 循环体 done 进入条件:当CONDITION为“真” ...

  9. shell脚本实例一,移动文件夹中大于2000B的文件到另一个文件夹

    shell脚本能帮我们简化linux下的一些工作,现在有个需求,把TMPA文件夹下大于2000B的文件都移动到TMPB下 #! /bin/bash function movefiles() { ` d ...

随机推荐

  1. 【C#】枚举和字符串以及数字之间的互相转换

    准备条件: ①枚举类型: public enum enumColor { Red = , Yellow, Green, Blue, White, Black } ②以下状态都是理想状态,并未对错误数据 ...

  2. 软件测试技术作业3---PrintPrimes()

    一.代码部分: private static void printPrimes (int n) { int curPrime; // Value currently considered for pr ...

  3. 20145328 《Java程序设计》实验四实验报告

    20145328 <Java程序设计>实验四实验报告 实验名称 Andoid开发基础 实验内容 基于Android Studio开发简单的Android应用并部署测试; 了解Android ...

  4. redis命令的使用

    批量删除特定前缀的keys redis-cli KEYS "prefix:*" | xargs redis-cli DEL 返回list的长度 > LPUSH test &q ...

  5. 同余定理简单应用 - poj2769 - hdu 1021 - hdu 2035

    同余问题 基本定理: 若a,b,c,d是整数,m是正整数, a = b(mod m), c = d(mod m) a+c = b+c(mod m) ac = bc(mod m) ax+cy = bx+ ...

  6. 使用js合并table中的单元格

    用primefaces做的报表,领导要求合并相同内容的单元格,但是primefaces没有找到可以合并单元格的组件,想来想去,只有页面加载后用js合并了. http://blog.csdn.net/d ...

  7. Grunt Part 1

    Grunt Part 1 Objectives and Outcomes In this exercise, you will learn to use Grunt, the task runner. ...

  8. arm-linux-gcc安装使用教程

    arm-linux-gcc如何下载安装2(转) [转]ubuntu下交叉编译环境构建(arm-linux-gcc-3.4.1.tar.bz2 ) 2009-03-03 10:05 1.下载arm-li ...

  9. 【Jmeter】压测mysql数据库中间件mycat

    背景 因为博主所负责测试的项目需要数据库有较大的吞吐量,在最近进行了升级,更新了一个数据库中间件 - - mycat.查询了一些资料,了解到这是阿里的一个开源项目,基于mysql,是针对磁盘的读与写, ...

  10. Angular 4.x 修仙之路

    参考:https://segmentfault.com/a/1190000008754631 一个Angular4的博客教程目录