2016-09-30 83 views
1

作爲AWS的新手,它基於安裝文檔獲得了Shoryuken gem(帶有活動作業和活動記錄)的曲線。Rails:設置Shoryuken,Active Job和Amazon SQS

  1. 中間件:我不知道,如果中間件是建立,因爲它只是在基本的例子產生的必要組成部分。我的理解是正確的,如果您需要在從隊列中提取消息之前或之後執行操作,那麼它很有用。

  2. 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完成。

謝謝!

+0

關於中間件,你能指出我困惑你的文檔嗎? –

回答

0

原來,YAML格式不正確。 queues不應該在aws之下,但在同一級別。這裏是正確的版本:

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 
+0

解決方案參考:https://github.com/phstc/shoryuken/issues/253#issuecomment-251468159 –