MariaDB --init-команда при вызове mysql из скрипта BASH - PullRequest
1 голос
/ 04 октября 2019

Я новый пользователь в переполнении стека, поэтому заранее прошу прощения за любые потенциальные нарушения этикета сайта.

Я пытаюсь создать скрипт BASH, который сгенерирует команду для вызова монитора MariaDB,то есть mysql. Я хочу, чтобы эта команда mysql включала параметр --init-command. Я хочу, чтобы опция --init-command установила список пользовательских переменных в их значения, как указано в файле конфигурации.

Сценарий создает строку, которая, по-видимому, подходит для моих целей, но при вызовеmysql, сгенерирована ошибка. Если я распечатываю сгенерированную строку из скрипта, то, похоже, это именно то, что я пытался создать.

Я свел ее к следующему примеру кода:

#!/bin/sh
declare foo="name"
declare bar="value"
declare invoke="mysql -p -D information_schema"
declare opts=" --init-command='SET @$foo:=\"$bar\"'"
invoke+=$opts
echo $invoke
$invoke

КогдаЯ выполняю этот скрипт, результат выглядит так:

$ example.sh
mysql -p -D information_schema --init-command='SET @name:="value"'
Enter password:
ERROR 1044 (42000): Access denied for user 'Bill'@'%' to database '@name:="value"''

Это сообщение об ошибке даже не имеет смысла.

Однако, если я скопирую сгенерированную команду и вставлю ее обратнов командной строке он запрашивает мой пароль и поступает так, как я ожидал, следующим образом:

$ mysql -p -D information_schema --init-command='SET @name:="value"'
Enter password:
Welcome to the MariaDB monitor.  Commands end with ; or \g.
Your MariaDB connection id is 171
Server version: 10.3.11-MariaDB Source distribution

Copyright (c) 2000, 2018, Oracle, MariaDB Corporation Ab and others.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

MariaDB [information_schema]> SELECT @name;
+-------+
| @name |
+-------+
| value |
+-------+
1 row in set (0.000 sec)

MariaDB [information_schema]>

демонстрация того, что команда SET в опции --init-command была успешно передана на монитор MariaDB,и выполнено.

Я не знаю, является ли это проблемой Linux, проблемой BASH или проблемой MariaDB. Итак, хотя я потратил много времени, пытаясь найти ответ, я действительно не знаю, откуда возникла проблема, и, следовательно, где сосредоточить свое исследование.

Обратите внимание: я использовал толькоБаза данных information_schema в моем примере, потому что я ожидаю, что любой, кто попытается воссоздать эту проблему, получит эту базу данных для себя.

Заранее благодарю за помощь.

Ответы [ 2 ]

0 голосов
/ 04 октября 2019

Некоторые опции:

Опция 1:

#!/bin/sh

# USING BASH
# FILE: bash_mariadb.sh

foo="\`name\`"
bar="value"

mysql -p -D information_schema --init-command="SET @$foo:='$bar';"

Опция 2:

#!/bin/sh

# USING BASH
# FILE: bash_mariadb.sh

foo="\`name\`"
bar="value"

opts=(--init-command="SET @$foo:='$bar';")
invoke=(mysql -p -D information_schema "$opts")
"${invoke[@]}"

Опция 3:

#!/bin/sh

# USING BASH
# FILE: bash_mariadb.sh

foo="\`name\`"
bar="value"

#define
invoke() {
  opts=(--init-command="SET @$foo:='$bar'")

  if [[ -v opts ]]; then
    invoke=(mysql -p -D information_schema "$opts")
  else
    invoke=(mysql -p -D information_schema)
  fi

  "${invoke[@]}"
}

#call
invoke

Опция 4: ОПАСНОСТЬ, опция не рекомендуется по соображениям безопасности.

#!/bin/sh

# USING BASH
# FILE: bash_mariadb.sh

foo="\`name\`"
bar="value"

invoke="mysql -p -D information_schema"
opts=" --init-command='SET @$foo:=\"$bar\"'"
invoke+=$opts
eval $invoke

Во всех случаях:

$ ./bash_mariadb.sh
Enter password:
Welcome to the MariaDB monitor.  Commands end with ; or \g.
Your MariaDB connection id is 1
Server version: 10.3.11-MariaDB Source distribution

Copyright (c) 2000, 2018, Oracle, MariaDB Corporation Ab and others.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

MariaDB [information_schema]> SELECT @`name`;
+---------+
| @`name` |
+---------+
| value   |
+---------+
1 row in set (0.000 sec)
0 голосов
/ 04 октября 2019

Добро пожаловать в SO.

Из скрипта вы должны указать пароль, который хотите использовать.

Опция -p принудительно вводит пароль в интерактивном режиме, который не работает из скрипта.

Если вместо этого вы используете -ppassword (обратите внимание, что вы все еще пишете «p», только если вы пишете его рядом с паролем, без пробелов), ваше соединение будет работать.

Итак, вам просто нужно изменить строку:

declare invoke="mysql -ppassword -D information_schema"

(не забудьте написать свой пароль, где я написал «пароль», конечно :))

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...