JDBC连不上,原来都是特殊字符搞的鬼?^M与M-BM-是什么鬼?

今天遇到个趣的问题,linux上springboot启动,连接达梦数据库报错。
解决思路: 1)是不是数据库本身有问题,客户端登录没问题。

2)排查是不是war包问题,本地连接数据库,没问题。

3)是不是启动参数有问题?因为多数据源的关系,在启动参数里配置了数据源跟驱动名 --spring.datasource.url=jdbc:dm://172.31.98.190:5236/DMSERVER
–spring.datasource.driverClassName=dm.jdbc.driver.DmDriver
检查了下,没任何问题。

4)是不是有特殊字符? 用vi -b start.sh查看了启动脚本,并未发现^M这样的特殊字符。

5)去除启动参数,将启动参数写死放到application.properties中,重新打包,上传上去,./start.sh,启动竟然不报错了。

6)回头再检查这两行参数,将参数逐行删除,再手动打上去,定位到参数行 --spring.datasource.driverClassName=dm.jdbc.driver.DmDriver
将DmDriver 后的空格删除,再重新手动打个空格,:wq保存,重启启动,成功。

7)为什么?中午吃饭去了,下午回来再看。路上怀疑是隐藏字符。

8)下午回来,按照隐藏字符的思路去百度了下,看还有什么方法可以查看linux上的隐藏字符。找到了个命令,cat -A。 cat -A start.sh

发现信息如下 --spring.datasource.url=jdbc:dm://172.31.98.190:5236/DMSERVERM-BM- $ --spring.datasource.driverClassName=dm.jdbc.driver.DmDriverM-BM- $

多了M-BM-这串特殊字符,真相大白。

9)M-BM-是什么特殊字符?哪位大神能告诉我下?我关键字只搜索到了BM算法,这是一个查找替换算法,另外还搜到了个帖子,说放在oneNote里再贴出来也出现这个问题。所以猜测是运维人员在windows上批量替换数据库参数导致。

扩展: 解决^M的问题。 vi -b 文件,发现^M的问题

:set ff=unix,意思设置文件格式为 fileformat=unix 。 可以先用:set ff查看下fileformat,可能当前文件格式先前在windows下转了一道手变成了dos文件。

发布了63 篇原创文章 · 获赞 6 · 访问量 1万+

猜你喜欢

转载自blog.csdn.net/yy448671246/article/details/99190942
今日推荐