11
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

リクルート ICT統括室Advent Calendar 2023

Day 3

Slack/Teamsを利用して5万人向けの通知システムを作ってみた

Posted at

この記事は リクルート ICT統括室 Advent Calendar 2023 3日目の記事です。

はじめに

はじめまして!ICT統括室 WEBエンジニアリンググループの山川 良太です。
社内向けシステムの開発・ディレクションを担当しています。この記事では Slack/Teamsを利用して社内に通知するシステムを構築した時に得た知見やハマりポイントを共有します。

この記事で伝えたいこと

  • Slack/Teams通知の実装に利用するAPIについて
  • Slack/TeamsのAPIで通知を実装する際に考慮した方が良い事

背景

毎日たくさん送られてくるメール。みなさんしっかり中身確認していますか?
・自分には関係ないメールばかり届く。「そんなメールきてた?」埋もれて気づかなかった。
・SlackやTeamsなら毎日業務で見ている。けれどメールはほとんど見ていない。
・個別メンション以外の通知は切っている。個人へメンションして欲しい。
必要な人に・いつも使っているツールへ・わかりやすく通知を送りたい。そんな思いからSlack/Teamsでの通知システム開発がはじまりました。

構成

今回、構成についてはあまり触れないので簡単な構成図のみ添付します。

  • サーバーサイド
    • Ruby on Rails
  • データベース
    • Redis
    • RDS
  • キューイングライブラリ
    • Sidekiq

st-ページ2.drawio.png

通知実装に利用するAPI

Slack

Slackで個別にメッセージを送信する処理を実装するにはSlack Botを利用します。実装・通知を行う前にSlack Appを作成してください。(参考)

Teams

Teamsで個別にメッセージを送信する処理を実装するにはTeams Botを利用します。

Botアプリを事前に作成し、通知を送信するユーザーに対してインストールする必要があります。
※ Microsoft 365 テナント管理者の場合はテナント内のユーザーに対して自動でインストールする設定を行う事が出来ます。

その他API制約の確認

実際にAPIを利用する上で、制約などを確認する必要があります。
APIコールのRate Limitに達してしまったり、他の要因によりAPIコールが成功しなかった場合には適切にリトライ・スキップ処理を行う必要があります。

Slack

Slackについては、こちらのページ で詳細が確認できます。
基本的に 1 Slack App あたり1件/秒 しかメッセージを投稿するAPIをコールする事が出来ません。

Teams

TeamsではAPIコールの前に認証フローを通す必要があり、アクセストークン取得APIを用いてアクセストークンを取得します。

なお、アクセストークンには有効期限が設定されているので、有効期限切れや何らかのエラーなどでアクセストークンが無効になった際には取り直す処理の実装が必要になります。(参考)

また、APIの最大リクエスト可能数として1 Teams Bot あたり 50 件/秒 という制約があります。ただし、利用するAPIやそのコール方法によってレートリミットが変わるためこちらのページのRate Limit 節を確認しながら実際の開発は行う必要があります。

リトライ処理について

Slack / Teams のAPI制約とは別にリトライ処理として以下の内容を考慮する必要があります。

  • HTTPステータスコード 408(Request Timeout) が返却された
  • 何らかの理由でコネクションが確立できなかった
  • Exponential Backoff 設定の追加
    • 失敗回数が増えるに連れて再送信するまでの待ち時間を指数関数的に増やす仕組み(参考)
    • AWSを利用する場合はAWS DNSのレートリミット(参考)

Slack

  • 特定のHTTPステータスコードでリトライ
    • 429(Too Many Requests)
    • Retry-After ヘッダーが返却された場合はそこに指示されている秒数だけ処理を止める(参考)

Teams

  • 特定のHTTPステータスコードでリトライ
    • 412(Precondition Failed), 429(Too Many Requests), 502(Bad Gateway), 504(Gateway Timeout)
    • 429以外にも指定のステータスコードでリトライする必要がある(参考)

通知を送信するにあたって考慮したポイント

  • 非同期処理を行いたい
    • Sidekiq(キューイングライブラリ) を使った
  • 素早く送りたい
    • Parallel(並列処理を行うライブラリ)を使った
  • 送信制限を超えないように通知を送る必要がある
    • Slack送信JobとTeams送信Jobがそれぞれ同時に実行されると送信制限を超える可能性があった
      • それぞれのJobごとに直列で実行するように設定を行った
    • 並列実行しているためコネクションプール数が足りなくなる可能性があった
      • 並列処理で動くスレッド数分を設定に追加した
  • Slackの送信速度を上げる必要があった
    • 並列処理のスレッドごとに Slack App を割り当てて高速化した

まとめ

ここにまとめたことは公式のAPI Documentなどに記載されていることなので、何か目新しいところというのはありません。とはいえ日頃検索で見つけた記事を鵜呑みにして、バージョン違いであったり、間違った情報のせいで思わぬ落とし穴にハマることがあります。

面白くわかりやすく書いてくれている記事は本当にありがたいですが、まずは腰を据えて公式のドキュメントを読むことができる素直なエンジニアでありたいと思っています。

リクルート ICT統括室 Advent Calendar 2023では、リクルートの社内ICTに関する記事を投稿していく予定です。もし興味があれば、ぜひ他の記事もあわせてご参照ください。

11
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
11
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?