shell-文件目录监控自动分发脚本

前提条件如下:
安装了expect工具,配置脚本中的环境参数

logger.sh脚本内容如下:

#!/bin/bash

BEBUG_LOG="./debug-$(date +'%Y-%m-%d').log"
INFO_LOG="./info-$(date +'%Y-%m-%d').log"
WARN_LOG="./warn-$(date +'%Y-%m-%d').log"
ERROR_LOG="./error-$(date +'%Y-%m-%d').log"
CRITICAL_LOG="./critical-$(date +'%Y-%m-%d').log"

###########################
# level: 
# header: format
# path : 
##########################
debug() {
    local timestamp=$(date +"%Y-%m-%d %H:%M:%S")
    echo "[DEBUG]-[$timestamp] $*" | tee -a "$DEBUG_LOG"
}

#########################
# level: 
# header: format
# path : 
##########################
info() {
    local timestamp=$(date +"%Y-%m-%d %H:%M:%S")
    echo "[INFO]-[$timestamp] $*" | tee -a "$INFO_LOG"
}

##########################
# level: 
# header: format
# path : 
##########################
warn() {
    local timestamp=$(date +"%Y-%m-%d %H:%M:%S")
    echo "[WARN]-[$timestamp] $*" | tee -a "$WARN_LOG"
}
##########################
# level: 
# header: format
# path : 
##########################
error() {
    local timestamp=$(date +"%Y-%m-%d %H:%M:%S")
    echo "[ERROR]-[$timestamp] $*" | tee -a "$ERROR_LOG"
}
##########################
# level: 
# header: format
# path : 
##########################
critical() {
    local timestamp=$(date +"%Y-%m-%d %H:%M:%S")
    echo "[CRITICAL]-[$timestamp] $*" | tee -a "$CRITICAL_LOG"
}

smdir.sh脚本内容如下:

#!/bin/bash
source ./logger.sh
#######
# 指定文件目录监控分发
# 1、分发目录配置、目的端信息配置
# 2、扫描指定目录是否触发推送
# 3、推送到指定地址 user@host:path
######
SRCDIR="./"
LASTMODIFY=$(date +"%s")
HOSTCONFS=("root@localhost:/tmp/")
PASSWORD="123456"

#触发
trigger(){
    for host in ${HOSTCONFS[@]}
    do
        expect <<- CMD
            set timeout 5
            spawn scp -r $SRCDIR $host
            expect "Password:"
            send "$PASSWORD\r"
            send "\r"
            expect eof
        CMD
    done
}

# 扫描
scan(){
    MODIFYTIME=$(stat -c %Y $SRCDIR)
    info "lastmodify:$LASTMODIFY" "modifytime:$MODIFYTIME"
    if [ $MODIFYTIME != $LASTMODIFY ]
    then
        LASTMODIFY=$MODIFYTIME
        trigger
        info "指定文件目录有更新触发推送"
    fi
}

while true
do
    scan
    sleep 1
done

执行参考:
调测:sh smdir.sh
部署:nohup sh smdir.sh >/dev/null 2>&1 &
当前只是做了一个简单的实现,后期还需要对日志进行归档删除

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值