“脚本”的版本间的差异

来自tomtalk
跳转至: 导航搜索
Linux 磁盘监控脚本
Tom讨论 | 贡献
Linux CPU、内存 监控脚本
第193行: 第193行:
  
 
==Linux CPU、内存 监控脚本==
 
==Linux CPU、内存 监控脚本==
 
 
<source lang="bash">
 
<source lang="bash">
 
#!/bin/bash
 
#!/bin/bash
#script  to capture system statistics
 
 
DATE=`date +%Y/%m/%d`
 
DATE=`date +%Y/%m/%d`
 
TIME=`date +%H:%M:%S`
 
TIME=`date +%H:%M:%S`
第207行: 第205行:
 
FREE=`$VMOUT|sed -n '/[0-9]/p'|sed -n '2p'|gawk '{print $4} '`
 
FREE=`$VMOUT|sed -n '/[0-9]/p'|sed -n '2p'|gawk '{print $4} '`
 
FREE=`expr $FREE / 1024`
 
FREE=`expr $FREE / 1024`
 
 
IDLE=`$VMOUT|sed -n '/[0-9]/p'|sed -n '2p'|gawk '{print $15}'`
 
IDLE=`$VMOUT|sed -n '/[0-9]/p'|sed -n '2p'|gawk '{print $15}'`
  
 
echo "$DATE $TIME  users = $USERS  1m avg.load = $LOAD  free = ${FREE}MB  idle = $IDLE"  
 
echo "$DATE $TIME  users = $USERS  1m avg.load = $LOAD  free = ${FREE}MB  idle = $IDLE"  
 +
 +
#cpu
 +
wget -q -O /dev/null "http://www.tomtalk.net:8080/receive/unit_data?code=cpu_load&value=$LOAD"
 +
 +
#memory
 +
wget -q -O /dev/null "http://www.tomtalk.net:8080/receive/unit_data?code=mem_free&value=$FREE"
 
</source>
 
</source>
  

2017年4月1日 (六) 06:34的版本

备份数据库

#!/bin/bash
FILE_NAME="tgfx".data.`date +%Y%m%d`.tar.gz
cd /opt/data/
rm -rf "tgfx".data.$(date -d -14day +"%Y%m%d").tar.gz
tar -zcvf $FILE_NAME /var/lib/mysql/anxintgfx2 -C /opt/data

磁盘容量监控脚本

#!/bin/bash  
 
AA=`date +%Y-%m-%d`
 
df=$(df -h | grep hda1 | awk '{print $5}')
 
echo $AA  $df >> /root/df.per.day

sh文件增加可执行权限

chmod +x hello.sh

Awk

Awk 是其作者 "Aho,Weinberger,Kernighan" 的简称。Awk是一种处理结构数据并输出格式化结果的编程语言。

Awk通常被用来进行格式扫描和处理。通过扫描一个或多个文件中的行,查看是否匹配指定的正则表达式,并执行相关的操作。


Awk的工作方式

Awk 语法 awk 'pattern {action}'

  1. Awk 一次读取文件中的一行
  2. 对于一行,按照给定的正则表达式的顺序进行匹配,如果匹配则执行对应的 Action
  3. 如果没有匹配上则不执行任何动作
  4. 在上诉的语法中, Search Pattern 和 Action 是可选的,但是必须提供其中一个
  5. 如果 Search Pattern 未提供,则对所有的输入行执行 Action 操作
  6. 如果 Action 未提供,则默认打印出该行的数据
  7. {} 这种 Action 不做任何事情,和未提供的 Action 的工作方式不一样
  8. Action 中的语句应该使用分号分隔


注意

Awk包含许多内建的变量,对于每行的记录, Awk 默认按照空格进行分割,并将分隔后的值存入对应的 $n 变量中。如果一行还有 4 个单词,将被分别存储进 $1 $2 $3 $4 中,其中 $0 代表整行。 NF 也是一个内建的变量,代表该行中分割后的变量个数。

示例:

du -k $filepath =>4  tt.js $1=4 $2=tt.js $0=4  tt.js

linux中用shell获取昨天、明天或多天前的日期

linux中用shell获取昨天、明天或多天前的日期: 在Linux中对man date -d 参数说的比较模糊,以下举例进一步说明:

  1. -d, --date=STRING display time described by STRING, not `now’

[root@Gman root]# date -d next-day +%Y%m%d #明天日期 20091024 [root@Gman root]# date -d last-day +%Y%m%d #昨天日期 20091022 [root@Gman root]# date -d yesterday +%Y%m%d #昨天日期 20091022 [root@Gman root]# date -d tomorrow +%Y%m%d # 明天日期 20091024 [root@Gman root]# date -d last-month +%Y%m #上个月日期 200909 [root@Gman root]# date -d next-month +%Y%m #下个月日期 200911 [root@Gman root]# date -d next-year +%Y #明年日期 2010 DATE=$(date +%Y%m%d --date ’2 days ago’) #获取昨天或多天前的日期

名称 : date 使用方式 : date [-u] [-d datestr] [-s datestr] [--utc] [--universal] [--date=datestr] [--set=datestr] [--help] [--version] [+FORMAT] [MMDDhhmm[[CC]YY][.ss]] 说明 : date 能用来显示或设定系统的日期和时间,在显示方面,使用者能设定欲显示的格式,格式设定为一个加号后接数个标记,其中可用的标记列表如下 : 时间方面 : % : 印出 % %n : 下一行 %t : 跳格 %H : 小时(00..23) %I : 小时(01..12) %k : 小时(0..23) %l : 小时(1..12) %M : 分钟(00..59) %p : 显示本地 AM 或 PM %r : 直接显示时间 (12 小时制,格式为 hh:mm:ss [AP]M) %s : 从 1970 年 1 月 1 日 00:00:00 UTC 到目前为止的秒数 %S : 秒(00..61) %T : 直接显示时间 (24 小时制) %X : 相当于 %H:%M:%S %Z : 显示时区 日期方面 : %a : 星期几 (Sun..Sat) %A : 星期几 (Sunday..Saturday) %b : 月份 (Jan..Dec) %B : 月份 (January..December) %c : 直接显示日期和时间 %d : 日 (01..31) %D : 直接显示日期 (mm/dd/yy) %h : 同 %b %j : 一年中的第几天 (001..366) %m : 月份 (01..12) %U : 一年中的第几周 (00..53) (以 Sunday 为一周的第一天的情形) %w : 一周中的第几天 (0..6) %W : 一年中的第几周 (00..53) (以 Monday 为一周的第一天的情形) %x : 直接显示日期 (mm/dd/yy) %y : 年份的最后两位数字 (00.99) %Y : 完整年份 (0000..9999) 若是不以加号作为开头,则表示要设定时间,而时间格式为 MMDDhhmm[[CC]YY][.ss], 其中 MM 为月份, DD 为日, hh 为小时, mm 为分钟, CC 为年份前两位数字, YY 为年份后两位数字, ss 为秒数 把计 : -d datestr : 显示 datestr 中所设定的时间 (非系统时间) --help : 显示辅助讯息 -s datestr : 将系统时间设为 datestr 中所设定的时间 -u : 显示目前的格林威治时间 --version : 显示版本编号 例子 : 显示时间后跳行,再显示目前日期 : date +%T%n%D 显示月份和日数 : date +%B %d 显示日期和设定时间(12:34:56) : date --date 12:34:56 设置系统当前时间(12:34:56):date --s 12:34:56 注意 : 当你不希望出现无意义的 0 时(比如说 1999/03/07),则能在标记中插入 - 符号,比如说 date +%-H:%-M:%-S 会把时分秒中无意义的 0 给去掉,像是原本的 08:09:04 会变为 8:9:4。另外,只有取得权限者(比如说 root)才能设定系统时间。 当你以 root 身分更改了系统时间之后,请记得以 clock -w 来将系统时间写入 CMOS 中,这样下次重新开机时系统时间才会持续抱持最新的正确值。 ntp时间同步 linux系统下默认安装了ntp服务,手动进行ntp同步如下 ntpdate ntp1.nl.net 当然,也能指定其他的ntp服务器


扩展功能 date 工具可以完成更多的工作,不仅仅只是打印出当前的系统日期。您可以使用它来得到给定的日期究竟是星期几,并得到相对于当前日期的相对日期。了解某一天是星期几 GNU 对 date 命令的另一个扩展是 -d 选项,当您的桌上没有日历表时(UNIX 用户不需要日历表),该选项非常有用。使用这个功能强大的选项,通过将日期作为引号括起来的参数提供,您可以快速地查明一个特定的日期究竟是星期几: $ date -d "nov 22" Wed Nov 22 00:00:00 EST 2006 $ 在本示例中,您可以看到今年的 11 月 22 日是星期三。 所以,假设在 11 月 22 日召开一个重大的会议,您可以立即了解到这一天是星期三,而这一天您将赶到驻地办公室。 获得相对日期 d 选项还可以告诉您,相对于 当前日期若干天的究竟是哪一天,从现在开始的若干天或若干星期以后,或者以前(过去)。通过将这个相对偏移使用引号括起来,作为 -d 选项的参数,就可以完成这项任务。 例如,您需要了解两星期以后的日期。如果您处于 Shell 提示符处,那么可以迅速地得到答案: $ date -d ’2 weeks’ 关于使用该命令,还有其他一些重要的方法。使用 next/last指令,您可以得到以后的星期几是哪一天: $ date -d ’next monday’ (下周一的日期) $ date -d next-day +%Y%m%d(明天的日期)或者:date -d tomorrow +%Y%m%d $ date -d last-day +%Y%m%d(昨天的日期) 或者:date -d yesterday +%Y%m%d $ date -d last-month +%Y%m(上个月是几月) $ date -d next-month +%Y%m(下个月是几月) 使用 ago 指令,您可以得到过去的日期: $ date -d ’30 days ago’ (30天前的日期) 您可以使用负数以得到相反的日期: $ date -d ’dec 14 -2 weeks’ (相对:dec 14这个日期的两周前的日期) $ date -d ’-100 days’ (100天以前的日期) $ date -d ’50 days’(50天后的日期) 这个技巧非常有用,它可以根据将来的日期为自己设置提醒,可能是在脚本或 Shell 启动文件中,如下所示: DAY=`date -d ’2 weeks’ +"%b %d"` if test "`echo $DAY`" = "Aug 16"; then echo ’Product launch is now two weeks away!’; fi

Linux CPU 监控脚本

下面是一个简单的CPU监控脚本,当然还可以在进行全面考虑升级该脚本。

#!/bin/sh
 
#-gt "60" 服务器只有一个CPU 
scriptdir=/root/shell/cpu_jk    #目录存放 
logdir=$scriptdir/log  #日志文件存放及目录创建/清理
 
if [ -d $logdir ] 
then 
    echo "$logdir is exist~!" 
else 
    mkdir -p $logdir 
fi
 
cpu=`mpstat 1 2 |grep "平均时间"|awk '{print $3}'|sed "s/\([0-9]*\)\..*/\1/g"`
 
if [ "$cpu" -gt 60 ] 
then 
    echo "该注意CPU使用情况了">$logdir/cpu.txt 
    cat $logdir/cpu.txt |mail -s "`date +%Y-%m-%d`日,xxIP的cpu使用率已经超过60%" 
fi
 
#sleep 5 
#rm -fr $logdir/cpu.txt

Linux CPU、内存 监控脚本

#!/bin/bash
DATE=`date +%Y/%m/%d`
TIME=`date +%H:%M:%S`
 
TIMEOUT='uptime'
VMOUT='vmstat 1 2'
 
USERS=`$TIMEOUT|gawk '{print $6}'`
LOAD=`$TIMEOUT|gawk '{print $10}'|sed 's/,//'`
FREE=`$VMOUT|sed -n '/[0-9]/p'|sed -n '2p'|gawk '{print $4} '`
FREE=`expr $FREE / 1024`
IDLE=`$VMOUT|sed -n '/[0-9]/p'|sed -n '2p'|gawk '{print $15}'`
 
echo "$DATE $TIME   users = $USERS   1m avg.load = $LOAD   free = ${FREE}MB   idle = $IDLE" 
 
#cpu
wget -q -O /dev/null "http://www.tomtalk.net:8080/receive/unit_data?code=cpu_load&value=$LOAD"
 
#memory
wget -q -O /dev/null "http://www.tomtalk.net:8080/receive/unit_data?code=mem_free&value=$FREE"

Linux 磁盘监控脚本

#!/bin/bash
 
used=`df|sed -n '/hda1/ p'|gawk '{print $3}'|sed 's/%//'`
available=`df|sed -n '/hda1/ p'|gawk '{print $4}'|sed 's/%//'`
total=`expr $used + $available`
used_percent=`awk 'BEGIN{printf "%.2f",('$used'/'$total')*100}'`
 
echo "($used / $total) * 100 = $used_percent"
wget -q -O /dev/null "http://www.tomtalk.net:8080/receive/unit_data?code=hd_used&value=$used_percent"

Linux 网卡监控脚本

#!/bin/bash
#network
while : ; do
    time=`date +%m"-"%d" "%k":"%M`
    day=`date +%m"-"%d`
    rx_before=`ifconfig enp0s8|sed -n "8"p|awk '{print $2}'|cut -c7-`
    tx_before=`ifconfig enp0s8|sed -n "8"p|awk '{print $6}'|cut -c7-`
 
    sleep 2
 
    rx_after=`ifconfig enp0s8|sed -n "8"p|awk '{print $2}'|cut -c7-`
    tx_after=`ifconfig enp0s8|sed -n "8"p|awk '{print $6}'|cut -c7-`
    rx_result=$[(rx_after-rx_before)/256]
    tx_result=$[(tx_after-tx_before)/256]
    echo "$time Now_In_Speed: "$rx_result"kbps Now_OUt_Speed: "$tx_result"kbps"
 
    sleep 2
done

列出当前目录下的所有子目录

程序

  1. !/bin/bash
  2. Name: lsdir

ls -l|tr -s ' '|grep -e '^d'|cut -d ' ' -f 8|awk '{print "["$1"]"}'

程序说明 ls -l: 列出当前目录下的所有文件和子目录的详细信息。 tr -s ' ': 把每一行中的连续的多个空格替换成一个空格。 grep -e '^d': 只显示以'd'开头的行,就是子目录对应的行。 cut -d ' ' -f 8: 以空格为分隔符,抓取第8列数据,即子目录的目录名。 awk '{print "["$1"]"}': 在目录名两边加上[]。 程序效果 [bin] [boot] [dev] [etc] [home] [lib] [media] [mnt] [opt] [proc] [root] [sbin] [srv] [subdomain] [sys] [tmp] [usr] [var]

2006.01.19更新 在实际使用中,发现有如下不方便之处: 只能显示当前目录 发现有时候,ls列出的日期格式会有不同,进而导致无法正确抓到目录名。 我喜欢列出的目录格式是多列形式的,不是一行一列的形式。 因此,对上述脚本进行了改进:

ls -l --full-time $*|tr -s ' '|grep -e '^d'|\

cut -d ' ' -f 9|\

awk '{print "["$1"]"}'|column

其中的'column'程序可以把输出格式化成多行。

改进后的程序输出效果:

> lsdir / [bin] [home] [opt] [srv] [usr] [boot] [lib] [proc] [subdomain] [var] [dev] [media] [root] [sys] [etc] [mnt] [sbin] [tmp]

如果要显示所有的子目录,包括隐含的子目录,用如下命令 > lsdir -a ~

shell判断文件大小

#!/bin/sh
filepath=tt.js
s=$(du -k $filepath|awk '{print $1}')
if [ $s -ge 102400000 ];
then  
    rm -f $filepath && touch $filepath
else
    continue
fi

echo 中的换行符怎么表示?不是\n吗?

各位前辈,bash下我想用echo 生成一个参数文件creat_par

20070107 
0 0 
32 32 
64 64 
7.0 

可当我执行

echo "20070107\n 0 0\n 32 32\n 64 64\n 7.0\n" > create_par 
 
#creat_par的内容如下: 
 
#20070107\n 0 0\n 32 32\n 64 64\n 7.0\n 
 
#正确写法
echo -ne "20070107\n 0 0\n 32 32\n 64 64\n 7.0\n" > create_par