Unixコマンドラインを使用した一括IPアドレスルックアップコマンドはUnixシェルでは機能しますが、Linuxシェルでは機能しません。

Unixコマンドラインを使用した一括IPアドレスルックアップコマンドはUnixシェルでは機能しますが、Linuxシェルでは機能しません。
cat ips.txt | xargs -I% curl -s http://ipinfo.io/%/geo > temp.txt

ここで、ips.txt は IP アドレスのリストを 1 行に 1 つずつ含むファイルです。サンプル:

103.240.8.0 
116.236.230.0

これはMacの端末と完全に機能します。

{
"ip": "103.240.8.0",
"city": "Nagpur",
"region": "Maharashtra",
"country": "IN",
"loc": "21.1500,79.1000"
"postal": "440002"
}

{
"ip": "116.236.230.0",
city": "Shanghai",
"region": "Shanghai",
"country": "CN",
"loc": "31.0456,121.3997"
"postal": "440002"
}

しかし、Linuxとcygwinの両方で次のエラーが発生します。

xargs: curl: No such file or directory

助けてください!

答え1

カールがインストールされている場合は、Linuxで実行されます。または試してみてください

xargs -I% wget -q -O - http://ipinfo.io/%/geo <ips.txt >temp.txt

答え2

より迅速な処理のためにGNU Parallelを使用することを検討してください。

cat ips.txt | parallel -j 100 curl -s http://ipinfo.io/{}/geo > temp.txt

また、異なるジョブの出力が混在しないようにするため、2つの異なるジョブから行の半分を取得できないようにします。

GNU Parallelは、同じコンピュータまたはSSHを介してアクセスできる複数のコンピュータでタスクを並列に簡単に実行できる汎用の並列ハンドラです。

4つのCPUで32の異なるジョブを実行する場合は、並列化する簡単な方法は、各CPUで8つのジョブを実行することです。

簡単なスケジューリング

代わりに、GNU Parallel はタスクが完了すると新しいプロセスを作成し、CPU をアクティブに保つことで時間を節約します。

GNU並列スケジューリング

インストールする

セキュリティ上の理由から、パッケージマネージャを使用してGNU Parallelをインストールする必要がありますが、GNU Parallelが展開用にパッケージ化されていない場合は、rootアクセスを必要としないプライベートインストールを実行できます。これは10秒で完了できます。

(wget -O - pi.dk/3 || curl pi.dk/3/ || fetch -o - http://pi.dk/3) | bash

その他のインストールオプションについては、以下を参照してください。http://git.savannah.gnu.org/cgit/parallel.git/tree/README

詳細

より多くの例を見る:http://www.gnu.org/software/parallel/man.html

紹介ビデオを見る:https://www.youtube.com/playlist?list=PL284C9FF2488BC6D1

このチュートリアルを見てください。http://www.gnu.org/software/parallel/parallel_tutorial.html

サポートを受けるには、メールリストに参加してください。https://lists.gnu.org/mailman/listinfo/parallel

関連情報