设为首页 收藏本站
查看: 2746|回复: 0

Linux常用shell脚本

[复制链接]

尚未签到

发表于 2018-8-29 07:49:52 | 显示全部楼层 |阅读模式
  1. 设置ssh、scp命令的认证
  运行一次脚本后,以后再使用ssh或scp命令登录远程机器时不再提示输入密码
  -----------------setkey.sh开始-------------------------
  OLDDIR=`pwd`
  if [ -z "$1" ]; then
  echo Need user@host info;
  exit;
  fi;
  cd $HOME;
  if [ -e "./.ssh/id_rsa.pub" ]; then
  cat ./.ssh/id_rsa.pub | ssh $1 'mkdir -p .ssh;cat >> .ssh/authorized_keys';
  else
  ssh-keygen -t rsa;
  cat ./.ssh/id_rsa.pub | ssh $1 'mkdir -p .ssh;cat >> .ssh/authorized_keys';
  fi;
  cd $OLDDIR
  -----------------setkey.sh结束-------------------------
  用法:setkey.sh [用户名]@[要登录的目标机IP地址]
  2. 进程监控程序
  定时检查进程,发现进程挂掉时重启进程
  -----------------loopcheck.sh开始-------------------------
  #!/bin/sh
  predir=`pwd`
  filedir=`dirname $0`
  cd "${filedir}"
  curdir=`pwd`
  logfilename=./loopcheck.log
  #-----------------------------------
  # 函数: CheckProcess
  # 功能: 检查一个进程是否存在
  # 参数: $1 --- 要检查的进程名称
  # 返回: 如果存在返回0, 否则返回1.
  #---------------------------------------
  checkprocess()
  {
  if [ "$1" = "" ]; then
  return 1
  fi
  # $PROCESS_NUM获取指定进程名的数目,为1返回0,表示正常,不为1返回1,表示有错误,需要重新启动
  process_num=`ps -ef |grep "$1" |grep -v "grep" |wc -l`
  if [ $process_num -eq 1 ]; then
  return 0
  else
  return 1
  fi
  }
  # 启动C++进程
  startBinProcessByName()
  {
  /bin/$1  > "log.${1}.txt" &
  echo "`date` [startBinProcessByName]restart $1 ok" >> ${logfilename}
  }
  # 主逻辑
  while [ 1 ]; do
  # 对C++进程进行检查
  tblBins=("gamesvr.bin" "dbsvr.bin")
  for tblBin in "${tblBins[@]}";do
  checkprocess "${tblBin} server${serverNo}"
  check_result=$?
  if [ $check_result -eq 1 ]; then
  echo "`date` error ${tblBin}" >> ${logfilename}
  startBinProcessByName "${tblBin}"
  fi
  done
  # 每隔10秒执行一次
  sleep 60
  echo "`date` check ok" >> ${logfilename}
  done
  cd ${predir}
  -----------------loopcheck.sh结束-------------------------
  3. mysql数据库表自动修复脚本
  -----------------checkdbtable.sh开始-------------------------
  #!/bin/sh
  mysql_host=localhost
  mysql_user=star
  mysql_pass=star
  database=starcraft27
  tables=$(mysql -h$mysql_host -u$mysql_user -p$mysql_pass $database -A -Bse "show tables")
  for arg in $tables; do
  check_status=$(mysql -h$mysql_host -u$mysql_user -p$mysql_pass $database -A -Bse "check table $arg"  | awk '{ print $4 }')
  if [ "$check_status" = "OK" ]
  then
  echo "$arg is ok"
  else
  echo $(mysql -h$mysql_host -u$mysql_user -p$mysql_pass $database -A -Bse "repair table $arg")
  fi
  # echo $(mysql -h$mysql_host -u$mysql_user -p$mysql_pass $database -A -Bse "optimize table $arg")
  done
  -----------------checkdbtable.sh结束-------------------------
  4. mysql数据库备份脚本
  -----------------backupdb.sh开始-------------------------
  #!/bin/bash
  predir=`pwd`
  dir=`dirname $0`
  cd "${dir}"
  DB_DATABASE=databasename
  DB_USR=username
  DB_PWD=userpassword
  BACKDIR=../backup/db
  LOG_PATH=../backup/log
  DATE=`date +%Y.%m.%d.%H.%M.%S`
  targetFile=$BACKDIR/db.$DATE.tar.gz
  if [ $# = 1 ];then
  targetFile=$1
  fi
  mkdir -p $LOG_PATH
  echo "backupdb begin">>${LOG_PATH}/dailyMaintenace.log
  mkdir -p $BACKDIR
  mysqldump -u"${DB_USR}" -p"${DB_PWD}" $DB_DATABASE >$DB_DATABASE.$DATE.sql
  tar -zcf $targetFile $DB_DATABASE.$DATE.sql
  rm -rf $DB_DATABASE.$DATE.sql
  echo "backupdb done">>${LOG_PATH}/dailyMaintenace.log
  cd "${predir}"
  -----------------backupdb.sh结束-------------------------
  5. mysql数据库备份恢复脚本
  -----------------recoverdb.sh开始-------------------------
  #!/bin/bash
  predir=`pwd`
  dir=`dirname $0`
  cd "${dir}"
  if [ $# = 0 ];then
  echo please specified the source sql file for recover
  exit 0
  fi
  if [ ! -e $1 ];then
  echo "there isn't the file $1"
  exit 0
  fi
  DB_DATABASE=databasename
  DB_USR=username
  DB_PWD=userpassword
  RECOVERDIRTEMP=../backup/db/recovertmp
  echo recovering...
  mkdir -p $RECOVERDIRTEMP
  rm -rf $RECOVERDIRTEMP/*
  tar -xzf $1 -C $RECOVERDIRTEMP/
  if [ $# = 2 ];then
  mysql  -u"${DB_USR}" -p"${DB_PWD}"  -e "drop database  if exists ${DB_DATABASE};create database ${DB_DATABASE};"
  fi
  mysql -u"${DB_USR}" -p"${DB_PWD}" $DB_DATABASE < $RECOVERDIRTEMP/*.sql
  rm -f $RECOVERDIRTEMP/*.sql
  echo done
  cd "${predir}"
  -----------------recoverdb.sh结束-------------------------
  6. mysql数据库结果分析输出csv文件脚本
  -----------------export_userinfo.sh开始-------------------------
  #!/bin/bash
  rm -rf export_out.csv
  var=0
  records=()
  map=""
  date
  while read line
  do
  key=`echo $line | awk -F ' ' '{print $1}'`
  #echo $key
  result=(`mysql rxsg2_$1 --skip-column-names -e"select p.passport, u.name, u.level, o.total_online, u.vip from mem_passport p left join (mem_user u left join mem_user_online o on o.uid=u.uid) on u.uid=p.uid where p.passport='$key'"`)
  len=${#result[@]}
  if [ $len -ne 5 ]; then
  records[$var]="$key"
  else
  records[$var]="${result[0]},${result[1]},${result[2]},${result[3]},${result[4]}"
  fi
  #echo ${records[$var]};
  var=`expr $var + 1`
  #if [ $var -eq 5 ]; then
  #break;
  #fi
  done < export_in.txt
  outstr="";
  echo "over";
  #echo ${records
  • } > export_result.txt
      for ((i=0;i> export_out.csv
      #outstr=$outstr`echo ${map[$i]}``echo "\n"`
      done
      #echo $outstr > export_result.txt
      date
      -----------------export_userinfo.sh结束-------------------------
      【参考】
      http://www.cnblogs.com/end/archive/2011/07/20/2111888.html


  • 运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
    2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
    3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
    4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
    5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
    6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
    7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
    8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

    所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.iyunv.com/thread-557918-1-1.html 上篇帖子: Shell脚本查看apk签名信息 下篇帖子: shell脚本进行数据库操作
    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    扫码加入运维网微信交流群X

    扫码加入运维网微信交流群

    扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

    扫描微信二维码查看详情

    客服E-mail:kefu@iyunv.com 客服QQ:1061981298


    QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


    提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


    本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



    合作伙伴: 青云cloud

    快速回复 返回顶部 返回列表