ホームページ  >  に質問  >  本文

Laravelでcronジョブを使用して大きなCSVファイルをインポートする

<p><strong>Laravel 8</strong> を使用しており、<strong>何十億もの商品の価格を更新したいと考えています</strong>。この コードを追加したところ、正常に動作しました が、 効率的ではなく 、サーバーの 負荷が増加しました 。 </p> <pre class="brush:php;toolbar:false;">試してください { $priceCsvs = PriceCsv::whereStatus(PriceCsv::PENDING)->get(); foreach ($priceCsvs as $price) { dump($price->name." が開始されました"); $csvData = fopen($price->file_url, 'r'); $firstline = true; while (($data = fgetcsv($csvData, 555, ',')) !== false) { if (!$firstline && !empty($data)) { ダンプ($data); } $firstline = false; } fclose($csvData); dump($price->name." は終了です"); } } catch (\Exception $ex) { dump($ex->getMessage()); }</pre> <p><em><strong>ポイントは次のとおりです:</strong></em><strong>CSV ファイル</strong> またはその他のファイルから入力を取得する方法はありますか< ;strong> 1000 回後に睡眠を追加</strong>うまくいきました。 </p>
P粉024986150P粉024986150383日前462

全員に返信(1)返信します

  • P粉242126786

    P粉2421267862023-09-03 10:50:36

    人材紹介の仕事をお探しの場合は、

    をご覧ください。

    タスクのスケジュール設定

    基本的には、いくつかのコンソール (アーティザン) コマンドを定義し、コンソール カーネル ファイルでスケジュールします。スケジューラは、artisan を使用して実行され、コマンド (cron ジョブの定義) を 1 分ごとに実行することをお勧めします。カーネルのスケジュール定義が「phpArtisan Schedule:work」コマンドの実行時と一致していれば、ジョブが実行されます。

    返事
    0
  • キャンセル返事