-1

Как мы можем использовать curl для одновременной загрузки нескольких файлов? Даже если нам нужно запустить несколько процессов curl, как я могу сделать это из командной строки или функции оболочки? Например:

$ multiCurl <download 1> <download 2> <download 3>

multiCurl () {
  curl <download 1>
  curl <download 2>
  curl <download 3>
}

или же

for link in $(cat download.list); do
  curl <link 1>
  curl <link 2>
  curl <link 3>
  curl <link 4>
done

2 ответа2

0

Может быть, вы можете использовать команду parallel для одновременной загрузки нескольких файлов.

Здесь я предполагаю, что вы зарезервировали оригинальное имя файла

#!/usr/bin/env bash

funcDownloadOperation(){
    link="${1:-}"
    curl -fsSL -O "${link}"
    if [[ -s "${link##*/}" ]]; then
        echo "file ${link##*/} download successfully!"
    else
        echo "fail to download link ${link}"
    fi
}

export -f funcDownloadOperation
cat download.list | parallel -k -j 0 funcDownloadOperation

Вам нужно установить parallel утилиту вручную в вашей системе Linux.

-1

Просто добавьте & в конце каждой команды, чтобы она выполнялась в фоновом режиме:

curl <link 1>&

После этого все зависит от того, хотите ли вы знать, когда заканчиваются эти команды и каков их код возврата. Если это так, вы хотите попробовать что-то вроде:

set -a pids # Array of the process ids of background commands
for url in $whatever_the_list_of_urls 
do
    curl $url&  # start CURL in background
    pids[${#pids[*]}]=$! # remember PID 
done

# all started, now wait for them
for pid in ${pids[*]}
do
    wait $pid 
    print "Sensed end of $pid, rc:=$?"
done

Всё ещё ищете ответ? Посмотрите другие вопросы с метками .