使用shell中的变量将密码传递给mysql_config_editor
发布时间:2020-12-15 21:39:23 所属栏目:安全 来源:网络整理
导读:我将密码存储在变量$db_pwd中,我想将它传递给 shell脚本中的 mysql_config_editor.我不能使用配置文件或db_pwd环境变量. 我这样做 mysql_config_editor set --login-path=local --host=localhost --user=username --password (https://stackoverflow.com/a/2
我将密码存储在变量$db_pwd中,我想将它传递给
shell脚本中的
mysql_config_editor.我不能使用配置文件或db_pwd环境变量.
我这样做 mysql_config_editor set --login-path=local --host=localhost --user=username --password (https://stackoverflow.com/a/20854048/6487831). 它的作用是要求输入密码“输入密码”,但我希望使用变量提供密码. 我试过这个: mysql_config_editor set --login-path=local --host=localhost --user=username --password $db_pwd 和 mysql_config_editor set --login-path=local --host=localhost --user=username --password | echo $db_pwd 和 echo "$db_pwd" | mysql_config_editor set --login-path=local --host=localhost --user=username --password 和 >期待.但是,如果出现“此路径已存在,重写(y / n)”等警告,则会导致错误. 有什么办法吗?或者我应该恢复使用mysql而不是mysql_config_editor? 解决方法
当没有TTY时,我发现其他建议的答案不起作用.所以我使用这个bash脚本在没有终端的Terraform / ssh这样的地方工作:
#!/bin/bash if [ $# -ne 4 ]; then echo "Incorrect number of input arguments: $0 $*" echo "Usage: $0 <login> <host> <username> <password>" echo "Example: $0 test 10.1.2.3 myuser mypassword" exit 1 fi login=$1 host=$2 user=$3 pass=$4 unbuffer expect -c " spawn mysql_config_editor set --login-path=$login --host=$host --user=$user --password expect -nocase "Enter password:" {send "$passr"; interact} " 测试一下: ./mysql_config.sh login 10.1.2.3 myuser mypass < /dev/null (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |