当前位置: 首页 > article >正文

shell脚本定义特殊字符导致执行mysql文件错误的问题

       记得有一次版本发布过程中有提供一个sh脚本用于一键执行sql文件,遇到一个shell脚本定义特殊字符的问题,sh脚本的内容类似以下内容:

# 数据库ip地址
ip="127.0.0.1"
# 数据库密码
cmdb='cmdb!@#$!'
sm='sm!@#$!'

# 执行脚本文件(参照样本)
mysql –ucmdb –p$cmdb -Dcmdb<./xxx_xxx1.sql
mysql –ucmdb –p$cmdb -Dcmdb<./xxx_xxx2.sql
mysql –usm –p$sm -Dsm<./xxx_xxx2.sql
mysql –usm –p$sm -Dsm<./xxx_xxx2.sql

       由于现场一线人员设置的密码比较复杂,因此包含许多特殊字符,最后在执行sh脚本的时候频繁报数据库密码错误的错误。
       经过排查验证,通过mysql客户端验证密码是正确的,但是通过我们提供的sh脚本执行时却一直报错,最后排查到是shell脚本将特殊字符转义导致运行失败了,例子如下:(定义一个变量并且输出)
在这里插入图片描述
通过执行上述脚本,会发现字符串中后面的$!字符丢失了。
在这里插入图片描述
最后将双引号改为单引号,避免字符串转义即可,如下:
在这里插入图片描述


http://www.kler.cn/a/449505.html

相关文章:

  • uniapp跨平台开发---webview调用app方法
  • Windows、CentOS环境下搭建自己的版本管理资料库:GitBlit
  • typora数学符号
  • Redis分片集群学习总结
  • 华为IPD流程6大阶段370个流程活动详解_第一阶段:概念阶段 — 81个活动
  • 如何在Windows系统上安装和配置Maven
  • 汽车IVI中控开发入门及进阶(47):CarPlay开发
  • 【unity】【游戏开发】Unity项目一运行就蓝屏报Watch Dog Timeout
  • 重温设计模式--命令模式
  • 安卓APP-HTTPS抓包Frida Hook教程
  • 集星云推短视频矩阵系统:重塑短视频营销格局
  • 图匹配经典论文(三)Deep Learning of Graph Matching—CVPR2018图匹配
  • C++中的模板元编程
  • 0基础学前端-----CSS DAY5
  • 004最长回文子串
  • ABAQUS纤维混凝土冲击破坏三维模型
  • 苏黎世联邦理工学院与加州大学伯克利分校推出MaxInfoRL:平衡内在与外在探索的全新强化学习框架
  • C++ 中的多线程与并发编程:从基础到进阶
  • Apache RocketMQ 5.1.3安装部署文档
  • QT多媒体开发(一):概述
  • 数据流图和流程图的区别
  • Vue.js 表单处理
  • 3.1、SDH的5种标准容器
  • CentOS常见命令
  • Note2024122001_Excel按成绩排名
  • 【YashanDB知识库】insert语句有编码不识别字,执行卡住问题