Shell脚本编程入门:轻松掌握自动化利器
liuian 2025-07-09 14:14 1 浏览
Shell脚本编程入门:轻松掌握自动化利器
一、初识Shell脚本:你的自动化小助手
Shell脚本就像一位不知疲倦的助手,能够帮你自动完成那些重复性的系统操作。想象一下,每天上班第一件事要检查服务器状态、备份重要文件、清理临时文件...这些繁琐工作,一个简单的脚本就能轻松搞定!
bash
#!/bin/bash
# 这是一个简单的欢迎脚本
echo "早上好,$(whoami)!"
echo "现在是:$(date)"
echo "系统已经运行了:$(uptime -p)"
二、脚本基础:从Hello World开始
1. 创建你的第一个脚本
bash
#!/bin/bash
# 我的第一个Shell脚本
echo "Hello World!"
保存为hello.sh后,需要添加执行权限:
bash
chmod +x hello.sh
2. 运行脚本的两种方式
方式 | 命令 | 说明 |
直接执行 | ./hello.sh | 需要可执行权限 |
解释器调用 | bash hello.sh | 不需要可执行权限 |
三、参数处理:让你的脚本更灵活
1. 位置参数
bash
#!/bin/bash
echo "脚本名称:$0"
echo "第一个参数:$1"
echo "第二个参数:$2"
echo "参数总数:$#"
echo "所有参数:$@"
2. 选项参数处理(getopts)
bash
#!/bin/bash
while getopts "a:b:c" opt; do
case $opt in
a) arg_a="$OPTARG";;
b) arg_b="$OPTARG";;
c) flag_c=true;;
?) echo "无效参数"; exit 1;;
esac
done
echo "参数a: ${arg_a:-未设置}"
echo "参数b: ${arg_b:-未设置}"
echo "标志c: ${flag_c:-未设置}"
四、变量与数据类型:脚本的"记忆单元"
变量类型对比
变量类型 | 定义方式 | 作用域 | 示例 |
局部变量 | var=value | 当前Shell | name="Alice" |
环境变量 | export var=value | 子进程可见 | export PATH=$PATH:/new/path |
特殊变量 | 预定义 | 全局 | $0, $1, $#, $? |
字符串操作示例
bash
#!/bin/bash
str="Hello World"
echo "长度: ${#str}" # 11
echo "子串: ${str:6:5}" # World
echo "替换: ${str/Hello/Hi}" # Hi World
五、流程控制:脚本的决策大脑
条件判断:if vs case
特性 | if语句 | case语句 |
适用场景 | 复杂条件判断 | 多分支简单匹配 |
语法复杂度 | 较高 | 较低 |
可读性 | 条件复杂时较差 | 多分支时较好 |
示例 | if [ $a -gt $b ]; then ... | case $var in pattern) ... ;; |
循环结构对比
循环类型 | 适用场景 | 示例 |
for循环 | 已知迭代次数 | for i in {1..5}; do ... |
while循环 | 条件满足时执行 | while [ $i -lt 10 ]; do ... |
until循环 | 条件不满足时执行 | until [ $i -eq 10 ]; do ... |
六、函数编程:模块化你的脚本
bash
#!/bin/bash
# 定义函数
greet() {
local name=$1
local hour=$(date +%H)
if [ $hour -lt 12 ]; then
echo "早上好,$name!"
elif [ $hour -lt 18 ]; then
echo "下午好,$name!"
else
echo "晚上好,$name!"
fi
return 0
}
# 调用函数
greet "Alice"
七、实用技巧:提升你的脚本水平
1.调试技巧:
bash
# 打印执行的每一行 bash -x script.sh # 脚本内部设置调试 set -x # 开启调试 set +x # 关闭调试
2.安全建议:
总是检查参数是否存在
对用户输入进行验证
使用set -euo pipefail使脚本更健壮
3.性能优化:
减少子进程创建(使用内置命令)
避免不必要的循环
使用awk或sed处理大文件
八、实战案例:自动备份脚本
bash
#!/bin/bash
# 自动备份脚本
set -euo pipefail
# 参数设置
BACKUP_DIR=${1:-/var/backups}
MAX_BACKUPS=${2:-5}
LOG_FILE="/var/log/backup_$(date +%Y%m%d).log"
# 检查目录存在
[ -d "$BACKUP_DIR" ] || mkdir -p "$BACKUP_DIR"
# 执行备份
backup() {
local timestamp=$(date +%Y%m%d_%H%M%S)
local backup_file="$BACKUP_DIR/backup_$timestamp.tar.gz"
echo "$(date) - 开始备份..." | tee -a "$LOG_FILE"
tar -czf "$backup_file" /path/to/important/data 2>> "$LOG_FILE"
echo "$(date) - 备份完成: $backup_file" | tee -a "$LOG_FILE"
# 清理旧备份
local backups=("$BACKUP_DIR"/backup_*.tar.gz)
if [ ${#backups[@]} -gt $MAX_BACKUPS ]; then
echo "保留最新 $MAX_BACKUPS 个备份,清理旧备份..." | tee -a "$LOG_FILE"
ls -t "$BACKUP_DIR"/backup_*.tar.gz | tail -n +$(($MAX_BACKUPS + 1)) | xargs rm -f
fi
}
# 主程序
backup
exit 0
九、Shell脚本 vs 其他编程语言
特性 | Shell脚本 | Python | Perl |
学习曲线 | 平缓 | 中等 | 陡峭 |
系统操作 | 优秀 | 良好 | 优秀 |
文本处理 | 优秀 | 良好 | 优秀 |
复杂逻辑 | 一般 | 优秀 | 良好 |
性能 | 中等 | 良好 | 良好 |
可移植性 | 依赖Shell | 优秀 | 良好 |
适用场景 | 系统管理自动化 | 通用编程 | 文本处理 |
十、学习资源推荐
1.书籍:
《Linux命令行与Shell脚本编程大全》
《Shell脚本学习指南》
2.在线资源:
GNU Bash手册
ShellCheck在线检查工具
3.进阶方向:
正则表达式
sed和awk高级用法
系统性能监控脚本
记住,Shell脚本编程的精髓在于"小而美"。从简单的自动化任务开始,逐步构建你的脚本工具箱,很快你就会发现工作效率得到了质的提升!
相关推荐
- 使用Assembly打包和部署Spring Boot工程
-
SpringBoot项目的2种部署方式目前来说,SpringBoot项目有如下2种常见的部署方式一种是使用docker容器去部署。将SpringBoot的应用构建成一个docke...
- java高级用法之:调用本地方法的利器JNA
-
简介JAVA是可以调用本地方法的,官方提供的调用方式叫做JNI,全称叫做javanativeinterface。要想使用JNI,我们需要在JAVA代码中定义native方法,然后通过javah命令...
- Linux中如何通过Shell脚本来控制Spring Boot的Jar包启停服务?
-
SpringBoot项目在为开发者带来方便的同时,也带来了一个新的问题就是Jar包如何启动?在一般情况下我们都是采用了最为经典的java-jar命令来进行启动。然后通过ps命令找到对应的应用线程通...
- 牛逼!自己手写一个热加载(人民币手写符号一个横还是两个横)
-
热加载:在不停止程序运行的情况下,对类(对象)的动态替换JavaClassLoader简述Java中的类从被加载到内存中到卸载出内存为止,一共经历了七个阶段:加载、验证、准备、解析、初始化、使用、...
- java 错误: 找不到或无法加载主类?看看怎么解决吧!
-
问题扫述:项目名称调整,由原来的com.mp.qms.report.biz调整为com.mp.busicen.mec.qms.report.biz后。项目在IDEA直接运行,但打包部署到服务器...
- 如何将 Spring Boot 工程打包成独立的可执行 JAR 包
-
导语:通过将SpringBoot项目打包成独立的可执行JAR包,可以方便地在任何支持Java环境的机器上运行项目。本文将详细介绍如何通过Maven构建插件将SpringBoot...
- class 增量发包改造为 jar 包方式发布
-
大纲class增量发包介绍项目目录结构介绍jar包方式发布落地方案class增量发包介绍当前项目的迭代修复都是通过class增量包来发版本的将改动的代码class增量打包,如下图cla...
- Jar启动和IDE里启动Sprintboot的区别
-
想聊明白这个问题,需要补充一些前提条件,比如Fatjar、类加载机制等1、Fatjar我们在开发业务程序的时候,经常需要引用第三方的jar包,最终程序开发完成之后,通过打包程序,会把自己的代码和三...
- Java 20年,以后将往哪儿走?(java还能流行多久)
-
在今年的Java20周年的庆祝大会中,JavaOne2015的中心议题是“Java的20年”。甲骨文公司Java平台软件开发部的副总裁GeorgesSaab的主题演讲就将关注点放在了java...
- Spring Boot Jar 包秒变 Docker 镜像实现多环境部署
-
你是否在互联网大厂后端开发工作中,遇到过这样的困扰?当完成一个SpringBoot项目开发,准备将Jar包部署到不同环境时,却发现各个环境依赖不同、配置复杂,部署过程繁琐又容易出错,不仅耗费...
- 从0开始,让你的Spring Boot项目跑在Linux服务器
-
1搭建Linux服务器1.1购买阿里云服务器或安装虚拟机这里建议是CentOS7.X或CentOS8.X,当然其他的Linux如deepin、Ubuntu也可以,只是软件环境的安装包和安装方式...
- 【技术】Maven 上传第三方jar包到私服
-
通过nexus后台上传私服以NexusRepositoryManagerOSS2.14.5-02为例。登录nexus后台。定义Maven坐标Maven坐标有两种方式:1.自定义参数;2....
- JVM参数、main方法的args参数使用
-
一、前言我们知道JVM参数分为自定义参数、JVM系统参数,Javamain方法的参数。今天就谈谈怎么使用吧。二、查看jvm参数定义自定义参数我们打开cmd窗口,输入java,就能看到自定义参数的格式...
- Maven项目如何发布jar包到Nexus私服
-
Maven项目发布jar包到Nexus私服在编码过程中,有些通用的代码模块,有时候我们不想通过复制粘贴来粗暴地复用。因为这样不仅体现不了变化,也不利于统一管理。这里我们使用mavendeploy的方...
- 干货丨Hadoop安装步骤!详解各目录内容及作用
-
Hadoop是Apache基金会面向全球开源的产品之一,任何用户都可以从ApacheHadoop官网下载使用。今天,播妞将以编写时较为稳定的Hadoop2.7.4版本为例,详细讲解Hadoop的安...
- 一周热门
-
-
Python实现人事自动打卡,再也不会被批评
-
【验证码逆向专栏】vaptcha 手势验证码逆向分析
-
Psutil + Flask + Pyecharts + Bootstrap 开发动态可视化系统监控
-
一个解决支持HTML/CSS/JS网页转PDF(高质量)的终极解决方案
-
再见Swagger UI 国人开源了一款超好用的 API 文档生成框架,真香
-
网页转成pdf文件的经验分享 网页转成pdf文件的经验分享怎么弄
-
C++ std::vector 简介
-
系统C盘清理:微信PC端文件清理,扩大C盘可用空间步骤
-
10款高性能NAS丨双十一必看,轻松搞定虚拟机、Docker、软路由
-
python使用fitz模块提取pdf中的图片
-
- 最近发表
-
- 使用Assembly打包和部署Spring Boot工程
- java高级用法之:调用本地方法的利器JNA
- Linux中如何通过Shell脚本来控制Spring Boot的Jar包启停服务?
- 牛逼!自己手写一个热加载(人民币手写符号一个横还是两个横)
- java 错误: 找不到或无法加载主类?看看怎么解决吧!
- 如何将 Spring Boot 工程打包成独立的可执行 JAR 包
- class 增量发包改造为 jar 包方式发布
- Jar启动和IDE里启动Sprintboot的区别
- Java 20年,以后将往哪儿走?(java还能流行多久)
- Spring Boot Jar 包秒变 Docker 镜像实现多环境部署
- 标签列表
-
- python判断字典是否为空 (50)
- crontab每周一执行 (48)
- aes和des区别 (43)
- bash脚本和shell脚本的区别 (35)
- canvas库 (33)
- dataframe筛选满足条件的行 (35)
- gitlab日志 (33)
- lua xpcall (36)
- blob转json (33)
- python判断是否在列表中 (34)
- python html转pdf (36)
- 安装指定版本npm (37)
- idea搜索jar包内容 (33)
- css鼠标悬停出现隐藏的文字 (34)
- linux nacos启动命令 (33)
- gitlab 日志 (36)
- adb pull (37)
- table.render (33)
- python判断元素在不在列表里 (34)
- python 字典删除元素 (34)
- vscode切换git分支 (35)
- python bytes转16进制 (35)
- grep前后几行 (34)
- hashmap转list (35)
- c++ 字符串查找 (35)