Linux脚本实现自动化运维:系统自动备份、资源监控

1、系统自动备份

目的:将重要应用备份到别的机器上

脚本实例:

bash 复制代码
#!/bin/bash
# 定义变量
app_user=待备份应用的服务器用户名
app_passwd=待备份应用的服务器密码
app_ip=待备份应用的服务器IP
BASE_PATH='/data/inspur_bak'
TODAY_DATE=`date +\%Y\%m\%d`
CURRENT_PATH=${BASE_PATH}/${TODAY_DATE}
test -d ${CURRENT_PATH} || mkdir -p ${CURRENT_PATH}


#定义日志路径
log_path=${BASE_PATH}/log
log=${log_path}/bak_${TODAY_DATE}.log
if [ ! -d ${log_path} ]; then
  mkdir -p ${log_path}
  chmod -R 755 ${log_path}
  touch ${log}
  chmod 755 ${log}
  if [ $? -ne 0 ]; then
    echo "log create fail!"
    echo "log is not exit!!please check..."
    exit -1
  fi
fi

#日志函数
function Log()
{
  createTime=`date  +"%Y-%m-%d %H:%M:%S"`
  #log_file有可能不存在,先打印,不报错
  echo -e "[${createTime}] $*" |tee -a ${log} 2>/dev/null
}
Log ""
Log "-------------------------开始备份应用目录--------------------------------------"
Log ""

lftp -u ${app_user},${app_passwd} ftp://${app_ip}<<EOF
mirror /app/nwom/Inspur  ${CURRENT_PATH}/Inspur
mirror /app/nwom/tools-zookeeper-2181  ${CURRENT_PATH}/tools-zookeeper-2181
bye
EOF

if [ $? -ne 0 ]; then
  ERRCODE=-1
  ERR_LOG="10.238.83.47 应用备份失败"
  Log "${ERR_LOG}"
  continue
fi

Log ""
Log "-------------------------应用备份完成------------------------------------------"
Log ""

使用方法

将上述内容保存为 backup.sh

给脚本执行权限:

bash 复制代码
chmod +x backup.sh

运行脚本:

bash 复制代码
./backup.sh

添加定时任务

bash 复制代码
#每天凌晨2点执行备份脚本
0 2 * * * /path/to/backup.sh

2、系统资源监控

这个脚本将监控系统的CPU、内存和磁盘使用情况,并将结果写入日志文件。当资源使用过高时,通过邮件或消息通知管理员。

monitor_resources.sh:

bash 复制代码
#!/bin/bash

# 定义变量
LOG_FILE="/path/to/monitor.log"
CPU_THRESHOLD=80
MEM_THRESHOLD=80
DISK_THRESHOLD=80

# 获取资源使用情况
CPU_USAGE=$(top -bn1 | grep "Cpu(s)" | sed "s/.*, *\([0-9.]*\)%* id.*/\1/" | awk '{print 100 - $1}')
MEM_USAGE=$(free | grep Mem | awk '{print $3/$2 * 100.0}')
DISK_USAGE=$(df -h | grep '/dev/sda1' | awk '{print $5}' | sed 's/%//g')

# 记录日志
echo "$(date) - CPU: $CPU_USAGE%, MEM: $MEM_USAGE%, DISK: $DISK_USAGE%" >> $LOG_FILE

# 检查阈值并报警
if (( $(echo "$CPU_USAGE > $CPU_THRESHOLD" |bc -l) )); then
  echo "CPU usage is above threshold: $CPU_USAGE%" | mail -s "CPU Alert" admin@example.com
fi

if (( $(echo "$MEM_USAGE > $MEM_THRESHOLD" |bc -l) )); then
  echo "Memory usage is above threshold: $MEM_USAGE%" | mail -s "Memory Alert" admin@example.com
fi

if (( $(echo "$DISK_USAGE > $DISK_THRESHOLD" |bc -l) )); then
  echo "Disk usage is above threshold: $DISK_USAGE%" | mail -s "Disk Alert" admin@example.com
fi

使用方法:

将上述内容保存为 monitor_resources.sh

给脚本执行权限:

bash 复制代码
chmod +x monitor_resources.sh

运行脚本:

bash 复制代码
./monitor_resources.sh

添加定时执行任务

bash 复制代码
# 每小时执行资源监控脚本
0 * * * * /path/to/monitor_resources.sh
相关推荐
人生匆匆9 分钟前
通过nginx解决跨域问题
运维·nginx
Joseph Cooper20 分钟前
Linux HID 子系统实战:从虚拟键盘到 input 事件上报
linux·c语言·计算机外设
原来是猿20 分钟前
【Socket编程预备知识】
linux·运维·服务器·网络
河北小博博31 分钟前
自动化发布测试文章
自动化
吴爃40 分钟前
Spring Boot 项目在 K8S 中的打包、部署与运维发布实践
运维·spring boot·kubernetes
Elastic 中国社区官方博客1 小时前
在 Elastic 中使用 MCP 自动化用户旅程以进行合成监控
大数据·运维·人工智能·elasticsearch·搜索引擎·自动化·可用性测试
长安链开源社区1 小时前
学者观察 | 基于区块链的隐私计算技术——北京理工大学教授祝烈煌
运维·区块链
learning-striving1 小时前
Ubuntu26.04下载安装教程
运维·服务器·vmware·虚拟机
码上行动 661 小时前
用U盘制作系统盘以及如何装系统
运维
invicinble1 小时前
关于搭建运维监控系统(Prometheus+Grafana)
运维·grafana·prometheus