解决 Linux Bash 脚本因换行符问题导致的 “bash^M: No such file or directory“ 错误

一、问题重现

最近在部署一个 Bash 脚本时遇到一个诡异的问题:

```bash

$ chmod +x deploy.sh

$ ./deploy.sh

/usr/bin/env: 'bash\r': No such file or directory

```

明明脚本内容正确,权限也设置好了,为什么会出现这样的错误?

二、问题根源

经过排查发现,这个错误的根本原因是换行符格式问题:

  1. Windows 换行符(CRLF):`\r\n`(回车+换行)

  2. Unix/Linux 换行符(LF):`\n`(仅换行)

当脚本在 Windows 系统编辑后保存,会使用 CRLF 格式。而 Linux 系统只能识别 LF 格式,因此当它看到 `\r\n` 时:

• 把 `\r` 当作命令名的一部分(变成 `bash\r`)

• 系统找不到名为 `bash\r` 的命令,于是报错

三、解决方案

方法 1:使用 dos2unix 工具

最简单直接的方法是使用 `dos2unix` 工具转换换行符:

```bash

安装 dos2unix(如果未安装)

sudo apt-get install dos2unix # Ubuntu/Debian

sudo yum install dos2unix # CentOS/RHEL

转换文件

dos2unix deploy.sh

```

方法 2:使用 sed 命令

如果没有 dos2unix,可以用 sed 命令手动删除 `\r` 字符:

```bash

sed -i 's/\r$//' deploy.sh

```

方法 3:VS Code 编辑器转换

  1. 用 VS Code 打开脚本文件

  2. 右下角状态栏会显示当前换行符格式(CRLF 或 LF)

  3. 点击换行符标识,选择 "LF"

  4. 保存文件

四、如何验证换行符格式

检查文件换行符格式的方法:

```bash

方法 1:cat -v 命令

cat -v deploy.sh | head -n 1

如果输出中出现 ^M,则说明有 Windows 换行符

方法 2:file 命令

file deploy.sh

会显示 "with CRLF line terminators" 或 "ASCII text"

```

五、为什么换行符会造成问题?

  1. 历史原因:

• Windows 继承了 DOS 的 `\r\n` 换行格式

• Unix/Linux 使用简洁的 `\n` 换行格式

  1. 技术原理:

• `\r` 是回车(Carriage Return),把光标移回行首

• `\n` 是换行(Line Feed),把光标移到下一行

• Windows 要求两者配合使用,Unix/Linux 只需要 `\n`

相关推荐
大树882 小时前
金刚石散热越强,管路越先见顶
大数据·运维·服务器·人工智能·ai
摇滚侠3 小时前
Linux CentOS7 rpm 安装 MySQL 5.7
linux·运维·mysql
霸道流氓气质3 小时前
领域驱动设计(DDD)在 Spring Boot 微服务中的实践指南
运维·spring boot·微服务
bush43 小时前
嵌入式linux学习记录十四、术语
linux·嵌入式
载数而行5203 小时前
Linux 11 动态监控指令top
linux
Inhand陈工4 小时前
基于台达PLC与映翰通IG502的智慧水产养殖精准投喂与远程运维解决方案
运维·人工智能·物联网·阿里云·信息与通信
酣大智4 小时前
ARP代理--工作原理
运维·网络·arp·arp代理
不会C语言的男孩4 小时前
Linux 系统编程 · 第 8 章:进程基础
linux·c语言
shushangyun_5 小时前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化
古城小栈5 小时前
Unix 与 Linux 异同小叙
linux·服务器·unix