shell 脚本

shell 清理log ,

#/bin/bash

find /var/log/hadoop/ocdp/ -mtime +2 -name "hdfs-audit.log.*" -exec rm -rf {} \;

find . -name "*.log.*" -exec du -k {} \; |awk '{sum+=$1}END{print sum}'


————————————————————————————————————————————————

ssh 登录跳转脚本,不需要每次去登录了, 直接执行./tiao.sh 就可以登录到目标主机上了。

cat tiao.sh            // 跳了两次

#!/usr/bin/expect 

set timeout 3

spawn ssh ocdc@xx.xx.xxx.xxx

expect "*password:"

send "23pBZHjg4y\r"

#interact

expect "]*"

send "ssh root@yy.yy.yyy.y \r"

expect "*password:"

send "8Wfy_zwy\r"

expect "]*"

send "su - ocdp \r"

interact





#!/usr/bin/expect           实现自动su , 自动跳转

spawn su - aisware

expect "Password:"

send "qW&Pa5gW3gnJ0#cw\r"

#interact

send "ssh aisware@hohhot031 \r"

expect "*password:"

send "qW&Pa5gW3gnJ0#cw\r"

interact


SSH 互信 ,脚本实现yes, 密码 输入。 脚本执行完成后,会更改 PS1 变量。 需执行  PS1='[\u@\h \w]\$ ' 

#!/bin/bash

cat /home/ocdp/hostliu.txt |while read hostline

do

/usr/bin/expect << EOF

set timeout 3

spawn ssh-copy-id -i /home/ocdp/.ssh/id_rsa.pub ocdp@$hostline

expect {

    "*yes/no" { send "yes\r"; exp_continue }

    "*password:" { send "Asia%2019\r" }

    }

#  expect "*$"

#  send "hostname -f\r"

#    expect "*$"

#    send "exit\r"

#interact

expect eof

EOF

done



check_alive.sh
#!/bin/bash

if [ ! -f /tmp/check.txt ];then

  touch /tmp/check.txt

else

  >/tmp/check.txt

fi

ip=172.20.54.

for i in `seq 21 140`

do

 ping -w 1 -c 1 ${ip}${i}  >/dev/null

   if [ $? -eq 0 ];then

     echo "${ip}${i} .........is live" >>/tmp/check.txt

   else

      echo "${ip}${i} .........is unlive" >>/tmp/check.txt

   fi

done



mysqlbak.sh
#!/bin/sh

MYUSER=root

MYPASS=Test%0328

SOCKET=/usr/local/mysql/mysql.sock

MYLOGIN="mysql -u$MYUSER -p$MYPASS -S $SOCKET "

MYDUMP="mysqldump -u$MYUSER -p$MYPASS -S$SOCKET -B"

DATABASE="$($MYLOGIN -e "show databases;" |egrep -vi "Data|_schema|mysql|sys")"

echo $DATABASE

for dbname in $DATABASE

  do

  MYDIR=/server/backup/$dbname

  [ ! -d $MYDIR ] && mkdir -p $MYDIR

  $MYDUMP $dbname|gzip >$MYDIR/${dbname}_$(date +%F).sql.gz

done



实时网速统计:
#!/bin/sh

if [ "$1" = "" ];then  #判断后面是否有跟参数

  echo -e "\n  use interface_name after the script,like \"script eth0\"...\n"

  exit -1

fi

echo -e "\n  start monitoring the $1,press \"ctrl+c\" to stop"

echo ----------------------------------------------------------

file=/proc/net/dev  #内核网卡信息文件

while true

  do

  RX_bytes=`cat $file|grep $1|sed 's/^ *//g'|awk -F'[ :]+' '{print $2}'`  #这里sed这一步为了同时兼容centos6和7

  TX_bytes=`cat $file|grep $1|sed 's/^ *//g'|awk -F'[ :]+' '{print $10}'`

  sleep 10

  RX_bytes_later=`cat $file|grep $1|sed 's/^ *//g'|awk -F'[ :]+' '{print $2}'`

  TX_bytes_later=`cat $file|grep $1|sed 's/^ *//g'|awk -F'[ :]+' '{print $10}'`

  #B*8/1024/1024=Mb

  speed_RX=`echo "scale=2;($RX_bytes_later - $RX_bytes)/1024/1024"|bc`

  speed_TX=`echo "scale=2;($TX_bytes_later - $TX_bytes)/1024/1024"|bc`

  printf "%-3s %-3.1f %-10s %-4s %-3.1f %-4s\n" IN: $speed_RX Mb/s OUT: $speed_TX Mb/s

done



#!/bin/bash

for i in {1..9}

do

  umount /data0$i

done

umount /data10

#格式化硬盘

PIDARRAY=()

for i in b c d e f g h i j k

do

  parted -s /dev/sd$i mklabel gpt

  parted -s /dev/sd$i mkpart primary 0% 100%

  mkfs.ext4 -T largfile /dev/sd$i"1" &

  PIDARRAY+=("$!")

  echo "sd$i"1" is formatting.....,please wait!!!!!"

done

wait ${PIDARRAY[@]}

if [ $? -eq 0 ]; then

  echo " disk has been formatted successful"

else

  exit 110

fi

#修改自动挂载

sed -i s/UUID/#UUID/g /etc/fstab

echo "/dev/sdb1 /hdfs/data1 ext4 defaults 1 2" >> /etc/fstab

echo "/dev/sdc1 /hdfs/data2 ext4 defaults 1 2" >> /etc/fstab

echo "/dev/sdd1 /hdfs/data3 ext4 defaults 1 2" >> /etc/fstab

echo "/dev/sde1 /hdfs/data4 ext4 defaults 1 2" >> /etc/fstab

echo "/dev/sdf1 /hdfs/data5 ext4 defaults 1 2" >> /etc/fstab


mount /dev/sdb1 /hdfs/data1

mount /dev/sdc1 /hdfs/data2

mount /dev/sdd1 /hdfs/data3

mount /dev/sde1 /hdfs/data4

mount /dev/sdf1 /hdfs/data5


ambari 元数据备份
#!/bin/sh

now=`date "+%y%m%d"`

export PATH=/usr/bin:/usr/local/bin:$PATH

cd /home/ocdc/mysqlbak_ambari

mysqldump -h10.299.31.250 -uroot -pAsia%222 --set-gtid-purged=OFF --databases ambari --triggers --routines --events >mysql_ambari_${now}.sql

echo "==mysqldata dump Completed !=="

#backup to remote server

tar -zcvf mysql_ambari_${now}.tgz  mysql_ambari_${now}.sql --remove-files

scp /home/ocdc/mysqlbak_ambari/mysql_ambari_${now}.tgz 10.299.31.242:/home/ocdc/mysqlbak_ambari/

scp /home/ocdc/mysqlbak_ambari/mysql_ambari_${now}.tgz 10.299.31.130:/data02/mysqlbak_ambari/

#rm 7 days ago

find /home/ocdc/mysqlbak_ambari/  -mtime +7 -name 'mysql_ambari_*.tgz' -exec rm {} \;

ssh 10.299.31.242 "find /home/ocdc/mysqlbak_ambari/  -mtime +7 -name 'mysql_ambari_*.tgz' -exec rm {} \;"

ssh 10.299.31.130 "find /data02/mysqlbak_ambari/  -mtime +7 -name 'mysql_ambari_*.tgz' -exec rm {} \;"

exit 0




tomcat  定时重启

#!/bin/bash

#. /etc/profile

tomcatPath="/usr/local/apache-tomcat-9.0.19"

binPath="$tomcatPath/bin"

echo "[info][$(date +'%F %H:%M:%S')]正在监控tomcat,路径:$tomcatPath"

pid=`ps -ef | grep tomcat | grep -w $tomcatPath | grep -v 'grep' | awk '{print $2}'`

if [ -n "$pid" ]; then

echo "[info][$(date +'%F %H:%M:%S')]tomcat进程为:$pid"

echo "[info][$(date +'%F %H:%M:%S')]tomcat已经启动,准备使用shutdown命令关闭..."

$binPath"/catalina.sh" stop

sleep 2

pid=`ps -ef | grep tomcat | grep -w $tomcatPath | grep -v 'grep' | awk '{print $2}'`

if [ -n "$pid" ]; then

echo "[info][$(date +'%F %H:%M:%S')]使用shutdown命令关闭失败,准备kill进程..."

kill -9 $pid

echo "[info][$(date +'%F %H:%M:%S')]kill进程完毕!"

sleep 1

else

echo "[info][$(date +'%F %H:%M:%S')]使用shutdown命令关闭成功!"

fi

else

echo "[info][$(date +'%F %H:%M:%S')]tomcat未启动!"

fi

echo "[info][$(date +'%F %H:%M:%S')]准备启动tomcat..."

$binPath"/catalina.sh" start



0 0 * * * nmon -s10 -c8640 -f -m /home/ocdc/app/nmon_monitor >/dev/null 2>&1

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,992评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,212评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,535评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,197评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,310评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,383评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,409评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,191评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,621评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,910评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,084评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,763评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,403评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,083评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,318评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,946评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,967评论 2 351

推荐阅读更多精彩内容

  • 如果本机公钥和私钥是有密码的,需要重新生成,并且不去设置密码,否者免密登陆的时候, 远程主机不需要密码了,但是每次...
    你说你要一场阅读 690评论 0 0
  • 1 概述 expect 是由Don Libes基于Tcl(Tool Command Language )语言开发的...
    ghbsunny阅读 11,529评论 0 0
  • 西冰老师是业内大专家,各位可以百度。 他自从转入新媒体研发推广这二年来,仿佛老房子着火一般无法抵挡,而且其思考角度...
    車鉴阅读 559评论 0 0
  • 炎炎夏日的暑假,热浪滚滚,对于刚考上事业单位的我来说,本可以好好的放松一下,可是没休息几天我就开始了我的兼职工作—...
    慕容兰馨阅读 731评论 10 13
  • 总有一天 我要背一小包零食 带上相机 穿最喜欢的西装裤和小皮鞋 选一个最风和日丽的日子 买两张去外地的票 随便去哪...
    哀慕熙荣阅读 124评论 0 1