shell 基础强化笔记 ( 二)

本贴最后更新于 1812 天前,其中的信息可能已经时移世改

1.杂谈

shift+> 缩进,v 进入选择模式

seq 命令用于产生从某个数到另外一个数之间的所有整数。

2.批量 ping 存活主机

 #!/bin/bash  
 for i in {1..254}  
 do  
  {  
  ip=120.255.0.$i  
  ping -c 1 -W 1 $ip &>/dev/null  
  if [ $? -eq 0 ];then  
  echo "$ip is ok"  
  else  
  echo "$ip is down"  
  fi  
  }&  
 done  
 wait  
 echo "ping is done"

3.批量判断是否 22 端口开启

 #!/bin/bash  
 >/tmp/activIp.log  
 for i in {1..254}  
 do  
  {  
  ip=120.255.0.$i  
  ping -c 1 -W 1 $ip &>/dev/null  
  if [ $? -eq 0 ];then  
  echo "$i. $ip is ok">>/tmp/activIp.log  
  else  
  echo "$i. $ip is down"  
  fi  
  }&  
 done  
 ​
 wait  
 echo "Scan ping is done"  
 echo "Scan port starting ..."  
 ​  
 IFS=$'\n'  
 for i in $(cat /tmp/activIp.log)  
 do  
  ip=$(echo $i |awk '{print $2}')  
  echo $ip  
  nmap $ip |grep "22" &>/dev/null  
 ​  
  if [ $? -eq 0 ];then  
  echo "$ip Port 22 is open!"  
  else  
  echo "$ip Port 22 is down!"  
  fi  
 done

4. mysql 主从监测恢复脚本

其中 for 循环中的{}&表示并发编程的意思

 #!/bin/bash  
 IO_Status=$(docker exec -it msmysql mysql -u root -p123456 -e "show slave status\G"|awk '/Slave_IO_Running:/ {print $2}'|sed 's/\r//')  
 SQL_Status=$(docker exec -it msmysql mysql -u root -p123456 -e "show slave status\G"|awk '/Slave_SQL_Running:/ {print $2}'|sed 's/\r//')  
 ​  
 if [ "$IO_Status" == "Yes" ] && [ "$SQL_Status" == "Yes" ];then  
  echo "数据库主从同步正常!"  
 else  
  echo "数据库主从同步失败!"  
  if [ ! "$IO_Status" == "Yes" ];then  
  IO_Err=$(docker exec -it msmysql mysql -u root -p123456 -e "show slave status\G"|awk '/Last_IO/')  
  echo -e "\033[31m Mysql slave 链接异常 \033[0m \n $IO_Err"  
  fi  
  if [ ! "$SQL_Status" == "Yes" ];then  
  IO_Err=$(docker exec -it msmysql mysql -u root -p123456 -e "show slave status\G"|awk '/Last_SQL_Errno:/ {print $2}'|sed 's/\r//')  
  echo -e "\033[31m Mysql slave Sql异常 \033[0m \n $IO_Err"  
  case $IO_Err in  
  1007)  
  sleep 2;  
  docker exec -it msmysql mysql -u root -p123456 -e "stop slave;set global sql_slave_skip_counter=1;start slave;"  
  IO_Err=$(docker exec -it msmysql mysql -u root -p123456 -e "show slave status\G"|awk '/Last_SQL_Errno:/ {print $2}'|sed 's/\r//')  
  if [ $IO_Err -eq 0 ];then  
  echo "尝试跳过一次,主从恢复正常"  
  else  
  IO_Err2=$(docker exec -it msmysql mysql -u root -p123456 -e "show slave status\G"|awk '/Last_SQL_Err/')  
  echo "$IO_Err2"  
  echo "发邮件!"  
  fi  
  ;;  
  1008)  
  echo "发邮件!"  
  ;;  
  *)  
  echo "发邮件!"  
  esac  
  fi  
 fi

快速搭建 mysql 主从测试环境参考:
https://www.cnblogs.com/songwenjie/p/9371422.html

  • 运维

    互联网运维工作,以服务为中心,以稳定、安全、高效为三个基本点,确保公司的互联网业务能够 7×24 小时为用户提供高质量的服务。

    149 引用 • 257 回帖
  • Shell

    Shell 脚本与 Windows/Dos 下的批处理相似,也就是用各类命令预先放入到一个文件中,方便一次性执行的一个程序文件,主要是方便管理员进行设置或者管理用的。但是它比 Windows 下的批处理更强大,比用其他编程程序编辑的程序效率更高,因为它使用了 Linux/Unix 下的命令。

    122 引用 • 74 回帖

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
  • yuanhenglizhen

    数据库主从判断优化

    #Author: MuFengs
    #QQ: 1126501575
    #Date: 2019-12-03
    #FileName: shell/check/mysql_m2s.sh
    #URL: https://blog.mufengs.com/
    #Description: The test script
    #********************************************************************
    
    
    # 输入格式 比如  user password host port
    echo "请输入从数据库的链接信息例如:user password host port"
    read -p "请输入从服务器的链接信息:" slavecons
    slavecon=($slavecons)
    # 基础方法
    getStatus(){
    	docker exec -it msmysql mysql -u${slavecon[0]} -p${slavecon[1]} -h${slavecon[2]} -P${slavecon[3]} -e "show slave status\G"
    	#docker exec -it msmysql mysql -u root -p123456 -e "show slave status\G"
    	}
    skipReslove(){
    	docker exec -it msmysql mysql -u${slavecon[0]} -p${slavecon[1]} -h${slavecon[2]} -P${slavecon[3]} -e "stop slave;set global sql_slave_skip_counter=1;start slave;"
    	}
    
    IO_Status=$(getStatus |awk '/Slave_IO_Running:/ {print $2}'|sed 's/\r//')
    if [ -z $IO_Status ];then
    		echo "数据库链接失败,请检查链接信息!"
    		exit
    fi
    SQL_Status=$(getStatus |awk '/Slave_SQL_Running:/ {print $2}'|sed 's/\r//')
    
    # 判断主从同步状况
    
    if [ "$IO_Status" == "Yes" ] && [ "$SQL_Status" == "Yes" ];then
    	echo "数据库主从同步正常!"
    else
    	echo "数据库主从同步失败!"
    	if [ ! "$IO_Status" == "Yes" ];then
    		IO_Err=$(getStatus |awk '/Last_IO/')
    		echo -e "\033[31m Mysql slave 链接异常 \033[0m \n $IO_Err"
    	fi
    	if [ ! "$SQL_Status" == "Yes" ];then
                    IO_Err=$(getStatus |awk '/Last_SQL_Errno:/ {print $2}'|sed 's/\r//')
                    echo -e "\033[31m Mysql slave Sql异常 \033[0m \n $IO_Err"
    		case $IO_Err in
    			1007)
    				sleep 2;
    				skipReslove
    				IO_Err=$(getStatus |awk '/Last_SQL_Errno:/ {print $2}'|sed 's/\r//')
    				if [ $IO_Err -eq 0 ];then
    					echo "尝试跳过一次,主从恢复正常"
    				else
    					IO_Err2=$(getStatus |awk '/Last_SQL_Err/')
    					echo "$IO_Err2"
    					echo "发邮件!"
    				fi
    				;;
    			1008)
    				echo "发邮件!"
    				;;
    			*)
    				echo "发邮件!"
    		esac
            fi
    fi