深入实践 Shell 脚本编程:高效自动化操作指南


一、什么是 Shell 脚本?

Shell 脚本是一种用 Shell 编写的脚本程序,用于执行一系列的命令。它是 Linux/Unix 系统中自动化管理任务的利器,能够显著提升工作效率,特别适合批量处理文件、监控系统状态、自动部署等任务。


二、Shell 脚本的基础语法

1. 脚本结构
  • Shebang 行:指定解释器路径。
    #!/bin/bash
    
  • 注释:以 # 开头的内容表示注释。
    # 这是一个注释
    
2. 变量
  • 定义变量
    NAME="Linux"
    
  • 使用变量
    echo "Welcome to $NAME"
    
  • 读取用户输入
    read USERNAME
    echo "Hello, $USERNAME"
    
3. 条件语句
  • if 结构
    if [ condition ]; then
        echo "Condition met"
    else
        echo "Condition not met"
    fi
    
  • 条件操作符
    • 文件判断:-e(存在)、-d(目录)、-f(文件)。
    • 数值比较:-eq(等于)、-gt(大于)、-lt(小于)。
    • 字符串比较:=(等于)、!=(不等)。
4. 循环
  • for 循环
    for i in {1..5}; do
        echo "Iteration $i"
    done
    
  • while 循环
    counter=1
    while [ $counter -le 5 ]; do
        echo "Count: $counter"
        ((counter++))
    done
    
5. 函数
  • 定义函数
    my_function() {
        echo "This is a function"
    }
    
  • 调用函数
    my_function
    

三、Shell 脚本实战案例

1. 文件批量处理

需求:批量将 .log 文件重命名为带时间戳的文件名。

代码示例

#!/bin/bash

for file in *.log; do
    timestamp=$(date +%Y%m%d_%H%M%S)
    mv "$file" "${file%.log}_$timestamp.log"
    echo "Renamed $file to ${file%.log}_$timestamp.log"
done

执行方法

  1. 保存为 rename_logs.sh
  2. 运行脚本:
    chmod +x rename_logs.sh
    ./rename_logs.sh
    

2. 系统监控脚本

需求:定时监控系统的 CPU 和内存使用情况。

代码示例

#!/bin/bash

while true; do
    echo "CPU Usage: $(top -bn1 | grep "Cpu(s)" | awk '{print $2 + $4}')%"
    echo "Memory Usage: $(free -m | awk '/Mem:/ {printf "%.2f%%\n", $3/$2 * 100}')"
    sleep 5
done

执行方法

chmod +x monitor.sh
./monitor.sh

3. 自动备份脚本

需求:自动将指定目录下的文件压缩备份到 /backup 目录,并保留最近 7 天的备份。

代码示例

#!/bin/bash

SOURCE_DIR="/path/to/source"
BACKUP_DIR="/backup"
DATE=$(date +%Y%m%d)

mkdir -p "$BACKUP_DIR"
tar -czf "$BACKUP_DIR/backup_$DATE.tar.gz" "$SOURCE_DIR"

# 删除 7 天前的备份
find "$BACKUP_DIR" -type f -mtime +7 -exec rm -f {} \;
echo "Backup completed and old backups cleaned."

执行方法

chmod +x backup.sh
./backup.sh

4. 自动检测网络状态

需求:检测一组 IP 地址是否可达,并记录到日志文件。

代码示例

#!/bin/bash

IP_LIST=("8.8.8.8" "1.1.1.1" "192.168.0.1")
LOG_FILE="network_status.log"

for ip in "${IP_LIST[@]}"; do
    if ping -c 1 $ip > /dev/null 2>&1; then
        echo "$(date): $ip is reachable" >> $LOG_FILE
    else
        echo "$(date): $ip is unreachable" >> $LOG_FILE
    fi
done

执行方法

chmod +x check_network.sh
./check_network.sh

5. 用户管理脚本

需求:批量创建用户并设置默认密码。

代码示例

#!/bin/bash

USER_LIST=("user1" "user2" "user3")
DEFAULT_PASSWORD="password123"

for user in "${USER_LIST[@]}"; do
    if id "$user" &>/dev/null; then
        echo "User $user already exists."
    else
        useradd "$user"
        echo "$DEFAULT_PASSWORD" | passwd --stdin "$user"
        echo "User $user created with default password."
    fi
done

执行方法

sudo chmod +x create_users.sh
sudo ./create_users.sh

四、Shell 脚本调试与优化

1. 调试脚本
  • 开启调试模式:添加 set -x,逐行输出执行过程。
    set -x
    
  • 检查错误:使用 $? 检查上一条命令的执行结果。
2. 提高脚本效率
  • 使用 xargs 批量处理:
    ls *.log | xargs rm
    
  • 避免使用子进程,尽量用内建命令。
3. 增强可读性
  • 增加注释,解释每段代码的功能。
  • 使用函数组织代码逻辑。

五、Shell 脚本进阶技巧

1. 使用数组
  • 定义数组:
    my_array=("value1" "value2" "value3")
    
  • 遍历数组:
    for item in "${my_array[@]}"; do
        echo $item
    done
    
2. 使用正则表达式
  • 匹配字符串:
    if [[ $string =~ ^[0-9]+$ ]]; then
        echo "This is a number."
    fi
    
3. 捕获信号
  • 捕获 Ctrl+C 信号并执行清理操作:
    trap "echo 'Interrupt signal received'; exit" SIGINT
    

六、Shell 脚本学习资源

1. 推荐书籍
  • 《Shell 编程技术》
  • 《Linux Shell 脚本攻略》
2. 在线资源
  • Linux Command
  • B 站 Shell 脚本入门教程。
3. 实践平台
  • 使用本地虚拟机(如 VirtualBox)或云服务器(如 AWS、Google Cloud)。

七、总结

Shell 脚本是 Linux 系统管理的重要工具,其简单、高效、灵活的特性使其在自动化操作中不可或缺。通过掌握基础语法和实战案例,你可以在工作中实现各种自动化任务,提升工作效率。

下一步实践

  1. 将上述案例改进为适应你的实际需求。
  2. 学习结合 awksed 编写更复杂的脚本。
  3. 使用定时任务(crontab)将脚本应用到生产环境。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/920453.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【腾讯云产品最佳实践】腾讯云CVM入门技术与实践:通过腾讯云快速构建云上应用

目录 前言 什么是腾讯云CVM? 腾讯云CVM的技术优势 基于最佳技术实践,使用腾讯云CVM搭建应用 1. 开通CVM实例 2. 连接CVM实例 3. 配置Web环境 4. 部署PHP应用 腾讯云CVM行业应用案例:电商平台的双十一攻略 1. 弹性伸缩解决高并发问题…

mongodb多表查询,五个表查询

需求是这样的,而数据是从mysql导入进来的,由于mysql不支持数组类型的数据,所以有很多关联表。药剂里找药物,需要药剂与药物的关联表,然后再找药物表。从药物表里再找药物与成分关联表,最后再找成分表。 这里…

STL中vector实现——简单易懂版

本章内容 模拟实现 vector 的部分重要功能 1.迭代器的引入1.1 之前写法1.2 STL库中的写法 2.默认成员函数2.1构造与拷贝构造2.2拷贝赋值2.3析构函数 3.增删查改功能3.1插入3.2删除 4.为什么STL中vector没有find函数?5.🔥🔥迭代器失效场景&am…

Springboot + vue 健身房管理系统项目部署

1、前言 ​ 许多人在拿到 Spring Boot 项目的源码后,不知道如何运行。我以 Spring Boot Vue 健身房管理系统的部署为例,详细介绍一下部署流程。大多数 Spring Boot 项目都可以通过这种方式部署,希望能帮助到大家。 ​ 2、项目查看 ​ 首…

NuGet如何支持HTTP源

今天是2024年11月21号,最近更新了VisualStudio后发现HTTP的包源已经默认禁止使用了,生成时会直接报错。如下图: 官方也明确指出了要想使用HTTP包源的解决办法,这里就简单总结一下。 一、全局配置 1、全局NuGet包的配置文件路径在…

SpringBoot学习记录(四)之分页查询

SpringBoot学习记录(四)之分页查询 一、业务需求1、基本信息2、请求参数3、相应数据 二、传统方式分页三、使用PageHelper分页插件 一、业务需求 根据条件进行员工数据的条件分页查询 1、基本信息 请求路径: /emps 请求方式: …

JavaParser如何获取方法的返回类型

使用JavaParser 如何获取一个Java类中的某个方法的返回类型呢? 假如有一个如下的简单的Java 类: /*** Copyright (C) Oscar Chen(XM):* * Date: 2024-11-21* Author: XM*/ package com.osxm.ai.sdlc.codeparse.codesample;public class MyClass {public…

2024亚太杯国际赛C题宠物预测1234问完整解题思路代码+成品参考文章

中国宠物业发展趋势及预测模型 一、问题背景与研究目标 近年来,中国宠物业经历了快速发展,特别是在城市化进程加快、人口结构变化和消费水平提升的背景下,宠物作为家庭成员的角色变得愈发重要。根据相关数据,中国宠物数量&#…

Java实现离线身份证号码OCR识别

最近公司要求做离线身份证OCR功能,找了一圈总算是找到了,在这里对文档做个整理,方便后来者,感谢码龄23年博主的分享 系统:Windows11,红旗Linux Asianux8.1 文档中Linux全root用户操作;需先安装…

Gradle核心概念总结

这部分内容主要根据 Gradle 官方文档整理,做了对应的删减,主要保留比较重要的部分,不涉及实战,主要是一些重要概念的介绍。 Gradle 这部分内容属于可选内容,可以根据自身需求决定是否学习,目前国内还是使用…

鸿蒙网络编程系列50-仓颉版TCP回声服务器示例

1. TCP服务端简介 TCP服务端是基于TCP协议构建的一种网络服务模式,它为HTTP(超文本传输协议)、SMTP(简单邮件传输协议)等高层协议的应用程序提供了可靠的底层支持。在TCP服务端中,服务器启动后会监听一个或…

第5-1节:SpringBoot对SpringMVC的自动配置

我的后端学习大纲 SpringBoot学习大纲 1、SpringBoot对SpringMVC自动配置概览

Emacs进阶之插入时间信息(一百六十三)

简介: CSDN博客专家、《Android系统多媒体进阶实战》一书作者 新书发布:《Android系统多媒体进阶实战》🚀 优质专栏: Audio工程师进阶系列【原创干货持续更新中……】🚀 优质专栏: 多媒体系统工程师系列【…

嵌入式实验报告:家用计时器

实验目的和要求 1、实验目的 掌握STM32串口通信原理。学习编程实现STM32的UART通信掌握STM32中断程序设计流程。熟悉STM32固件库的基本使用。熟悉STM32定时器中断设计流程。2、实验要求 设计一个家用计时器,其功能如下: 利用串口设置计时时间,格式:XX:XX:X 例如01:59:…

【WRF理论第十二期】Registry.EM 文件详解

【WRF理论第十二期】Registry.EM 文件详解 Registry.EM 文件的作用Registry.EM 文件的结构Registry.EM 文件内容理解如何修改 Registry.EM 文件以输出特定变量WRF-Urban 修改 Registry.EM 文件以输出 UCM 相关变量1. 修改 Registry.EM 文件2. 重新编译 WRF 注意事项参考 在 WRF…

Midjourney 图生图,真人二次元保持一致性,场景多元可选择

Midjourney 拥有强大的图生图的功能,下面我们就来看一下,如何在我们的AceDataCloud网站上实现将照片切换成任意的二次元场景,同时保持人物的一致性。 我们可以按照如下的步骤去实现人物一致性。 下面我们来看看效果吧,原图如下。…

三种复制只有阅读权限的飞书网络文档的方法

大家都知道,飞书是一款功能强大的在线协作工具,可以帮助团队更高效地协作和沟通。越来越多的资料都在使用飞书文档,在使用飞书的过程中,发现很多文档没有复制权限,如果想要摘抄笔记,只能一个字一个字地敲出…

【GL003】TCP/IP 协议

目录 一、TCP/IP协议简介 二、TCP/IP协议的分层模型 2.1 OSI模型的七层框架 2.2 TCP/IP协议层(四层) 2.2.1 TCP/IP协议层与ISO模型 2.2.2 TCP/IP协议层的作用 三、TCP协议的报文格式 3.1 什么是报文 3.2 TCP报文 四、TCP的通信连接 4.1 TCP…

Spring WebFlux学习笔记(二)

目标 运行第一个spring webflux项目 官网操作 https://start.spring.io/ 依赖、工具 jdk 21、idea、maven 运行过程 将下载的代码直接导入到idea后运行 运行上个笔记的例子 注意 需要更改为MediaType.TEXT_EVENT_STREAM_VALUE 未完待续。。。

【YOLOv8】安卓端部署-2-项目实战

文章目录 1 准备Android项目文件1.1 解压文件1.2 放置ncnn模型文件1.3 放置ncnn和opencv的android文件1.4 修改CMakeLists.txt文件 2 手机连接电脑并编译软件2.1 编译软件2.2 更新配置及布局2.3 编译2.4 连接手机 3 自己数据集训练模型的部署4 参考 1 准备Android项目文件 1.1…