时间:2021-05-22
一、写备份并清除老日志Shell脚本:
复制代码 代码如下:
#!/bin/sh
#backup eoslog
#author rhao
#date 2008-12-27
#定义环境变量
EOS_HOME=/home/eos
SAS_HOME=/home/eos/SAS
# 测试主辅结点
if test -d '/home/eos/SAS/SAS1_web1'
then
SAS_LOG_HOME=$SAS_HOME/SAS1_web1/SAS_Domain/bin
else
SAS_LOG_HOME=$SAS_HOME/SAS2_web1/SAS_Domain/bin
fi
# 定义并创建日志备份目录
SAS_LOG_BAK_HOME=$EOS_HOME/saslog/
mkdir -p $SAS_LOG_BAK_HOME
# 切换目录为EOS日志文件目录
cd $SAS_LOG_HOME
# 获取当前系统日期
TODAY=`date +%Y%m%d`
# 备份当前日志
cp nohup.out $SAS_LOG_BAK_HOME/$TODAY.log
# 清除当前日志
touch nohup.null
cp nohup.null nohup.out -f
rm nohup.null
# 清除七天前的日志
for rmfile in `find $SAS_LOG_BAK_HOME -ctime +7 `;
do /bin/rm -rf $rmfile;
done
二、将脚本加入操作系统的crontab 中,直接VI加入即可
复制代码 代码如下:
[eos@xcfwbz1 SAS]$ crontab -l
59 23 * * * /home/eos/SAS/backup_eoslog.sh
上面表示每天23:59分执行该脚本
清除日志(log)的shell脚本
复制代码 代码如下:
#!/bin/bash
LOG_DIR=/var/log
ROOT_UID=0
LINES=50
E_XCD=66
E_NOTROOT=67
if [ "$UID" -ne "$ROOT_UID" ]
then
echo "Must be root to run this script."
exit $E_NOTROOT
fi
if [ -n "$1" ]
then
lines=$1
else
lines=$LINES
fi
cd $LOG_DIR
if [ `pwd` != "$LOG_DIR" ]
then
echo "Can't change to $LOG_DIR."
exit $E_XCD
fi
tail -$lines messages > mesg.temp
mv mesg.temp messages
echo "Logs cleaned up."
exit 0
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
备份数据库的shell脚本一复制代码代码如下:#!/bin/bash#指定运行的脚本shell#运行脚本要给用户执行权限bakdir=/backupmonth=
备份网站内容复制代码代码如下:#!/bin/bash#指定运行的脚本shell#运行脚本要给用户执行权限bakdir=/backupmonth=`date+%m
在本文中,我将研究如何创建shell脚本来运行简单的.NETCore应用程序。之所以有这个研究议题,是因为本站(pzy.io)数据库需要每天定时备份,并在备份完
每天定时备份数据库需要用到Linux的定时任务,利用Linux的crondtab命令。下面我们来看详细步骤:一、写好shell脚本mysqlbak.sh#!/b
案例描述在定时脚本运行过程中,发现当备份表格的sql语句与删除该表部分数据的sql语句同时运行时,mysql会检测出死锁,并打印出日志。两个sql语句如下:(1