【问题标题】:Escaping out password variable with special characters for mysqldump使用 mysqldump 的特殊字符转义密码变量
【发布时间】:2020-03-03 14:45:37
【问题描述】:

我正在尝试创建一个 shell 脚本来自动备份我的整个数据库。我的脚本需要在新行中输入密码,因为我不想将其存储在任何地方。这是我的代码:

#!/bin/bash
echo -n Password:
read -s PASS
echo
docker exec db /usr/bin/mysqldump --all-databases -u admin --password='\''$PASS\'' > backup-$(date "+%Y-%m-%d").sql

问题是,由于密码中的 $ 符号,我需要将变量放在单引号中,但我无法读取单引号中的变量。 我知道那里有几个类似的问题,但我无法解决它们。

所以如果密码是'$ecretPa$$word',那么实际执行的程序应该是这样的:

docker exec db /usr/bin/mysqldump --all-databases -u admin --password='$ecretPa$$word' > backup-2020-03-03.sql

【问题讨论】:

    标签: mysql bash docker passwords escaping


    【解决方案1】:

    我设法完成了这项工作。也许问题不在于转义,而在于我尝试运行它的方式。 我的最终代码:

    #!/bin/bash
    echo -n Password:
    read -s PASS
    echo
    cmd="docker exec db /usr/bin/mysqldump --all-databases -u admin --password='$PASS' > backup-$(date "+%Y-%m-%d").sql"
    eval "$cmd";
    

    【讨论】:

      猜你喜欢
      • 2015-01-19
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多