Как заставить мой Linux (Ubuntu) спрашивать пароль SQL, чтобы я не сохранял его в файле .sh?

Как заставить мой Linux (Ubuntu) спрашивать пароль SQL, чтобы я не сохранял его в файле .sh?

У меня есть файл скрипта, который немедленно создает резервную копию корневого каталога документов моего сервера и моих баз данных и копирует ее в мою терминальную систему, из которой я подключаюсь по SSH к среде моего сервера:

(
cd /var/www/html
zip -r ./html.zip ./
mysqldump -u USER -p PASSWORD --all-databases > ./db.sql
zip backup.zip html.zip db.sql
scp backup.zip /home/user/backups
rm ./html.zip ./db.sql ./backup.zip
)

Моя проблема:

Там, где это ПАРОЛЬ, мне нужно вручную вводить пароль. Это то, чего я хочу избежать, потому что я вбил этот пароль себе в голову и также часто его использую, и не хочу вводить его внутри скрипта.

Мой идеал:

Я бы предпочел, чтобы мне предлагалось вводить пароль каждый раз, когда я выполняю следующую команду (или что-то в этом роде):

mysqldump -u USER --all-databases > ./db.sql

Мой вопрос:

Возможно ли получить такую ​​подсказку через сам Linux или через какую-то существующую утилиту?

решение1

Из страницы руководства mysqldump:

 o   --password[=password], -p[password]

           The password to use when connecting to the server. If you use the short option form (-p), you cannot have a space between the option and the password. If you omit the password value following the
           --password or -p option on the command line, mysqldump prompts for one.

           Specifying a password on the command line should be considered insecure. You can use an option file to avoid giving the password on the command line.

Просто опустите значение пароля в -pфлаге, и mysqldump запросит пароль.

Связанный контент