Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Bedrock × Confluenceで簡単(?)社内RAG
Search
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
iharu
April 21, 2025
Programming
1.1k
1
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
Bedrock × Confluenceで簡単(?)社内RAG
登壇資料
JAWS-UG東京 ランチタイムLT会 #22
https://jawsug.connpass.com/event/349480/
iharu
April 21, 2025
More Decks by iharu
See All by iharu
Skill Builderチームサブスクリプション 導入してみた
iharuoru
0
300
S3静的ホスティング+Next.js静的エクスポート で格安webアプリ構築
iharuoru
0
450
Other Decks in Programming
See All in Programming
「エンジニアインターン、どうやって取った?」準備のリアルを語るLT会 Progate BAR
akiomatic
0
120
LLM本来の能力を解き放つサンドボックス技術とAI民主化への適用
yukukotani
3
3.1k
These Five Tricks Can Make Your Apps Greener, Cheaper, & Nicer
hollycummins
0
280
気づいたらRubyで100作品 ー クリエイティブコーディングが生活の一部になるまで / 100 Ruby Sketches Later: How Creative Coding Became Part of My Life
chobishiba
3
550
Old Dog, New Tricks: The Java 25 Reinvention - JNation
bazlur_rahman
0
150
net-httpのHTTP/2対応について
naruse
0
450
軽量Java基盤の設計 DIコンテナに頼らない、長期保守と1秒起動の実現 JJUG CCC 2026 Spring
macha64
0
460
決定論的オーケストレーションの設計と実装 / Design and Implementation of Deterministic Orchestration
nrslib
3
1.2k
tsserverとは何だったのか、これからどうなるのか
nowaki28
1
450
エージェンティックRAGにAWSで入門しよう!
har1101
8
1.2k
コンテキストの使い捨てをやめる — ビジネスルール駆動開発と miko —
ioki
0
150
Lemonade + Foundry Toolkit でお手軽アプリ開発
seosoft
1
310
Featured
See All Featured
Writing Fast Ruby
sferik
630
63k
Making the Leap to Tech Lead
cromwellryan
135
9.9k
[Rails World 2023 - Day 1 Closing Keynote] - The Magic of Rails
eileencodes
38
2.9k
Digital Projects Gone Horribly Wrong (And the UX Pros Who Still Save the Day) - Dean Schuster
uxyall
0
1.6k
WENDY [Excerpt]
tessaabrams
11
38k
A Guide to Academic Writing Using Generative AI - A Workshop
ks91
PRO
1
320
Agile Actions for Facilitating Distributed Teams - ADO2019
mkilby
0
200
My Coaching Mixtape
mlcsv
0
140
Building Applications with DynamoDB
mza
96
7.1k
How to build an LLM SEO readiness audit: a practical framework
nmsamuel
1
770
Measuring & Analyzing Core Web Vitals
bluesmoon
9
860
The Language of Interfaces
destraynor
162
27k
Transcript
Bedrock × Confluence で簡単(?) 社内RAG Slack Bolt でアプリ実装 JAWS-UG 東京
ランチタイムLT 会 #22 haruka takai (@iharuoru) 1
自己紹介 Takai Haruka 株式会社Ridge-i AI アプリエンジニア(Python, LangChain ) X, Zenn
(@iharuoru ) AWS 初心者なので間違えている点は遠慮なくご指摘ください! 2
LT の目的 3
社内RAG を簡単に作りたい Amazon Bedrock の活用 ナレッジベースのConfluence 接続で簡単・セキュアにRAG 構築 アプリ・インフラ構築の実践 Slack
Bolt でアプリ実装 LT の目的 4
アーキテクチャ Bedrock ナレッジベースでConfluence のRAG 構築 Lambda でSlack アプリを構築 LT の目的
5
目次 1. Bedrock まわりのおさらい 2. Knowledge Bases 構築 3. 余談:AWS
Chatbot について 4. Bedrock SDK 実装 5. Slack アプリの設定 6. Slack Bolt 実装 LT の目的 6
Bedrock まわりのおさらい 7
Amazon Bedrock とは? 複数の基盤モデルを統一的なAPI で利用できるマネージドサービス 主な特徴 複数のAI モデルを利用可能 サーバーレスで利用可能 Knowledge
Bases でRAG 構築 (最近盛り上がってるエージェントやフローはキャッチアップできておらず) Bedrock まわりのおさらい 8
Knowledge Bases とは? Bedrock の機能の1 つで、簡単にRAG を実装できるサービス 主な特徴 複数のデータソースから自動取り込み ベクトルDB
・グラフDB の自動構築 引用元へのリンク付き回答生成 参考:Amazon Bedrock Knowledge Base “ “ Bedrock まわりのおさらい 9
Confluence 接続 Knowledge Bases のデータソース接続の1 つ(2024/7 ~プレビュー中) 主な特徴 メインドキュメントフィールドの自動検出 包含/
除外コンテンツフィルター 追加、更新、削除されたコンテンツの増分同期 参考:Amazon Bedrock のナレッジベースが追加のデータソース のサポートを開始 ( プレビュー版) “ “ Bedrock まわりのおさらい 10
Confluence 接続 実際のRAG 作成の流れ データソースを指定(Confluence など) Bedrock の埋め込みモデルを指定(Titan Text Embeddings
v2 など) 埋め込みモデルからOpenSearch にインデックスが作成 Bedrock まわりのおさらい 11
Knowledge Bases 構築 12
Confluence API トークンの取得 参考:Atlassian アカウントの API トークンを管理する “ “ Knowledge
Bases 構築 13
Secrets Manager へ登録 参考:ナレッジベースの Confluence に接続する “ “ Knowledge Bases
構築 14
Knowledge Bases の作成 データソースを選択 Knowledge Bases 構築 15
Knowledge Bases の作成 Confluence URL を入力 Knowledge Bases 構築 16
Knowledge Bases の作成 Confluence のAPI トークンを入れたシークレットを指定 Knowledge Bases 構築 17
Knowledge Bases の作成 お好きな埋め込みモデルを選択 ナレッジベースを作成 を押してしばらく待つ Knowledge Bases 構築 18
Knowledge Bases の作成 リソースは作成されましたが、まだデータは取り込まれていません データソースを選択して 同期 を押す モデルアクセスがない場合エラーになるので確認しましょう:Model access Knowledge
Bases 構築 19
Knowledge Bases の動作確認 ナレッジベースをテスト から確認( 回答を生成 をオフでベクトル検索のみ) Confluence のページ Knowledge
Bases 構築 20
余談:AWS Chatbot について 21
これまでのお話 Knowledge Bases ができたので後は使えるようにしたい 普段使っているSlack に連携したら便利 Slack アプリを開発 Slack Bolt
LT 作成中に気づいたのですが、もっと簡単な方法がありました ノーコードでBedrock とSlack を連携 AWS Chatbot 参考:AWS Chatbot が Microsoft Teams や Slack からの Amazon Bedrock エージェントとのやり取りに対応 “ “ 余談:AWS Chatbot について 22
AWS Chatbot とSlack Bolt の比較 項目 AWS Chatbot Slack Bolt
開発方法 ノーコード Python, TypeScript リソース AWS Chatbot, Bedrock エージェント Slack アプリ, Lambda, API Gateway 接続方法 aws のSlack アプリ追加 作成したSlack アプリ追加 呼出方法 @Amazon Q ask {params} 任意(DM, メンション等) UI 機能 テキストのみ Block Kit で拡張可能 権限管理 AWS IAM Slack Permission scopes 余談:AWS Chatbot について 23
ここからのお話 以下の理由で、今回はSlack Bolt を使用 コマンドを使わずアプリを呼び出したい インタラクティブなUI を実現したい タイトルが 簡単(?) となっているのは、コーディングが必要なため
余談:AWS Chatbot について 24
Bedrock SDK 実装 25
パッケージのインストール npm install @aws-sdk/client-bedrock-agent-runtime 環境変数の設定 KNOWLEDGE_BASE_ID=xxx # ナレッジベースID: ベクトル検索で使うナレッジベースを指定 MODEL_ARN=arn:aws:bedrock:...
# モデルARN: 回答生成で使うモデルを指定 Bedrock SDK 実装 26
クライアントの初期化 import { BedrockAgentRuntimeClient } from "@aws-sdk/client-bedrock-agent-runtime"; const bedrockClient =
new BedrockAgentRuntimeClient({ region: "us-west-2" // Bedrockが利用可能なリージョン }); 参考:AWS SDK for JavaScript v3 “ “ Bedrock SDK 実装 27
RAG の設定 RetrieveAndGenerate タイプを使用 const ragConfig = { // ナレッジベースのRAG(ベクトル検索+回答生成)を使用
type: RetrieveAndGenerateType.KNOWLEDGE_BASE, // 環境変数からナレッジベースID・モデルARNを設定 knowledgeBaseConfiguration: { knowledgeBaseId: KNOWLEDGE_BASE_ID, modelArn: MODEL_ARN, }, }; Bedrock SDK 実装 28
RAG の実行 RetrieveAndGenerate コマンドを使用 const command = new RetrieveAndGenerateCommand({ //
query: strをinputに渡す input: { text: query }, retrieveAndGenerateConfiguration: ragConfig }); const response = await bedrockClient.send(command); Bedrock SDK 実装 29
レスポンスのフォーマットについて output にはテキスト出力 citations には引用情報 が含まれている start , url ,
x-amz-bedrock-kb-title ( metadata に含まれる)を使うことで 引用を差し込むことができる # 実際はjson(紙面上yamlにしています) citations: - generatedResponsePart: textResponsePart: span: end: <number> # 終了位置(数値) start: <number> # 開始位置(数値) text: "<string>" # テキスト内容 retrievedReferences: - location: confluenceLocation: url: "<string>" # ConfluenceのURL metadata: # メタデータ(キーは任意、値はJSON形式) "<string>": <JSON value> output: text: "<string>" # 全体のテキスト出力 Bedrock SDK 実装 30
Slack アプリの設定 31
アプリの作成 基本設定 api.slack.com でアプリを作成 From scratch オプションを選択 アプリ名とワークスペースを設定 アプリをワークスペースにインストール 参考:Quickstart
“ “ Slack アプリの設定 32
権限の設定 必要なスコープ app_mentions:read メンションの読み取り chat:write メッセージの送信 im:history DM の履歴閲覧 im:write
DM の送信 設定手順 OAuth & Permissions ページで 設定 Bot Token Scopes に追加 Slack アプリの設定 33
イベントの設定 アプリがメッセージに反応するようにする Enable Events をオン Request URL を設定 API Gateway
のエンドポイントを指定 イベントのサブスクリプションを選択 message.group : グループメッセージ message.im : DM Slack アプリの設定 34
インタラクティブの設定 アプリがボタンに反応するようにする Interactivity をオン Request URL を設定 API Gateway のエンドポイントを指定
Slack アプリの設定 35
Slack Bolt 実装 36
パッケージのインストール npm install @slack/bolt アプリの初期化 const app = new App({
token: process.env.SLACK_BOT_TOKEN, signingSecret: process.env.SLACK_SIGNING_SECRET }); 参考:リファレンス(App インターフェイスと設定) “ “ Slack Bolt 実装 37
メッセージリスナー app.message : 正規表現 pattern にマッチしたメッセージを受け取ったときの処理が かける say : レスポンスを返せる
app.message(pattern, async ({ message, say }: { message: any, say: SayFn }) => { response // strやslack block形式 await say(response); }); Slack Bolt 実装 38
ブロックを使ったレスポンス json 形式でメッセージやリンク, ボタン を表示することができる ブロックを試すこともできます { "blocks": [ {
"type": "section", "text": { "type": "mrkdwn", "text": "ナレッジベースの回答がここに入る(<example.com|引用>)" } }, { "type": "actions", "elements": [ { "type": "button", "text": { "type": "plain_text", "text": " " }, "action_id": "feedback_good" } // feedback_badも同様 ] } ] } 参考:Block Kit Builder “ “ Slack Bolt 実装 39
アクションリスナー app.action : ボタンクリックなどインタラクティブなアクションがあ った時の処理がかける app.action('feedback_good', async ({ ack, body
}) => { await ack(); // フィードバック処理 // DynamoDBに保存するなど }); Slack Bolt 実装 40
ミドルウェア app.use を使うと、リスナーの前にしたい処理がかける app.use(async ({ payload, context, next, client })
=> { isAllowed: bool // 特定のチャンネルに入っているメンバー、などの条件 if isAllowed { await next(); // リスナーの処理に進む } }); 参考:グローバルミドルウェア “ “ Slack Bolt 実装 41
Lambda ハンドラー Slack アプリでは3 秒以 内にレスポンスがない とリトライしてしまう ため、リトライ時は何 もしないといった処理 も必要
import { App, AwsLambdaReceiver } from '@slack/bolt'; export const handler = async (event: any, context: any, callback: any) => { // lambda用レシーバーの初期化 const awsLambdaReceiver = new AwsLambdaReceiver({ signingSecret: process.env.SLACK_SIGNING_SECRET, }); // アプリの初期化 const app = new App({ token: process.env.SLACK_BOT_TOKEN, receiver: awsLambdaReceiver, }); // app.messageやapp.actionなどのリスナーを追加 // レスポンスを返却 const handler = await awsLambdaReceiver.start(); return await handler(event, context, callback); }; Slack Bolt 実装 42
まとめ 43
所感 ナレッジベースとConfluence の連携はかなり簡単 Slack とBedrock の連携は簡単ではない 生成AI でなんとか初心者でもBolt をかけた 今回紹介できなかったインフラもCDK
と生成AI で簡単にできる 改善ポイント はやりのMCP でもっとBedrock 主体に実装できるかも? まとめ 44