作爲AWS的新手,它基於安裝文檔獲得了Shoryuken gem(帶有活動作業和活動記錄)的曲線。Rails:設置Shoryuken,Active Job和Amazon SQS
中間件:我不知道,如果中間件是建立,因爲它只是在基本的例子產生的必要組成部分。我的理解是正確的,如果您需要在從隊列中提取消息之前或之後執行操作,那麼它很有用。
Shoryuken插入但不能從SQS中提取的消息:在這一點上,Shoryuken被傳遞消息到SQS隊列中,我可以看到這些消息(消息中可見)在AWS控制檯,但Shoryuken不是他們取到即使隊列中沒有任何東西也可以執行。
控制檯
irb(main):003:0> InvitationMailer.send_invite(ii).deliver_later
Enqueued ActionMailer::DeliveryJob (Job ID: 5c65184c-8656-42bd-95ce-e0ded78a9a44) to Shoryuken(development_mailers) with arguments: "InvitationMailer", "send_invite", "deliver_now", gid://projectname/Invitation/25
=> #<ActionMailer::DeliveryJob:0x007f7fad761a40 @arguments=["InvitationMailer", "send_invite", "deliver_now", #<Invitation id: 25, invite_code: "324234325", sender_id: 7, invitee_first_name: "Kylo", invitee_last_name: "Ren", invitee_email: "[email protected]", status: "sent", joined_member_id: nil, created_at: "2016-09-24 03:14:44", updated_at: "2016-09-24 04:16:36", invite_message: nil, sent_at: nil, accepted_at: nil, completed_at: nil, clicked_at: nil, source: nil>], @job_id="5c65184c-8656-42bd-95ce-e0ded78a9a44", @queue_name="development_mailers">
irb(main):004:0> Shoryuken.options
=> {:concurrency=>25, :queues=>[], :aws=>{}, :delay=>0, :timeout=>8, :lifecycle_events=>{:startup=>[], :quiet=>[], :shutdown=>[]}}
irb(main):005:0>
Shoryuken.yml
aws:
access_key_id: <%= ENV['AWS_ACCESS_KEY_ID'] %>
receive_message:
attribute_names:
- ApproximateReceiveCount
- SentTimestamp
region: <%= ENV['AWS_REGION'] %>
secret_access_key: <%= ENV['AWS_SECRET_ACCESS_KEY'] %>
concurrency: 25
delay: 0
queues:
- development_mailers
我會很感激的任何提示,可以幫助我弄清楚爲什麼沒有被檢索和行動的消息由Shoryuken完成。
謝謝!
關於中間件,你能指出我困惑你的文檔嗎? –