Shell脚本单实例运行|学习笔记

简介: 快速学习Shell脚本单实例运行

开发者学堂课程【Shell 脚本进阶:Shell脚本单实例运行】学习笔记,与课程紧密联系,让用户快速学习知识。

课程地址https://developer.aliyun.com/learning/course/799


Shell脚本单实例运行

目录:

一、单实例运行的背景

二、使用锁文件实现

三、flock命令介绍

一、单实例运行的背景

1、背景:计划任务定时执行的shell脚本,当脚本的运行时间可能会超过计划任务的时间间隔时,系统中就会出现多个shell脚本的运行实例。

2、场景:尤其是当脚本涉及到文件读写、数据库操作等任务时需要注意这种情况。

3、单实例:使得shell脚本运行的实例个数不超过一个,确保脚本中命令执行的安全性。

4、思路: shell脚本执行时,先检测当前脚本是否已有实例正在运行,若有则退出。

二、使用锁文件实现单实例运行

(一)错误示范:通过查询进程名来判断脚本是否在运行

(二)正确示范:通过锁文件来判断

1、若锁文件存在且文件中的进程在运行,退出

2、将当前程序进程号写入锁文忤

3、开始执行脚本的志体功能

4、结束时删除锁文件,并用trap命令保证

image.png

image.png

(三)缺点:

1、Linux 系统中的进程pid号可能会被复用

2、可能会存在极小概率的异常情况

三、flock命令介绍

1、Linux操作系统的文件锁机制

相关命令: flock

flock [-sxun][-w #] fd#

flock [-sxon][-w #] file [-c] command...

-s,--shared :获取-个共享锁,或者称为读锁

-x,--exclusive :获取一个排它锁,或称为写锁,为默认项

-u,--unlock:删除-个锁,通常是不需要的,因为在文件关闭时锁会自动删除

-n,--nonblock:非阻模式,当快取锁失败时,直接返回1而不是继续等待

-w,--timeout seconds :设置阻塞超时,没有立即获得锁,等待设置的秒数

-0,--close :表示执行命令前关闭锁的文件描述符,使命令的子进程不保持非常适用于crontab的场景中

***** flock -n /tmp/scipt_ name.lock -C "bash

-c,--command :在shell中运行单独的命令

script.sn

示例:

image.png

image.pngimage.jpeg

相关文章
|
Java 编译器 Maven
Spring boot 配置热部署(两步即可)
Spring boot 配置热部署(两步即可)
322 0
Spring boot 配置热部署(两步即可)
|
8天前
|
机器人 API 调度
基于 DMS Dify+Notebook+Airflow 实现 Agent 的一站式开发
本文提出“DMS Dify + Notebook + Airflow”三位一体架构,解决 Dify 在代码执行与定时调度上的局限。通过 Notebook 扩展 Python 环境,Airflow实现任务调度,构建可扩展、可运维的企业级智能 Agent 系统,提升大模型应用的工程化能力。
|
14天前
|
人工智能 数据可视化 Java
Spring AI Alibaba、Dify、LangGraph 与 LangChain 综合对比分析报告
本报告对比Spring AI Alibaba、Dify、LangGraph与LangChain四大AI开发框架,涵盖架构、性能、生态及适用场景。数据截至2025年10月,基于公开资料分析,实际发展可能随技术演进调整。
913 152
|
人工智能 前端开发 API
前端接入通义千问(Qwen)API:5 分钟实现你的 AI 问答助手
本文介绍如何在5分钟内通过前端接入通义千问(Qwen)API,快速打造一个AI问答助手。涵盖API配置、界面设计、流式响应、历史管理、错误重试等核心功能,并提供安全与性能优化建议,助你轻松集成智能对话能力到前端应用中。
651 154
|
负载均衡 Java 微服务
OpenFeign:让微服务调用像本地方法一样简单
OpenFeign是Spring Cloud中声明式微服务调用组件,通过接口注解简化远程调用,支持负载均衡、服务发现、熔断降级、自定义拦截器与编解码,提升微服务间通信开发效率与系统稳定性。
348 156
|
6天前
|
分布式计算 监控 API
DMS Airflow:企业级数据工作流编排平台的专业实践
DMS Airflow 是基于 Apache Airflow 构建的企业级数据工作流编排平台,通过深度集成阿里云 DMS(Data Management Service)系统的各项能力,为数据团队提供了强大的工作流调度、监控和管理能力。本文将从 Airflow 的高级编排能力、DMS 集成的特殊能力,以及 DMS Airflow 的使用示例三个方面,全面介绍 DMS Airflow 的技术架构与实践应用。