はじめに
会社で生成AIの検証と活用方法を見出す業務を担当することになり、色々と生成AIに関するサービスや活用事例を調べていたのですが、丁度住んでいる札幌でAWSの生成AIサービスの紹介とハンズオンするイベントがあったので、参加してきました。
AWS Bedrockのアプリケーション構築入門
こちらの説明は株式会社Fusic(フュージック)の清家 史郎さん(@seike460)より。
Amazon Bedrockは、Al21Labs、Anthropic。Cohere、Meta、Stability AI、Amazonなどの大手AI企業が提供する高性能な基板モデル(FM)を単一のAPIで選択できるフルマネージド型のサービス。
ここでのセッションはAPI Gateway経由でAWS LambdaからBoto3を利用してAWS Bedrockを利用するシンプルなアプリケーションの構築。
AWSのIDEサービス Cloud 9からAWS SAM(Serverless Application Model
Serverlessの開発とデプロイを簡素化するフレームワーク)を利用してデプロイを実施するというもの。
参加者各自に割り当てられたアカウントを利用してデプロイまでの手順を実施。
詳細は割愛するが、実際のアウトプット以下の通り。
サンプルのHTMLからAPI Gateway経由でLambdaをキックし、Bedrockへ質問を投げて、回答が得られるというもの。
実際に使うにはもっと配慮しないといけないのだろうけど、意外と簡単に使用できることがとても良い。
Knowledge Bases for Amazon Bedrock を組み込む
こちらはNECソリューションイノベータ株式会社佐々木 航太(Kota Sasaki)さん、近藤 恭史(Takafumi Kondo)さんより。
上記で作成したBedrockを利用したアプリケーションに、検索拡張(RAG)の仕組みを構築/導入する機能 Knowledge Basesを追加する。
要するにAmazon Bedrockに企業の独自データを生成(検索)対象にできる仕組みというものらしい。これありきのBedrockのような気がする。
Knowledge Baseの利用は今回はS3に、独自のマニュアルを入れて、それに関する質問が来たら、内容が返ってくるというもの。
ナレッジの蓄積
予めS3バケットを作成し、そこにマニュアルのWordファイルをアップロードする。
ここまででナレッジの蓄積は完了。
Knowledge Bases作成
Knowledge Basesを作成し、S3バケットにアップロードしたデータとSyncさせてナレッジを活用できるようにする。
ここからナレッジのデータソースをセットアップする。
途中経過割愛するが、S3に格納したナレッジデータをKnowledge Basesに同期させる。Knowledge base IDは後でLambda layerからキックする際に必要となる。
他実施したこととしては
- BedrockにアクセスするためのIAMの作成。今回はAmazonBedrockFullAccessを指定。
- BedrockをキックするためのLambdaを作成。
- Lambdaのタイムアウト値をデフォルトの3秒から30秒に伸ばす。Bedrockのレスポンスが3秒だと短すぎるため。
- API Gatewayに作成したLambdaの紐づけ。
個人的にここまでの過程が早く、実際の動作を確認するに至らず…。
しかし、Bedrockの肝要であるS3にデータを蓄積して同期を掛けるところについて理解できたのは収穫だった。別途自分のAWS環境で実施してみたいと思う。
Amazon Q を使用したアシスタンスサービス利活用入門
株式会社へプタゴン 立花 拓也さんからのご説明。
Amazon Qは昨年2023年12月のAWS re:Inventでも紹介されたAWS版ChatGPTといったものだという認識だったが、自身のAWS環境や他のサイトをナレッジとして利用が出来るものとのこと。
ハンズオンでは外部サイト(Wikipedia)やS3バケットにアップロードされたファイルをナレッジとして回答を行うことができるという内容だった。
以下、Add data soueceを選択し、各データソースを追加していく。
S3にアップロードしたファイルをデータソースとしても利用可能。
こうすることでデータソースの情報を参照した回答を返すことができる。
回答となる起源をS3をはじめ、他サイトから選ぶのも簡単なので直感的に使いやすい。企業内で利用するのであれば、やはりS3にいかに正確な情報をため込めるかがポイントとなりそう。
LT インフラエンジニアが語る CodeWhisper とAmazon Q を利用した境界線
フォージビジョン株式会社 北原 雅人さんからのご説明。
CodeWhisperの説明はなかったが、Amazon Qについて。
結局ChatGPTとAmazon Qだとどっちが良いんだい?という話。
要点としては
- ChatGPTの方が出力しながら回答。Amazon Qは引用含めて一気に回答出力するので、Amazon Qの方が回答までの所要時間が遅い(印象)。
- 汎用的な質問(天候、地理等)であればどちらもそこまで大差なし。
- Amazon Qの方がAWSサービスだけあり、AWSのベストプラクティスやドキュメントに関する回答をしてくれる。例としてRDS全体を暗号化させたい時にどういう手法だとダウンタイムを最小にして実現できるか、とか、AWS WellArchitectの主要な「柱」の説明に「持続可能性」が含まれているetc。
という内容。
当然かもしれないが、AWSサービスをメインにした回答を得たい場合にAmazon Qを選択するのが最適、ということらしい。
まとめ(所感)
今回のハンズオンに出席しての所感。
- BedrockもAmazon Qも社内利用を想定し業務に関する回答させたい場合はS3にいかに正しく適切なナレッジデータを溜め込んで管理するかがポイント。
- S3に入れておくナレッジデータをどのように正確に、かつ鮮度を高くして保管するか?が重要となるので、業務部門にも協力を求める必要が発生する。
- このナレッジデータの品質を高め、省力化をする仕組みは別問題として検討する必要があり。
- 当然だが、BedrockもAmazon Qもそれを個別に利用するというより、AWSサービスにいかに組み合わせて使用するか?が肝要なので、インフラ周りの設計等はしばらく変わらず残っていくのでは。
ともあれ、「S3にどんどんデータを貯めていけばOK!」という発想は運用設計上シンプルで分かりやすい。得られたノウハウはとても価値あるものでした。
開催・運営いただいた皆様、ありがとうございました!