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进行替换
结果: