shell应用示例

1.数据库备份

执行 “mysql_dump.sh 数据库密码”
脚本执行后会备份数据库中的所有库到/mnt/mysql_dump/目录中
备份文件名为“库名称.sql” 当此文件存在时报错并询问动作
输入 “s” 跳过备份,输入“b”时备份“库名称.sql”文件为“库名称_backup.sql”,当输入“o”时,覆盖原文件

[root@localhost mnt]# vim mysql_dump.sh 
#!/bin/bash
ACTION_CMD()
{
read -p "${DATABASE_NAME}.sql is exist
          [S]kip [B]ackup [O]verwrite
          please input action: " ACTION
          ACTION=`echo $ACTION | tr 'A-Z' 'a-z'`
      case $ACTION in
          s)
          continue
          ;;
          b)
          cp -p /mnt/mysql_dump/${DATABASE_NAME}.sql  /mnt/mysql_dump/${DATABASE_NAME}_backup.sql
          echo backup!!!
          ;;
          o)
          mysqldump -uroot -p $DATABASE_NAME > /mnt/mysql_dump/${DATABASE_NAME}.sql
          echo overwrite!!!
          ;;
          exit)
          exit 0
          ;;
          *)
          echo "Please input [S][B][O]: "
          ACTION_CMD
      esac
}
DATABASE_MESSAGE=`mysql -uroot -EN -p$1 -e "show databases;"|grep -E "^\*|schema$" -v`
mkdir -p /mnt/mysql_dump
for DATABASE_NAME in $DATABASE_MESSAGE
do
     [ -e "/mnt/mysql_dump/${DATABASE_NAME}.sql" ]&&{
     ACTION_CMD
     }
     mysqldump -uroot -p$1 $DATABASE_NAME > /mnt/mysql_dump/${DATABASE_NAME}.sql
     [ "$?" -eq "0" ]&&{
            echo -e "\033[32m$DATABASE_NAME is backuped!!\033[0m"
     }
done
[root@localhost mnt]# ls -l mysql_dump
[root@localhost mnt]# sh mysql_dump.sh lin

脚本内容:
这里写图片描述
输入 “s” 跳过备份
这里写图片描述
输入“b”时备份“库名称.sql”文件为“库名称_backup.sql”
这里写图片描述
当输入“o”时,覆盖原文件
这里写图片描述
输入其他时报错,并重新输入,输入exit时退出
这里写图片描述

2.服务器自动部署示例

执行脚本lamp.sh
脚本执行后部署好论坛,并设定apache的网络端口为8080
下载Discuz_X3.2_SC_UTF8.zip安装包到/varwww/html

这个脚本暂时还没完成。。。。。。
[root@localhost mnt]# unzip /var/www/html/Discuz_X3.2_SC_UTF8.zip 
[root@localhost mnt]# vim lump.sh
#!/bin/bash 
chomd 777 /var/www/html/upload -R
systemctl start mariadb
yum install php-mysql -y
yum install httpd -y
systemctl restart httpd
sed -e '/^Listen*/c\Listen 8080' -i /etc/httpd/conf/httpd.conf

执行
这里写图片描述
端口已经被改:
这里写图片描述

3.自动登录脚本

执行auto_ssh.sh 172.25.254.252 redhat ;其中172.25.254.252为ip,redhat为密码
执行脚本自动登录并保持登录

[root@localhost mnt]# vim auto_ssh.sh
#!/bin/bash
/usr/bin/expect <<EOF
set timeout -1
spawn ssh root@$1
expect {
        yes/no { send "yes\r";exp_continue }
        password: { send "$2\r"; }
}
expect eof
EOF
[root@localhost mnt]# sh auto_ssh.sh 172.25.254.252 redhat
spawn ssh root@172.25.254.252
The authenticity of host '172.25.254.252 (172.25.254.252)' can't be established.
ECDSA key fingerprint is eb:24:0e:07:96:26:b1:04:c2:37:0c:78:2d:bc:b0:08.
Are you sure you want to continue connecting (yes/no)? yes
Warning: Permanently added '172.25.254.252' (ECDSA) to the list of known hosts.
root@172.25.254.252's password: 
Last login: Fri Jun 22 07:37:17 2018 from 172.25.254.155
[root@server ~]# 

脚本内容
这里写图片描述
执行结果:
这里写图片描述

4.批处理脚本

检测教师中开启的所有主机并抓取所有主机的名称和ip的对应列表,把列表版存在/mnt/ip_host.list文件中

由于宿舍只有一台电脑,所以检测范围缩小一点,但道理是一样的
[root@localhost mnt]# vim host_check.sh
#!/bin/bash
AUTO_check()
{
/usr/bin/expect <<EOF
set timeout 10
spawn ssh root@172.25.254.$IP hostname     #连接主机并查看主机名
expect {
        "yes/no" { send "yes\r";exp_continue }
        "password:" { send "redhat\r" }    #“redhat”为密码
}
expect eof
EOF
}
for IP in {250..252}                       #检测250到252这三台主机中开着的主机
do
    ping -c1 -w1 172.25.254.$IP &> /dev/null &&{
         HOST_name=`AUTO_check|grep -E "authenticity|fingerprint|connecting|password|spawn|Warning" -v`
    }
    echo $HOST_name 172.25.254.$IP | sed 's/\r//g' >>/mnt/host_ip.list  #将主机名和ip导入文件
    #(执行脚本后/mnt/host_ip.list文件里会出现\r这个符号,\r是unix系统里的换行符,sed命令是为了把/mnt/host_ip.list文件里\r替换为空格,如果在脚本里不执行这个命令,也可以在文件内执行:%s/ctrl+v ctrl+m/ /g 如最后两个截图)
done

脚本内容:
这里写图片描述
执行脚本
这里写图片描述
/mnt/ip_host.list文件内容:
这里写图片描述
脚本中没执行sed替换\r的话可以在/mnt/host_ip.list中执行:%s/ctrl+v ctrl+m/ /g进行替换
这里写图片描述
结果:
这里写图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值