为 mysqldump 使用特殊字符转义密码变量
Escaping out password variable with special characters for mysqldump
我正在尝试创建一个 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
我成功完成了这项工作。也许问题不在于转义,而在于我尝试 运行 的方式。
我的最终代码:
#!/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";
我正在尝试创建一个 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
我成功完成了这项工作。也许问题不在于转义,而在于我尝试 运行 的方式。 我的最终代码:
#!/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";