每天解析一个脚本(11)

简介: 【4月更文挑战第18天】shell脚本解析及训练(11)

在信息化浪潮席卷全球的当下,数字化转型已成为各行各业的核心驱动力,而作为这一进程守护者的运维工作,其重要性与日俱增。面对瞬息万变的IT环境,复杂多元的系统架构,以及日益严苛的服务质量要求,高效的自动化工具与脚本已成为运维人员提升工作效率、确保系统稳定性不可或缺的“秘密武器”。有鉴于此,我倾力编撰了这份精心筛选与整理的Shell脚本合集,旨在为广大的运维同行献上一份诚意满满的“运维人福利”,助您在应对日常运维挑战时如虎添翼,从容不迫。

这份脚本合集,犹如一座蕴藏着丰富矿藏的知识宝库,凝结了我在实战运维工作中积累的点滴智慧与宝贵经验。它深度聚焦服务器监控、故障排查、数据备份与恢复、性能调优、自动化部署等运维核心领域,旨在为每一位身处其中的专业人士提供全方位的支持。无论是初涉运维领域的新人,渴望快速掌握实战技巧,还是久经沙场的资深专家,寻求优化现有流程、提升运维效能的新思路,都能在这份合集中找寻到契合自身需求的解决方案。

每一款脚本均经过真实业务场景的反复打磨与严格测试,秉持着简洁高效、易于理解和使用的理念设计。它们不仅具备高度的灵活性与适应性,能够轻松应对各种复杂运维环境下的多样化需求,而且注释详尽,逻辑清晰,旨在成为您日常工作中随时查阅、快速上手的实用指南。无论是自动化执行例行任务,迅速响应突发事件,还是深入挖掘系统瓶颈,优化资源分配,这些脚本都将化身为您的得力助手,使繁复的运维工作变得有条不紊,事半功倍。

我热忱欢迎所有运维同仁自由取阅、广泛分享这份宝贵的Shell脚本资源,将其融入个人的工作实践中,或是作为团队协作、技能培训的参考资料。它们不仅是提升个人技能、优化工作流程的有效工具,更是增进同行间技术交流、知识共享的优质载体。让我们携手共进,充分运用这份脚本合集所蕴含的技术力量,积极推动运维工作的智能化、自动化进程,共同为构建稳定、高效、可靠的信息化系统保驾护航,为企业的数字化转型之路奠定坚实基础。在这个瞬息万变的数字化时代,让我们以匠心独运的运维智慧,驾驭科技之舟,破浪前行,共创辉煌!

今天我们要分析的是:

Nginx 日志按要求切割

#!/bin/bash

#安装目录下日志文件

base_log_path='/usr/local/openresty/nginx/logs/access.log'

base_error_path='/usr/local/openresty/nginx/logs/error.log'

#需要保存的目录位置

log_path='/data_lytdev_dir/nginx/logs/'

35.生成10个随机数保存于数组中并找出其最大值和最小值

#获取月份

log_month=$(date -d yesterday +"%Y%m")

#获取前一天日期 (第二天凌晨备份,即保存的日志就是当天时间的日志)

log_day=$(date -d yesterday +"%d")

#在指定位置创建文件夹

mkdir -p $log_path/$log_month

#将安装目录下的日志文件,移动到指定存储位置

mv $base_log_path $log_path/$log_month/access_$log_day.log

mv $base_error_path $log_path/$log_month/error_$log_day.log

#再使用信号控制切割日志

#USR1 表示nginx信号控制,切割日志

kill -USR1 `cat /usr/local/openresty/nginx/logs/nginx.pid`

#每天凌晨1点切割日志

* 1 * * * /usr/local/openresty/nginx/logs/log_rotate.sh

脚本实现过程:

  1. 定义日志文件路径:
  • base_log_path: 定义Nginx访问日志(access.log)的原始路径。
  • base_error_path: 定义Nginx错误日志(error.log)的原始路径。
  • log_path: 定义日志备份存放的目录。
  1. 生成随机数及确定备份时间:
  • 注: 脚本中关于“生成10个随机数并找出最大值和最小值”的部分存在错误,未实际执行相关操作,且与日志切割无关,此处略过不提。
  • 获取当前日期时间:
  • log_month: 使用date -d "system" +"%Y%m"获取当前月份(格式:年份-月份)。
  • log_day: 使用date -d "system" +"%d"获取前一天的日期(格式:日)。
  1. 创建备份目录:
  • 使用mkdir -p命令在指定的log_path下创建以当前月份命名的子目录,用于存放备份的日志文件。
  1. 移动日志文件:
  • 将原access.log文件从base_log_path移动到$log_path/$log_month目录,并重命名为access_$log_day.log
  • 同理,将原error.log文件从base_error_path移动到$log_path/$log_month目录,并重命名为error_$log_day.log
  1. 触发Nginx日志切割:
  • 使用kill -USR1命令向Nginx主进程发送USR1信号。Nginx接收到此信号后,会自动执行日志切割操作,即创建新的日志文件(access.log和error.log),并将旧日志文件改名为以日期标记的备份文件。
  • 通过cat /usr/local/openresty/nginx/logs/nginx.pid获取Nginx主进程ID,作为kill命令的参数。

如何使用:

  1. 确认脚本配置:
  • 确认base_log_pathbase_error_pathlog_path变量设置正确,指向您实际的Nginx日志文件位置和期望的备份目录。
  1. 执行日志备份与切割:
  • 直接运行此脚本,它会执行日志移动和切割操作。
  1. 自动化日志管理:
  • 若要让脚本在每天凌晨1点自动执行,可将其添加到系统定时任务中,例如使用crontab
  • 打开定时任务编辑器:crontab -e
  • 添加一行,指定每天凌晨1点执行日志切割脚本:
  • Code
10 1 * * * /path/to/log_rotate.sh
  • 保存并退出编辑器,定时任务即设置完成。

实现Nginx日志的自动备份和切割。备份的日志文件会被移动到指定目录,并按日期进行命名。同时,Nginx会接收到USR1信号,触发自身的日志切割机制,创建新的日志文件以便继续记录后续的访问和错误信息。整个过程在每天凌晨1点自动执行,确保日志管理的持续性和系统资源的有效利用。

如果想上手操作练代码的同学们可以通过阿里云ecs服务器免费试用参与!

入口:新老同学免费试用

目录
相关文章
|
5天前
|
弹性计算 运维 监控
每天解析一个脚本(53)
【4月更文挑战第26天】shell脚本解析及训练(53)
20 5
|
6天前
|
弹性计算 运维 Shell
每天解析一个脚本(38)
【4月更文挑战第25天】shell脚本解析及训练(38)
10 1
|
9天前
|
存储 弹性计算 运维
每天解析一个脚本(17)
【4月更文挑战第21天】shell脚本解析及训练(17)
16 1
|
9天前
|
存储 弹性计算 运维
每天解析一个脚本(25)
【4月更文挑战第22天】shell脚本解析及训练(25)
28 0
|
5天前
|
弹性计算 运维 监控
每天解析一个脚本(51)
【4月更文挑战第26天】shell脚本解析及训练(51)
15 4
|
6天前
|
弹性计算 运维 监控
每天解析一个脚本(43)
【4月更文挑战第25天】shell脚本解析及训练(43)
9 0
|
6天前
|
运维 监控 Shell
每天解析一个脚本(44)
【4月更文挑战第25天】shell脚本解析及训练(44)
8 0
|
7天前
|
运维 Shell 网络安全
每天解析一个脚本(33)
【4月更文挑战第24天】shell脚本解析及训练(33)
14 1
|
7天前
|
运维 监控 Shell
每天解析一个脚本(36)
【4月更文挑战第24天】shell脚本解析及训练(36)
11 0
|
8天前
|
存储 弹性计算 运维
每天解析一个脚本(31)
【4月更文挑战第23天】shell脚本解析及训练(31)
18 3