私は別のプロセス(ターミナルからパスワードを要求するプロセス)を呼び出すbashスクリプトを作成しました。
#!/bin/bash
source pc.txt
snp_pw=$export_snapshot
export snapshot_pw=snp_pw
echo_time() {
date "+%d:%b:%Y:%H:%M:%S"
}
# Export Snapshot
echo "$(echo_time) :STARTING EXPORT SNAPPSHOT SCRIPT" | tee -a ${mail_log}
loop_var=3
echo "$(echo_time) :ON FAILURE TRY AT MAX ${loop_var} ATTEMPTS" | tee -a ${mail_log}
i=1
while [ "${loop_var}" -gt 0 ]; do
expect <(cat << 'EOD'
spawn $::env(Snp_Script_Path)/export_service_instance.sh bootstrap Export_Files/test.bar
expect "Enter RPD Password:"
send -- "$::env(snapshot_pw)\r"
expect "Re-enter RPD Password:"
send -- "$::env(snapshot_pw)\r"
interact
EOD
) &> ${export_snapshot_log_location}
ここで直接ハードコードするのではなく、他のファイルの変数からパスワードをどのように読み取ることができますか?
これは間違いなく爆発的になり、両方を期待しています。現在のソースコードを介してファイルを読み込もうとしていますが、$passでパスワードを提供します。しかし、期待どおりに動作しません。
私は何も暗号化/エンコードしたくありません。簡単に保ちたいです。
ベストアンサー1
何が起こっているのか、何が起こるのかわからないが、言うと
export snapshot_pw=snp_pw
環境変数をsnapshot_pw
文字列に設定していますs
n
p
_
p
w
。やりたいかもしれません
export snapshot_pw="$snp_pw"
環境変数をsnapshot_pw
次に設定します。値変数snp_pw
、つまり$snp_pw
。
また、"$mail_log"
引用符なしで使用するシェル変数やその他の変数を引用する必要があります。 ({
およびは必要ありません}
。)