解决 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`

相关推荐
国科安芯38 分钟前
抗辐照芯片在低轨卫星星座CAN总线通讯及供电系统的应用探讨
运维·网络·人工智能·单片机·自动化
gx23481 小时前
HCLP--MGER综合实验
运维·服务器·网络
angushine2 小时前
鲲鹏服务器部署Kafka2.8.1
运维·服务器
Johny_Zhao2 小时前
CentOS Stream 9上部署FTP应用服务的两种方法(传统安装和docker-compose)
linux·网络安全·信息安全·kubernetes·云计算·containerd·ftp·yum源·系统运维
一个网络学徒3 小时前
MGRE综合实验
运维·服务器·网络
守望时空333 小时前
RustDesk搭建指南
linux
C++ 老炮儿的技术栈3 小时前
在 Scintilla 中为 Squirrel 语言设置语法解析器的方法
linux·运维·c++·git·ubuntu·github·visual studio
白鹭4 小时前
基于LNMP架构的分布式个人博客搭建
linux·运维·服务器·网络·分布式·apache
java叶新东老师4 小时前
linux 部署 flink 1.15.1 并提交作业
linux·运维·flink
程序员JerrySUN5 小时前
Linux系统架构核心全景详解
linux·运维·系统架构