セロリを使う利点が何であるか理解できません。私はあなたがRedis、RabbitMQなどでCeleryを使うことができることに気が付いていますが、Celeryを前に置くのではなく、メッセージキューサービスのクライアントを直接取得するのはなぜですか?セロリとレディスとレディスとの比較
答えて
Celeryを使用する利点は、主にタスク処理コードを記述する必要があり、タスクプロセッサへのタスク配信の処理がCeleryフレームワークによって処理されることです。タスク処理のスケーリングは、並行性の高いセロリのワーカー(処理スレッド/プロセスのほうが多い)を実行するだけで簡単に実行できます。キューにタスクを送信し、キューからタスクを消費するコードを記述する必要はありません。 また、タスクキューのコンシューマを追加/削除する機能も組み込まれています。フレームワークは、タスクの再試行、障害処理、蓄積された結果などをサポートします。タスク処理ロジックのみの実装に集中するのに役立つ多くの機能を備えています。
ちょうどアナロジーのために、map-reduceプログラムをHadoop上で実行することは非常に複雑な作業ではありません。データが小さければ、簡単なPythonスクリプトを書いてmap-reduceロジックを実装することができます。このロジックは、Hadoop map-reduce Jobが同じデータを処理する性能を上回ります。しかし、データが非常に大きいときは、データを複数のマシンに分割する必要があります。複数のプロセスを複数のマシンで実行し、実行を調整する必要があります。複雑さは、マッパーの複数のインスタンスを実行し、複数のマシン間で減速タスクを実行し、入力を収集し、マッパーに入力を分配し、マッパーの出力を適切な減速装置に転送し、進行を監視し、失敗したタスクを再起動し、ジョブの完了を検出することにあります。 しかし、私たちはHadoopを持っているので、分散ジョブを実行する根本的な複雑さにはほとんど気にする必要はありません。同様にセロリーも主にタスク実行ロジックに集中するのに役立ちます。
- 1. レディスとセロリを最初から再起動するには?
- 2. レディスとカフカの違い
- 3. レディスでの保存とカウント
- 4. レディスのアイテム数
- 5. レディス、モンゴー、ヘーゼルキャスト?
- 6. レディスでのイベントタイムラインの保存
- 7. Laravelのループオーバーコレクションとレディスを使用してキーを保存
- 8. レディスとバックグラウンドタスクのためにResqueを使用する点
- 9. Sentinel経由でセリスとレディスを接続する
- 10. オーム/レディスの動的フィールドの設定
- 11. フラスコのレート制限(レディスなし)
- 12. Rails 5レディスによるアクションケーブルの固定
- 13. レディスの時間制限付きリスト
- 14. Googleアナリティクスとリアルタイムアナリティクスの比較:ChartbeatとClickyとMixpanelの比較
- 15. BufferedOutputStreamとByteArrayOutputStreamとの比較
- 16. OnItemClickListenerとOnItemTouchListenerとの比較
- 17. BroadcastReceiver.getResultsExtra()とIntent.getExtras()との比較
- 18. iosとjsonとの比較
- 19. IDeserializationCallbackとOnDeserializedAttributeとの比較
- 20. React.ComponentとReact.PureComponentとの比較
- 21. mapsqlparametersourceとjava.util.mapとの比較
- 22. NullReferenceExceptionとMSILとの比較
- 23. DataSourceUtils.getConnectionとDataSource.getConnectionとの比較
- 24. FuzzyとSeleniumとの比較
- 25. Display.asyncExecとDisplay.timerExecとの比較
- 26. File.Delete()とFileInfo.Delete()との比較
- 27. PHPとWordPressとの比較
- 28. AXとゼロとの比較
- 29. ELとequalIgnoreCaseとの比較
- 30. HttpContextとHttpListenerContextとの比較
メリットは使用方法に基づいており、結局のところメリットはありません。あなたが小さなシステムを構築しているなら、セロリはあなたにとって役に立たないかもしれません。これは、複数のノードを持つ大規模なシステムに役立ちます。 – ipinak
この質問はこのサイトには適していません。良い、客観的に正当な答えは、解決されている問題の具体的な詳細に依存しますが、可能性のある問題の宇宙全体にフィールドを開いてしまいます。 AとBの問題には問題があります。問題Aはcronジョブ+ Redisではるかに良く解決されますが、問題BにはCelery + Redisを使用するほうが効果的です。セロリーを使用するかどうかは、実際に解決されている問題の詳細によって決まります。 – Louis