linux中实用的Shell示例有哪些

74次阅读
没有评论

共计 2944 个字符,预计需要花费 8 分钟才能阅读完成。

这篇文章将为大家详细讲解有关 linux 中实用的 Shell 示例有哪些,丸趣 TV 小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

1、并发从数台机器中获取 hostname,并记录返回信息花费的时长,重定向到一个文件 hostname.txt 中,在全部完成后输出花费时长最短的那台机器的 CPU 信息。

#!bin/bash #  所以主机,以空格分隔  ALL_HOSTS=(IP  地址  IP  地址) for host in ${ALL_HOSTS[*]} do { start_time=$(date + %s) ssh $host  hostname   /dev/null sleep 2 stop_time=$(date + %s) time_consuming=$((stop_time-start_time)) echo  $host: $time_consuming   hostname.txt }  done wait host=$(sort -n -k 2 hostname.txt | head -1 | awk -F :   {print $1} ) ssh $host  top -b -n 1

2、统计 /proc 目类下 Linux 进程相关数量信息,输出总进程数,running 进程数,stoped 进程数,sleeing 进程数,zombie 进程数。

输出所有 zombie 的进程到 zombie.txt 杀死所有 zombie 进程。

#!/bin/bash ALL_PROCESS=$(ls /proc/ | egrep  [0-9]+ ) running_count=0 stoped_count=0 sleeping_count=0 zombie_count=0 for pid in ${ALL_PROCESS[*]} do test -f /proc/$pid/status   state=$(egrep  State  /proc/$pid/status | awk  {print $2} ) case  $state  in R) running_count=$((running_count+1)) ;; T) stoped_count=$((stoped_count+1)) ;; S) sleeping_count=$((sleeping_count+1)) ;; Z) zombie_count=$((zombie_count+1)) echo  $pid   zombie.txt kill -9  $pid  ;; esac done echo -e  total: $((running_count+stoped_count+sleeping_count+zombie_count))\nrunning: $running_count\nstoped: $stoped_count\nsleeping: $sleeping_count\nzombie: $zombie_count

3、把当前目录(包含子目录)下所有后缀为 .sh 的文件后缀变更为 .shell,之后删除每个文件的第二行。

#!/bin/bash ALL_SH_FILE=$(find . -type f -name  *.sh) for file in ${ALL_SH_FILE[*]} do filename=$(echo $file | awk -F .sh   {print $1} ) new_filename= ${filename}.shell  mv  $file   $new_filename  sed -i  2d   $new_filename  done

4、判断目录 /tmp/jstack 是否存在,不存在则新建一个目录,若存在则删除目录下所有内容。

每隔 1 小时打印 inceptor server 的 jstack 信息,并以 jstack_${当前时间} 命名文件,每当目录下超过 10 个文件后,删除最旧的文件。

#!/bin/bash DIRPATH= /tmp/jstack  CURRENT_TIME=$(date + %F - %H:%M:%S) if [ ! -d  $DIRPATH  ];then mkdir  $DIRPATH  else rm -rf  $DIRPATH /* fi cd  $DIRPATH  while true do sleep 3600 #  这里需要将 inceptor 改后自己的 java 进程名称  pid=$(ps -ef | grep  inceptor  | grep -v grep | awk  {print $2} ) jstack $pid    jstack_${CURRENT_TIME}  dir_count=$(ls | wc -l) if [  $dir_count  -gt 10 ];then rm -f $(ls -tr | head -1) fi done

5、从 test.log 中截取当天的所有 gc 信息日志,并统计 gc 时间的平均值和时长最长的时间。

#!/bin/bash awk  {print $2}  hive-server2.log | tr -d  :  | awk  {sum+=$1} END {print  avg:  , sum/NR}   capture_hive_log.log awk  {print $2}  hive-server2.log | tr -d  :  | awk  {max = 0} {if ($1+0   max+0) max=$1} END {print  Max:  , max} capture_hive_log.log

6、查找 80 端口请求数最高的前 20 个 IP 地址,判断中间最小的请求数是否大于 500,如大于 500,则输出系统活动情况报告到 alert.txt,如果没有,则在 600s 后重试,直到有输出为止。

#!/bin/bash state= true  while $state do SMALL_REQUESTS=$(netstat -ant | awk -F [ :]+   /:22/{count[$4]++} END {for(ip in count) print count[ip]}  | sort -n | head -20 | head -1) if [  $SMALL_REQUESTS  -gt 500 ];then sar -A   alert.txt state= false  else sleep 6 continue fi done

7、将当前目录下大于 10K 的文件转移到 /tmp 目录,再按照文件大小顺序,从大到小输出文件名。

#!/bin/bash #  目标目录  DIRPATH= /tmp  #  查看目录  FILEPATH= .  find  $FILEPATH  -size +10k -type f | xargs -i mv {}  $DIRPATH  ls -lS  $DIRPATH  | awk  {if(NR 1) print $NF}

关于“linux 中实用的 Shell 示例有哪些”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-08-25发表,共计2944字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)