60天shell脚本计划-9/12-渐入佳境

--作者:飞翔的小胖猪

--创建时间:2021年3月8日

--修改时间:2021年3月12日

说明

 每日上传更新一个shell脚本,周期为60天。如有需求的读者可根据自己实际情况选用合适的脚本,也可在评论区留言提出脚本需求,作者会尽快根据需求编写相关脚本对功能进行实现。

 每篇文章包含5个脚本。

总进度:9/12

上一篇脚本链接:https://www.cnblogs.com/Pigs-Will-Fly/p/14495999.html

下一篇脚本链接:https://www.cnblogs.com/Pigs-Will-Fly/p/14539999.html

主要内容

21年3月8日-加解密脚本

************************************************************************************************************************************************************************************************************************************

脚本说明

使用xxd+bc+dc实现字符串的加密解密,只适用于英文和数字,中文不支持。

文件说明

custome_encrypt_string.sh:脚本主体文件

脚本主体

[root@135 41_custome_encrypt_string]# cat custome_encrypt_string.sh 
#!/bin/bash
#自定义一个简单的一键加密解密的命令,并封装成一个命令。

#加密
encrypt(){
  echo -e "\e[32m进行加密操作...................\e[0m"
  input_string=$1
  echo -e "\e[34m原字符串:\e[33m ${input_string}\e[0m"
  en_string=`echo "ibase=16; $(echo "${input_string}" |xxd -ps -u)" |bc`
  echo "原字符串:${input_string}  加密结果:${en_string}" >> .secure_string
  echo -e "\e[34m加密结果:\e[33m ${en_string}\e[0m ,信息已经保存到文件中。"
}


#解密
decryption(){
  #解密必须是数字,可以参考之前我判断字符串类型的脚本进行处理在https://www.cnblogs.com/Pigs-Will-Fly/p/14399775.html中第二脚本。
  echo -e "\e[32m进行解密操作...................\e[0m"
  input_string=$1
  echo -e "\e[34m原字符串:\e[33m ${input_string}\e[0m"
  #echo -e "${1}P"
  Decrypted_string=`dc -e ${1}P`
  echo -e "\e[34m解密结果:\e[33m ${Decrypted_string}\e[0m。"
}

#判断条件是否满足
check_env(){
  if which bc  &>/dev/null;then
    let bc_r=0
  else
    let bc_r=1
    echo -e "\e[31m bc软件不存在,请先安装。\e[0m"
  fi

  if which xxd &>/dev/null;then
    let xxd_r=0
  else
    let xxd_r=1
    echo -e "\e[31m xxd软件不存在,请先安装。\e[0m"
  fi

  if which dc &>/dev/null;then
    let dc_r=0
  else
    let dc_r=1
    echo -e "\e[31m dc软件不存在,请先安装。\e[0m"
  fi
  
  echo  -en "\e[34m环境检查结果: \e[0m"
  let total_r=${bc_r}+${xxd_r}+${dc_r}
  #echo -e "\e[33m环境检查的结果为:${total_r}\e[0m"
  if [  ${total_r} -eq 0 ];then
    echo  -e "\e[32m环境满足要求。\e[0m"
  else
    echo  -e "\e[31m环境不满足要求,无法进行后续操作,请检查相关软件是否存在。\e[0m"
    exit 66
  fi
  


}

#在main函数中判断用户的输入根据输入选择加密还是解密
main(){

  #判断函数是否有输入,加密解密选项可选,默认加密。 如果加密字符串不存在则提示命令不对,退出。
  input_type=${2:-encrypt}
  if [ -z "${1}" ];then
    echo -e "\e[31m Not input string。\n \e[33mUsage: input_string [encrypt|decryption]\e[0m"
    exit 55
  fi

  #检查系统环境是否满足脚本运行。
  check_env
 
  #按照不同的操作类型执行相应的操作。
  case ${input_type} in
    "encrypt")
      encrypt $1
      ;;
    "decryption")
      decryption $1
      ;;
    *)
     echo 'Usage: input_string [encrypt|decryption]'
     exit
    ;;
  esac
  echo -e "\e[0m"
}

main $1 $2

结果

执行结果

文件结果

**************************************************************************************************************2021年3月8日脚本结束*****************************************************************************************************************

 

21年3月9日-生成ansible role文件结构脚本

************************************************************************************************************************************************************************************************************************************

脚本说明

脚本通过用户键入的应用名,自动生成对应的roles目录结构及调用该roles的playbook文件。

文件说明

gen_ansible_dir_structure.sh:脚本主体文件

脚本主体

[root@135 42_gen_ansible_dir_structure]# cat gen_ansible_dir_structure.sh 
#!/bin/bash
#创建roles对应的文件夹结构
create_dir(){
  #获取用户输入的的应用名
  if [ -z "${1}" ];then
    echo -e "\e[31m 没有指定应用名,程序退出了,再见。\e[0m"
    exit 44
  fi 


  #创建目录
  input_dir_name=${1}
  mkdir roles/${input_dir_name}/{files,tasks,templates,vars,handlers,meta,default}  -p &>/dev/null

  dir_file=`pwd`
  echo -e "\e[34m文件夹创建结果: \e[0m"
  cd roles/${input_dir_name}/
  if [ -d files ] && [ -d tasks ] && [ -d templates ] && [ -d vars ] && [ -d handlers ] && [ -d meta ] && [ -d default ];then
    echo -e  "\e[32m目录创建完成。\e[0m"
  else  
    echo -e "\e[31m目录创建失败。具体信息。\033[0m"
    exit 33
  fi
}

create_file(){
  input_dir_name=$1

  cd ${dir_file}
  #判断是否存在文件,存在则提示是否继续,继续则备份原有文件。
  if [ -f roles/${input_dir_name}/tasks/main.yml ];then
    echo -e "\e[33m main.yml文件已经存在,确认是否继续生成。\e[0m"
    read -p "输入Y(继续) / N(退出),默认不继续:" input
    chose=${input:-N}

    #判断用户是否确定继续执行。
    if [ "${chose}"=="Y" ];then
      echo -e "\e[33m用户选择了继续执行。\e[0m"
      cp -rp roles/${input_dir_name}/tasks/main.yml roles/${input_dir_name}/tasks/main.yml.bak &>/dev/null
    else
      echo -e "\e[31m用户选择不继续执行,程序退出。\e[0m"
      exit 22
    fi
  fi
  
  #创建tasks下main.yml文件
  echo -e '- include: mode_1.yml\n- include: mode_2.yml\n- include: mode_3.yml' >  roles/${input_dir_name}/tasks/main.yml
  if [ -f ${input_dir_name}.yml  ];then
    echo -e "\e[31m同名调用文件已经存在,不创建新的文件,程序退出。\e[0m"
    exit 99
  fi
  echo -e "---\n- hosts: websrvs\n  remote_user: root\n  roles:\n    - ${input_dir_name}" > ${input_dir_name}.yml
  echo -e "\e[32m文件结构生成完成。\e[0m"
}

main(){
   create_dir $1
   create_file $1

}

main $1

结果

**************************************************************************************************************2021年3月9日脚本结束*****************************************************************************************************************

 

21年3月10日-画心脚本

************************************************************************************************************************************************************************************************************************************

脚本说明

执行脚本会生成一个爱心图。

文件说明

Draw_the_heart.sh:脚本主体文件

脚本主体

[root@135 43_Draw_the_heart]# cat Draw_the_heart.sh 
#!/bin/bash
#画心心
draw_hear(){
  y=1.25
  yy=46
  while [[ yy -gt 0 ]];
  do
    xx=-120
    x=-1.14
    while [[ 0 -gt xx ]];
    do
      cc=$(echo `awk -v a=${x} -v b=${y} 'BEGIN{printf "%.125f\n",a*a+b*b-1}'`)
      bb=$(echo `awk -v a=${cc} -v b=${y} -v c=${x} 'BEGIN{printf "%.125f\n",a*a*a-c*c*b*b*b}'`)
      ff=$(echo `awk -v a=${bb}  'BEGIN{printf "%.0f\n",a*10000000}'`)
      if [[ ff -le 0 ]]; then
        printf "\e[1;41m \e[0m"
      else
        printf " "
      fi
      x=$(echo `awk -v a=${x} -v b=0.02 'BEGIN{printf "%.125f\n",a+b}'`)
      xx=$(echo `awk -v a=${xx} -v b=1 'BEGIN{printf "%.0f\n",a+b}'`)
    done
    printf "\n"
    y=$(echo `awk -v a=${y} -v b=0.05 'BEGIN{printf "%.10f\n",a-b}'`)
    yy=$(echo `awk -v a=${yy} -v b=1 'BEGIN{printf "%.0f\n",a-b}'`)
  done
}

main(){
  draw_hear
}

main

结果

**************************************************************************************************************2021年3月10日脚本结束*****************************************************************************************************************

 

21年3月11日-清理/var/log/过期文件夹

************************************************************************************************************************************************************************************************************************************

脚本说明

业务方主机搭建为一个日志服务器,实时的把远端日志传送到本地,按照当前日期生成对应的文件夹如:2021-03-10 ,查找/var/log/中超过185天的以20开头的文件夹并进行删除,把删除记录置入到/var/log/messages文件中。

可以把脚本加入到定时任务中实现每天定时执行。

文件说明

auto_delete_dir.sh:脚本主体文件

脚本主体

[root@135 44_auto_delete_dir]# cat auto_delete_dir.sh 
#!/bin/bash
#shows files to be deleted
list_file(){
  find /var/log/ -mtime +185 -type d -name "20*" > /opt/auto_clear_log/.temp_dir_name.txt
}

#delete dir file
clear_file(){
  #判断待删除文件是否为空,如果为空则提示不删除,并把结果置入到/var/log/messages中
  if [[ ! -s /opt/auto_clear_log/.temp_dir_name.txt ]];then
    echo "`date` not exec clear operation." >> /var/log/messages
    #echo -e "\e[31m`date` not exec clear operation.\e[0m"
  else
    #依次读取待删除文件内容,一条一条的删除。
    for i in `cat /opt/auto_clear_log/.temp_dir_name.txt`
    do
      #echo -e "\e[33m ${i} dir file will delete.\e[0m "
      #判断是否删除成功,删除成功则记录到/var/log/messages文件中.
      if  rm -rf  ${i} &> /dev/null;then
        echo "`date` ${i} dir_file delete succeed."  >> /var/log/messages
        #echo -e "\e[33m`date` ${i} dir_file delete succeed.\e[0m"
      else
        echo "`date` ${i} dir_file delete failed."   >> /var/log/messages
        #echo -e "\e[31m`date` ${i} dir_file delete failed.\e[0m"
      fi
    done
  fi
}

#main function
main(){
  list_file
  clear_file
}

#call main function
main

结果

**************************************************************************************************************2021年3月11日脚本结束*****************************************************************************************************************

 

21年3月12日-oracle开机启动(简易版)

************************************************************************************************************************************************************************************************************************************

脚本说明

oracle单机数据库开机启动简易版,需要用户自行加入到/etc/rc.d/rc.local文件中,每次开机会生成对应的日志文件置入到/var/log/messages中。

文件说明

oracle_startup.sh:脚本主体文件

脚本主体

[root@135 45_oracle_startup]# cat oracle_startup.sh 
#/bin/bash
su - oracle <<EOF
source /home/oracle/.bash_profile
lsnrctl start
export ORACLE_SID=orcl
sqlplus / as sysdba <<EOE
startup
EOE
EOF


#check database services  status
program_num=0
port_num=0


#check database port 
if ss -alntup | grep 1521 &>/dev/null;then
  echo "`date` Oracle Database The listener starts normally,1521 Port listening........" >>  /var/log/messages
else  
  port_num=1
  echo "`date` Oracle Database The listener starts an exception"  >> /var/log/messages
fi

#total oracle program num
tmp_program_num=`ps -ef | grep ora_  | grep -v grep | wc -l`
if [ ${tmp_program_num} -gt 5 ];then
  echo "`date` Oracle Database process normal."   >> /var/log/messages
else
  echo "`date` Oracle Database process exception."  >> /var/log/messages
  program_num=1
fi


if [ ${port_num} -eq 1 ] || [ ${program_num} -eq 1 ];then
  echo "`date` Oracle Database startup exception."   >> /var/log/messages
else
  echo "`date` Oracle Database startup success."   >> /var/log/messages
fi

结果

**************************************************************************************************************2021年3月12日脚本结束*****************************************************************************************************************

 

posted @ 2021-03-08 11:48  飞翔的小胖猪  阅读(116)  评论(0编辑  收藏  举报