MySQL shell脚本执行错误 $'\r':command not found

问题描述

前几天编写的shell小脚本,测试自动安装MySQL的,今天测试运行,而后出现以下错误
MySQL shell脚本执行错误 $'\r':command not found
$’\r’:command not found,mysql


问题分析

检查脚本,没有问题,只是有空行。提示这个错误也不是代码自己错误,怀疑多是编码格式等错误,:脚本是Linux下编辑完成测试。后期我又作了简单修改,是在在window下修改后完成,而后上传到Linux服务器的。
注意到:win下的换行是回车符+换行符,也就是\r\n,而unix下是换行符\n。linux

linux下不识别\r为回车符,若是脚本有\r回车符那么会致使脚本编码执行出现问题。sql


处理问题

  • 在linux上执行 dos2unix 脚本名,转换后,在执行该脚本。shell

  • 提示没有dos2unix命令的话,就yum安装下
    [root@localhost soft]#  dos2unix mysql_install_binary5.6.16.sh 
    bash: dos2unix: command not found...
    [root@localhost soft]# yum -y install dos2unix

    MySQL shell脚本执行错误 $'\r':command not found

    1. 在linux上执行 dos2unix 脚本名,
      [root@localhost soft]#  dos2unix mysql_install_binary5.6.16.sh 
      dos2unix: converting file mysql_install_binary5.6.16.sh to Unix format ...
  • 而后执行脚本
    MySQL shell脚本执行错误 $'\r':command not found
    MySQL shell脚本执行错误 $'\r':command not found
    MySQL shell脚本执行错误 $'\r':command not foundbash

  • 脚本执行完毕,MySQL直接到登陆界面。完成。
  • 在学习中尽可能慢慢养成好的习惯,在Linux下编码 测试 更新等

结尾

在工做和学习中遇到的问题和你们分享,但愿对你们有所帮助服务器

相关文章
相关标签/搜索