加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

使用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而不是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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读