gpt4 book ai didi

mysql - 使用mysqldump的特殊字符转义密码变量

转载 作者:行者123 更新时间:2023-12-02 19:00:41 27 4
gpt4 key购买 nike

我正在尝试创建一个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";

关于mysql - 使用mysqldump的特殊字符转义密码变量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60509759/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com