Đây là một tập lệnh đơn giản chạy nvidia-smi
lệnh trên nhiều máy chủ và lưu kết quả đầu ra của nó vào một tệp chung. Mục tiêu ở đây là làm cho nó chạy không đồng bộ .
Là &
ở cuối của process_host()
chức năng gọi đủ? Kịch bản của tôi có đúng không?
#!/bin/bash
HOSTS=(host1 host2 host3)
OUTPUT_FILE=nvidia_smi.txt
rm $OUTPUT_FILE
process_host() {
host=$1
echo "Processing" $host
output=`ssh ${host} nvidia-smi`
echo ${host} >> $OUTPUT_FILE
echo "$output" >> $OUTPUT_FILE
}
for host in ${HOSTS[@]}; do
process_host ${host} &
done;
wait
cat $OUTPUT_FILE