タグ付けされた質問 「amazon-sqs」


11
SNS-SQSではなくAmazon Kinesisを使用する必要があるのはなぜですか?
データのストリームが来て、同じペースで消費することができず、バッファーが必要になるユースケースがあります。これは、SNS-SQSキューを使用して解決できます。キネシスが同じ目的を解決することを知ったので、違いは何ですか?なぜKinesisを好む(または好まない)べきですか?

9
Amazon SQSでメッセージをDLQから移動する最良の方法は?
メッセージをデッドレターキューからAmazonSQSの元のキューに戻すためのベストプラクティスは何ですか? それでしょうか DLQからメッセージを取得する キューにメッセージを書き込む DLQからメッセージを削除します それとももっと簡単な方法はありますか? また、AWSは最終的にコンソールにメッセージをDLQから移動するためのツールを備えていますか?

4
SQSとRabbitMQ
処理用のキューを作成する必要があります。キュー自体は比較的少量です。1時間あたり約1,000回の書き込みがある可能性があります。各タスクの実行にはそれぞれ約1分かかる場合があり、アイテムがキューに追加されるとほぼすぐに処理されます。 Amazon SQSのような既成のものではなく、RabbitMQを実装したい理由はありますか?アプリケーションがSQSのようなものではなく独自のキューイングシステムを必要とする理由は何ですか?

3
SQS maxNumberOfMessages
Javaクライアントアプリケーションを使用して、SQSキューにメッセージを照会しています。キューには、テスト用のセットアップとして12,000メッセージがあります。私はaws-java-sdk最新(software.amazon.awssdk 2.10.62)でopenJDKを使用しています。pom.xmlはさらに下に表示されます。 私が目にしている問題は、maxNumberOfMessages(10)を設定しても3しか得られないということです。これは最大数であり、メッセージ数を保証するものではないことを理解していますが、返されるメッセージ数に揺らぎはありません。常に3です。 AWSドキュメント: MaxNumberOfMessages返されるメッセージの最大数。Amazon SQSがこの値を超えるメッセージを返すことはありません(ただし、返されるメッセージが少ない場合があります)。有効な値:1〜10。デフォルト:1。タイプ:整数必須:いいえ ショートポーリングを使用したメッセージの消費 ショートポーリングを使用してキューからメッセージを消費すると、Amazon SQSはそのサーバーのサブセットを(重み付けランダム分布に基づいて)サンプリングし、それらのサーバーからのみメッセージを返します。したがって、特定のReceiveMessageリクエストがすべてのメッセージを返さない場合があります。ただし、キュー内のメッセージが1,000未満の場合、後続のリクエストはメッセージを返します。キューから消費し続けると、Amazon SQSがそのすべてのサーバーをサンプリングし、すべてのメッセージを受信します。 したがって、古いaws sdkと新しいaws sdkの両方を使用して、Javaで2つのクライアントをテストしたところ、同じ結果が得られました。常に3つのメッセージのみが返されます。 興味深いことに、アプリケーションを外部(私の強力なデスクトップ上)で実行する代わりに、AWS Lambdaとして実行すると、10のメッセージが表示されます。このラムダテストは、同僚がJavaScriptを使用して行ったものです。 したがって、疑問が残るのは、なぜ要求ごとに3つのメッセージしか取得せず、ラムダ内で10を取得できるように見えるのかということです。 リクエストあたりのコストがあるとすると、Amazonの利益に基づいて重み付けされたランダム分布になります=)) SQSテスト方法: public void SQStart() { AwsBasicCredentials awsCreds = AwsBasicCredentials.create("accessKeyID", "secretKeyID"); AwsCredentialsProvider creds = StaticCredentialsProvider.create(awsCreds); SqsClient sqs = SqsClient.builder().credentialsProvider(creds).region(Region.EU_WEST_1).build(); GetQueueUrlRequest getQueueRequest = GetQueueUrlRequest.builder() .queueName(QUEUE_NAME) .build(); String queueUrl = sqs.getQueueUrl(getQueueRequest).queueUrl(); for (int x =1; x …
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.