0

0

Linux shell 脚本编写最佳实践

冷炫風刃

冷炫風刃

发布时间:2026-02-13 21:40:03

|

559人浏览过

|

来源于php中文网

原创

shell脚本首行应写#!/usr/bin/env bash而非#!/bin/bash以提升跨平台兼容性;所有变量引用必须加双引号;推荐使用$(...)替代反引号;建议添加set -euo pipefail增强健壮性。

linux shell 脚本编写最佳实践

shell 脚本第一行必须是 #!/usr/bin/env bash,不是 #!/bin/bash

很多脚本在本地跑得好,一上 CI 或不同发行版就报 command not found,根源常在这行。用 /bin/bash 依赖绝对路径,但 Alpine 用 /bin/sh,macOS 的 Homebrew bash 是 /opt/homebrew/bin/bash,硬写路径等于自设兼容性障碍。

#!/usr/bin/env bash 让系统通过 $PATH 查找,更可靠。但要注意:env 本身也得在 /usr/bin/ 下(绝大多数系统都满足);如果脚本需要严格限定 bash 版本(比如用了 4.4+ 的 declare -v),那就得额外检查 bash --version,不能只靠 shebang。

  • 别用 #!/bin/sh 写 bash 特性(如数组、[[source-r 参数),会静默失败或行为异常
  • CI 环境里,Docker 镜像若精简(如 alpine:latest),默认没装 bash —— 此时要么换 #!/bin/sh 并重写逻辑,要么显式 apk add bash
  • 脚本开头加 set -euo pipefail,避免变量未定义、命令失败被忽略、管道中间出错不退出等问题

变量引用不加双引号是 shell 脚本最常见崩溃点

cp $SRC $DST 看似简洁,一旦 $SRC 含空格、通配符或换行符,就会触发单词拆分和路径展开,轻则复制错文件,重则删库跑路。所有变量引用必须包在双引号里:cp "$SRC" "$DST"

例外极少:比如明确要让 shell 展开通配符(ls $PATTERN),或要拆分成多个参数(cmd $ARGS),但这时应改用数组:args=(--verbose --input "$file"); cmd "${args[@]}"

PHP Apache和MySQL 网页开发初步
PHP Apache和MySQL 网页开发初步

本书全面介绍PHP脚本语言和MySOL数据库这两种目前最流行的开源软件,主要包括PHP和MySQL基本概念、PHP扩展与应用库、日期和时间功能、PHP数据对象扩展、PHP的mysqli扩展、MySQL 5的存储例程、解发器和视图等。本书帮助读者学习PHP编程语言和MySQL数据库服务器的最佳实践,了解如何创建数据库驱动的动态Web应用程序。

下载
  • [ -n $VAR ] 错 —— 若 $VAR 为空,变成 [ -n ],条件恒真;应写 [ -n "$VAR" ]
  • for f in $FILES 错 —— 若 $FILES="a b c",会循环三次,但若含空格路径("my file.txt")就裂开;应改用 for f in $FILES 前先设 IFS=$'\n',或直接用数组
  • 函数传参也要引号:myfunc "$1" "$2",否则 myfunc "a b" "c" 进入函数后 $1 变成 a$2 变成 b

$(...) 替代反引号 `...`,且避免无必要子 shell

反引号嵌套困难(`echo \`date\``)、视觉混淆、且 POSIX 兼容性差;$(...) 更易读、支持嵌套($(echo $(date))),所有现代 shell 都支持。

但别滥用:每次 $(...) 都启一个子 shell,频繁调用 datejq 会影响性能。如果只是取当前时间戳,一次就够了:ts=$(date +%s),后面复用 $ts

  • 不要写 if [ "$(grep -q foo file)" ]; then —— grep -q 本身就有退出码,直接 if grep -q foo file; then 更高效、更安全
  • $(cat file) 应简化为 $((bash/zsh 支持),少一次进程开销
  • 解析 JSON 别用 $(jq '.name' data.json) 多次 —— 一次性读进变量:data=$(jq -r '{name,age}' data.json),再用 name=$(echo "$data" | jq -r '.name')(或直接用 read + jq -r 流式处理)

调试时别只靠 echo,用 set -xPS4 定制输出

set -x 打印每条执行命令及其展开后的结果,比零散 echo "DEBUG: $var" 更系统。但默认输出太吵,尤其带长路径或敏感变量时。

PS4='+ ${BASH_SOURCE##*/}:${LINENO}: ' 可让调试行带上文件名和行号,快速定位;再配合 set -o functrace,还能追踪函数调用链。

  • 临时调试加 set -x,完事加 set +x 关闭,别留在生产脚本里
  • 敏感值(密码、token)打印前先用 local masked=${TOKEN:0:4}... 处理,或改用 declare -g + set -v 配合日志分级
  • 远程执行脚本(如 ssh host 'bash -s' )时,<code>set -x 输出会混在 stdout 中,建议重定向:set -x 2> /tmp/debug.log
事情说清了就结束。真正难的不是记住这些规则,而是每次敲 if 前下意识多按两个键打上双引号,或者看到反引号就本能地删掉重写。习惯比语法更难改。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

436

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

544

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

317

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

81

2025.09.10

if什么意思
if什么意思

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

808

2023.08.22

登录token无效
登录token无效

登录token无效解决方法:1、检查token的有效期限,如果token已经过期,需要重新获取一个新的token;2、检查token的签名,如果签名不正确,需要重新获取一个新的token;3、检查密钥的正确性,如果密钥不正确,需要重新获取一个新的token;4、使用HTTPS协议传输token,建议使用HTTPS协议进行传输 ;5、使用双因素认证,双因素认证可以提高账户的安全性。

6384

2023.09.14

登录token无效怎么办
登录token无效怎么办

登录token无效的解决办法有检查Token是否过期、检查Token是否正确、检查Token是否被篡改、检查Token是否与用户匹配、清除缓存或Cookie、检查网络连接和服务器状态、重新登录或请求新的Token、联系技术支持或开发人员等。本专题为大家提供token相关的文章、下载、课程内容,供大家免费下载体验。

832

2023.09.14

token怎么获取
token怎么获取

获取token值的方法:1、小程序调用“wx.login()”获取 临时登录凭证code,并回传到开发者服务器;2、开发者服务器以code换取,用户唯一标识openid和会话密钥“session_key”。想了解更详细的内容,可以阅读本专题下面的文章。

1082

2023.12.21

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

23

2026.02.13

热门下载

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

精品课程

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

共48课时 | 9万人学习

Git 教程
Git 教程

共21课时 | 3.6万人学习

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

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