ファイルをキュー(IBM-MQ)から取り出すソリューションを実装します。メッセージは、デキュー、処理、およびアーカイブ(ストア)する必要がある10〜20種類のxmlメッセージになります。しかし、メッセージに含まれているデータをDBに保存する際に、ソースファイルを保持したいので、アーカイブプロセスから生成されるFileIdを保持し、メタデータと共に保存する必要があります。キューからファイルを処理し、アーカイブしてDBに格納する
私は最もスループットの高いものを見つけようとしていますか?
要件:
- は、ファイルのアーカイブを保管してください。
- メッセージから解析されたデータ(xmlブロブではありません)を保存します。
- アーカイブからソースファイルIDを保持します。
- スケールが大幅に拡大する可能性があるソリューションを実装してください....現在、おそらく1時間に40-50,000件のメッセージがあります。
基本的に私の現在のボトルネックは、アーカイブプロセスとデータ処理/ dbのロードがシリアルである(アーカイブが処理され、XML解析/ロードを開始する前に成功していると思われます).....これを達成するためのより良い方法があるかどうかは分かりませんでした。
同じキューでリッスンする他のアプリケーションサーバーを追加して、必要に応じてメッセージを並行して処理できるとします。可能な限り処理を実行することで、DBをボトルネックとして排除しようとします(xml blobをDBに送ることはできますが、XMLシュレッディングを実行する必要があります)。
この質問に答えるには、XMLファイルのサイズが "処理される"必要があることを知る必要があります。 – Brannon