0

0

LinuxShell并发执行_并发控制与锁机制

舞夢輝影

舞夢輝影

发布时间:2026-03-12 09:35:03

|

280人浏览过

|

来源于php中文网

原创

linux shell并发需配合锁机制防竞争,常用flock实现文件锁,支持阻塞/非阻塞模式;无flock时可用mkdir原子性模拟锁;控制并发数推荐sem或parallel;须规避管道子shell锁失效、nfs不兼容及锁路径不一致等问题。

linuxshell并发执行_并发控制与锁机制

Linux Shell 中实现并发执行时,必须配合合理的并发控制与锁机制,否则容易出现资源竞争、数据错乱或重复执行等问题。核心思路是:用进程隔离保证并行效率,用文件锁或信号量等手段保证关键操作的互斥性。

使用 flock 实现轻量级文件锁

flock 是 Shell 并发控制最常用、最便捷的方式,它基于内核文件描述符锁,无需额外服务,支持排他锁(写锁)和共享锁(读锁),且自动随进程退出释放。

  • 基本用法:flock /tmp/mylock -c "command",命令执行完自动解锁
  • 在脚本中封装更安全:
    exec 200>/tmp/global.lock
    flock -n 200 || { echo "获取锁失败,退出"; exit 1; }
    # 执行临界区逻辑
    echo "正在更新共享配置..." >> /var/log/app.log
    # ...
    flock -u 200
  • -n 表示非阻塞,抢锁失败立即返回;不加则会等待(可能无限挂起)

用临时文件 + 原子重命名模拟“检查-设置”锁

在不支持 flock 的极简环境(如某些容器或 busybox)中,可用 mkdir 的原子性实现互斥——因为 mkdir 天然不可重入:

网胜B2B电子商务系统蓝色风格 2008 SP6.2 普及版
网胜B2B电子商务系统蓝色风格 2008 SP6.2 普及版

  websenB2B是一套经过完善设计的B2B行业网站程序,是windows nt系列环境下最佳的B2B行业网产站解决方案。精心设计的架构与功能机制,适合从个人到企业各方面应用的要求,为您提供一个安全、稳定、高效、易用而快捷的行业网站商务系统。分普及版和商业版等不同版本。一、网胜B2B电子商务系统SP6.2蓝色风格普及版本升级功能说明:1、邮件群发功能:可以选择某一级别的会员,并放入支持html

下载
  • if mkdir /tmp/lock.dir 2>/dev/null; then echo "获得锁"; else echo "锁已被占用"; fi
  • 临界区结束后用 rmdir /tmp/lock.dir 释放(注意仅限单机,且需确保无残留)
  • 适合短时、低频、无复杂依赖的场景,例如防止同一脚本被重复触发

限制并发数量:sem 和 parallel 工具

当需要控制“最多 N 个任务同时运行”,而非完全互斥时,可借助外部工具:

  • GNU parallel:内置并发控制,cat tasks.txt | parallel -j 4 ./process.sh {} 表示最多 4 个进程并行
  • sem(来自 GNU parallel 包):配合 flock 使用,sem -j 3 --id myjob ./task.sh arg1 可跨脚本协调同名任务的并发上限
  • 纯 Shell 模拟较繁琐(需维护后台作业计数+wait -n),不建议自行实现

避免常见陷阱

并发 Shell 脚本容易踩坑,关键点在于理解锁的作用域和生命周期:

  • 管道中的子 shell 无法继承父进程的文件描述符锁,flock -e 200; echo "x" | while read line; do ...; done 会导致锁失效——应改用 while ... done 或把整个循环包进 <code>flock -c
  • 不要对 NFS 挂载点上的文件使用 flock(部分 NFS 版本不支持强制锁)
  • 多个脚本若共用同一锁路径,务必确保路径绝对、一致,且有足够权限

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

254

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

1089

2024.03.01

if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

846

2023.08.22

while的用法
while的用法

while的用法是“while 条件: 代码块”,条件是一个表达式,当条件为真时,执行代码块,然后再次判断条件是否为真,如果为真则继续执行代码块,直到条件为假为止。本专题为大家提供while相关的文章、下载、课程内容,供大家免费下载体验。

106

2023.09.25

磁盘配额是什么
磁盘配额是什么

磁盘配额是计算机中指定磁盘的储存限制,就是管理员可以为用户所能使用的磁盘空间进行配额限制,每一用户只能使用最大配额范围内的磁盘空间。php中文网为大家提供各种磁盘配额相关的内容,教程,供大家免费下载安装。

1564

2023.06.21

如何安装LINUX
如何安装LINUX

本站专题提供如何安装LINUX的相关教程文章,还有相关的下载、课程,大家可以免费体验。

716

2023.06.29

linux find
linux find

find是linux命令,它将档案系统内符合 expression 的档案列出来。可以指要档案的名称、类别、时间、大小、权限等不同资讯的组合,只有完全相符的才会被列出来。find根据下列规则判断 path 和 expression,在命令列上第一个 - ( ) , ! 之前的部分为 path,之后的是 expression。还有指DOS 命令 find,Excel 函数 find等。本站专题提供linux find相关教程文章,还有相关

300

2023.06.30

linux修改文件名
linux修改文件名

本专题为大家提供linux修改文件名相关的文章,这些文章可以帮助用户快速轻松地完成文件名的修改工作,大家可以免费体验。

800

2023.07.05

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

3

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 10.5万人学习

Git 教程
Git 教程

共21课时 | 4.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号