转 MySQL shell脚本执行错误 $'\r':command not found
2023-09-11 14:18:40 时间
问题描述
前几天编写的shell小脚本,测试自动安装MySQL的,今天测试运行,然后出现如下错误
$’\r’:command not found,
问题分析
检查脚本,没有问题,只是有空行。提示这个错误也不是代码本身错误,怀疑可能是编码格式等错误,:脚本是Linux下编辑完成测试。后期我又做了简单修改,是在在window下修改后完成,然后上传到Linux服务器的。
注意到:win下的换行是回车符+换行符,也就是\r\n,而unix下是换行符\n。
linux下不识别\r为回车符,如果脚本有\r回车符那么会导致脚本编码执行出现问题。
处理问题
-
在linux上执行 dos2unix 脚本名,转换后,在执行该脚本。
- 检查sh 文件,看看有无乱码
- cat -A mysql_install_binary5.6.16.sh
- 提示没有dos2unix命令的话,就yum安装下
-
[root@localhost soft]# dos2unix mysql_install_binary5.6.16.sh
-
bash: dos2unix: command not found...
-
[root@localhost soft]# yum -y install dos2unix
- 在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直接到登录界面。完成。
- 在学习中尽量慢慢养成好的习惯,在Linux下编码 测试 更新等
结尾
在工作和学习中遇到的问题和大家分享,希望对大家有所帮助
转载于:https://blog.51cto.com/it3246/2097318
相关文章
- Java+MyEclipse+Tomcat (三)配置MySQL及查询数据显示在JSP网页中
- Navicat Premium连接MySQL 1251错误和Mysql初始化root密码和允许远程访问
- 【Mysql 学习】mysqld_safe:MySQL服务器启动脚本
- 【MySQL】mysql optimize table
- 【MySQL】批量删除mysql中数据库中的表
- 【MySql】复制出现Slave_SQL_Running: No 错误解决
- Mysql错误: Lock wait timeout exceeded 解决办法
- 用Navicat连接mysql报错:2003-Can't connect to MySql server on '10.100.0.109'(10039)
- hibernate调用mysql存储过程
- 【MySQL】解决You can't specify target table 'user_cut_record_0413' for update in FROM clause
- 从【MySQL server has gone away】说起
- ef和mysql使用(一)
- 【原创】modb 功能设计之“支持部分MySQL客户端协议”-3
- mysql coalesce函数
- mysql 必知必会整理—数据库的维护[十八]
- MySQL在like查询中是否使用到索引
- 允许远程链接mysql,开放3306端口
- 〖Python 数据库开发实战 - MySQL篇⑪〗- 修改数据表结构
- Mysql报错:Can't connect to local MySQL server through socket '/tmp/mysql.sock'
- 【MySql】MySQL索引15连问(相信大家看完肯定会有帮助)
- MySQL 一文带你详解 mysql binlog
- Mysql错误:ERROR: No query specified
- MySQL-第七章-xtrabackup(XBK)工具使用