问题描述
在 DolphinScheduler 的 master-server/conf/dolphinscheduler_env.sh 脚本文件中出现 ^M 字符。执行如下命令启动 master-server 时会报错 “\r‘: 未找到命令”
bash ./bin/dolphinscheduler-daemon.sh start master-server
手动删除 ^M 字符后,重新执行启动脚本又会重新出现。
问题原因
^M 是 Windows 系统中的回车符(Carriage Return, \r)在 Linux/Unix 系统中的显示。问题出现在 DolphinScheduler 的启动机制中:
- 源文件污染:bin/env/dolphinscheduler_env.sh 文件本身包含 Windows 行结束符(CRLF)
- 自动复制机制:每次启动服务时,dolphinscheduler-daemon.sh 脚本中的 overwrite_server_env 函数会将源配置文件复制到各服务的配置目录
- 污染传播:被污染的源文件在每次启动时都会重新污染目标文件
故障定位
关键代码分析。在 bin/dolphinscheduler-daemon.sh 中:
function overwrite_server_env() {
local server=$1
local server_env_file="${DOLPHINSCHEDULER_HOME}/${server}/conf/dolphinscheduler_env.sh"
if [ -f "${BIN_ENV_FILE}" ]; then
echo "Overwrite ${server}/conf/dolphinscheduler_env.sh using bin/env/dolphinscheduler_env.sh."
cp "${BIN_ENV_FILE}" "${server_env_file}"
fi
}
每次启动时,这个函数都会将 bin/env/dolphinscheduler_env.sh 复制到 master-server/conf/dolphinscheduler_env.sh,而源文件 bin/env/dolphinscheduler_env.sh 本身就包含 Windows 行结束符。
将源文件 bin/env/dolphinscheduler_env.sh 中的 ^M 字符也去除后,重新执行启动脚本就正常了。
解决方案
方案1:在 Vim 编辑器中处理
# 方法一:设置文件格式为 Unix
:set ff=unix
:w
# 方法二:使用过滤功能去除所有 \r 字符
:%!tr -d '\r'
:w
方案2:命令行工具处理
# 使用 dos2unix
dos2unix bin/env/dolphinscheduler_env.sh
# 使用 sed
sed -i 's/\r$//' filename.sh
方案3:批量修复所有相关文件
# find 递归修复 bin/ 目录下所有 .sh 脚本文件
find bin/ -name "*.sh" -type f -exec sed -i 's/\r$//' {} \;
1108

被折叠的 条评论
为什么被折叠?



