ファイルからいくつかの値を読み取ってbash
変数に保存し、docker
その値を環境変数に渡して実行しようとしています。ファイルは次のように構成されます。
DB_NAME=db
ROOT_PASS=root123
USER_NAME=dev
USER_PASS=dev123
コードは次のとおりです。
ROOT_PASS=$(sed -nr '/ROOT_PASS=(\d*)/p' .env | cut -d '=' -f 2)
USER_NAME=$(sed -nr '/USER_NAME=(\d*)/p' .env | cut -d '=' -f 2)
USER_PASS=$(sed -nr '/USER_PASS=(\d*)/p' .env | cut -d '=' -f 2)
DB_NAME=$(sed -nr '/DB_NAME=(\d*)/p' .env | cut -d '=' -f 2)
echo -e $USER_NAME
echo -e $USER_PASS
echo -e $DB_NAME
docker volume ls
docker run --rm \
--name init-mysql \
-v mysql-data:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=$ROOT_PASS \
-e MYSQL_USER=$USER_NAME \
-e MYSQL_PASSWORD=$USER_PASS \
-e MYSQL_DATABASE=$DB_NAME \
-d mysql:latest
&& docker exec init-mysql echo $MYSQL_ROOT_PASSWORD
このスクリプトを実行した結果、$MYSQL_ROOT_PASSWORD
画面に値が印刷されると予想しましたが、空白行のみが表示されます(したがって、ユーザーにはroot
空白のパスワードがあります)。私は何が間違っていましたか? bash変数の値をdocker
環境変数に渡すにはどうすればよいですか?
PS:わかりましたdocker-compose.yml
。ただし、ここではこの方法を使用する必要があります。
答え1
それは私のために働くようです:
ROOT_PASS=$(sed -nr '/ROOT_PASS=(\d*)/p' .env | cut -d '=' -f 2)
echo $ROOT_PASS
root123
set -x
dockerコマンドで実行されたxtrace()を表示します。
ファイル構造がすぐにsource
実行できるようにするのはなぜですか?また、allexport
dockerが変数を継承するように変数を割り当てるときに自動的に環境にエクスポートするオプションを事前設定する必要があります。
$ set -o allexport
$ . ./.env
$ echo "$ROOT_PASS"
root123
$ echo "$USER_NAME"
dev
$ printenv USER_NAME
dev
$ echo "$USER_PASS"
dev123