shell日志颜色处理及清理系统日志的方法
程序员文章站
2023-11-02 13:58:28
记录一下shell日志颜色处理
_colors=${bs_colors:-$(tput colors 2>/dev/null || echo 0)}
__...
记录一下shell日志颜色处理
_colors=${bs_colors:-$(tput colors 2>/dev/null || echo 0)} __detect_color_support() { # shellcheck disable=sc2181 if [ $? -eq 0 ] && [ "$_colors" -gt 2 ]; then rc='\033[1;31m' gc='\033[1;32m' bc='\033[1;34m' yc='\033[1;33m' ec='\033[0m' else rc="" gc="" bc="" yc="" ec="" fi } __detect_color_support echoerror() { printf "${rc} * error${ec}: %s\\n" "$@" 1>&2; } echoinfo() { printf "${gc} * info${ec}: %s\\n" "$@"; } echowarn() { printf "${yc} * warn${ec}: %s\\n" "$@"; }
下面看下shell清理系统日志
1.设置日志峰值,到达则删除
2.定时检测,crontab添加定时任务
3.后台挂载 : ./xx.sh &
工作脚本:
#! /bin/sh #日志目录及限定大小 workdir="/var/*.log" maxsize=100 #搜索最老文件,不加目录默认的本目录里边的文件 r倒序输出 t时间 head -n1取第一行 awk命令括号$1位文件名 管道连接 oldfile(){ oldfile=`ls $workdir -t 2>/dev/null| head -n1 | awk '{printf $1}'` } clear_old_log(){ if [ ! $oldfile ] then #echo "日志不存在" 1>/dev/null return 0 fi while true; do oldfile if [ ! $oldfile ] then return 0 fi logsize=`du -ms $oldfile 2>/dev/null| awk '{printf $1}'` #m表示兆 k b if [ $logsize -gt $maxsize ] then str1="log" str2="err" if [[ $oldfile == *$str1* ]] then pkill snake rm -rf $oldfile fi if [[ $oldfile == *$str2* ]] then service mysql restart pkill snake rm -rf $oldfile fi else break fi done } testing(){ while true; do workdir="/var/*.log" oldfile clear_old_log workdir="/var/lib/mysql/*.err" oldfile clear_old_log done } testing 定时任务脚本: #! /bin/sh #a=`pgrep -f test1.sh|wc -l` #if [ $(ps -ef|grep test.sh|wc -l) -gt 1 ] if test $(pgrep -f test.sh|wc -l) -ge 1 then exit fi cd /home/zxd/ ./test.sh 下边这个带有日志时间加时间戳及系统负载检测: #! /bin/bash stra="long string" strb="string" result=$(echo $stra | grep "${strb}") if [[ "$result" != "" ]] then echo "包含" else echo "不包含" fi #日志目录及限定大小 workdir="/var/*.log" maxsize=100 #给文件加时间戳:函数里的变量必须在脚本函数后边跟着,这里$1不是命令行跟的参数,命令行的参数为脚本的$1 filetime(){ a=$(date +%y%m%d%h%m%s) a=$1.$(date +%y%m%d%h%m%s) echo $a } filetime "/var/log" #搜索最老文件,不加目录默认的本目录里边的文件 r倒序输出 t时间 head -n1取第一行 awk命令括号$1位文件名 管道连接 oldfile(){ oldfile=`ls $workdir -rt 2>/dev/null| head -n1 | awk '{printf $1}'` } clear_old_log(){ if [ ! $oldfile ] then echo "日志不存在" 1>/dev/null return 0 fi while true; do oldfile if [ ! $oldfile ] then echo "日志不存在" 1>/dev/null return 0 fi logsize=`du -bs $oldfile 2>/dev/null| awk '{printf $1}'` if [ $logsize -gt $maxsize ] then str1="log" str2="err" if [[ $oldfile == *$str1* ]] then pkill snake rm -rf $oldfile fi if [[ $oldfile == *$str2* ]] then service mysql restart pkill snake rm -rf $oldfile fi else break fi done } testing(){ echo "run" while true; do oldfile clear_old_log echo "222" workdir="/var/lib/mysql/libmaster.err" oldfile clear_old_log done } disk=`df |grep /dev/mapper/fedora-root | awk '{printf $5}' | sed 's/%//g'` echo "磁盘已用:%$disk" memtotal=`cat /proc/meminfo |grep memtotal |awk '{printf $2}'` memfree=`cat /proc/meminfo |grep memfree |awk '{printf $2}'` used=$((100- memfree*100/memtotal)) echo "内存已用:%$used" echo "exit" testing
总结
以上所述是小编给大家介绍的shell日志颜色处理方法,希望对大家有所帮助