9
4

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

【UiPath】Azure OpenAI Serviceと連携して安全にGPTを利用する手順

Last updated at Posted at 2024-01-22

はじめに

  • 本記事ではUiPath Automation CloudとAzure OpenAI Serviceを連携する手順について説明します。
  • この連携によって生成AIによる自然言語処理を自動化ワークフローに安全に組み込むことが可能になります。
  • Azure OpenAI Serviceの既定値ではすべてのネットワークからアクセスが許可されていますが、クライアントからのGPTモデルの利用要求はAutomation Cloudによってプロキシできますので、必要な接続のみを許可することによって安全性を高めることができます。

構成図とIntegration Service概要

  • 本記事での構成図を示します。

00a.png

  • GPTモデルを利用するクライアントとしてUiPath StudioまたはUiPath Studio Webを使用します。
  • Integration Service はUiPathがAutomation Cloud上で提供するiPaaS(Integration Platform as a Service)です。さまざまなサードパーティアプリケーションやSaaSの認証と認可を標準化してAPI接続の管理を行い、容易に連携することが可能になります。
  • Integration Serviceを利用するメリットは下記の通りです。
    • Azure OpenAI Serviceの認証情報となるAPIキーをサーバー側で保管するため、クライアント側にAPIキーを保存することによって生じる漏洩リスクを軽減できます。またこのAPIキーはAutomation Cloudに接続しているクライアントのみ利用可能となるため、管理者によって利用ユーザーを制御することができます。
    • クライアントからのGPTモデルの利用要求はIntegration Serviceによってプロキシされるため、Azure OpenAI Serviceのネットワーク設定ではIntegration Serviceからのアクセスのみを許可(IPフィルター)することによって安全性を高められます。

Azure OpenAI Serviceの設定

  • まずAzure OpenAI Serviceを利用するための準備を行います。既にAzureサブスクリプションが準備されていることが前提となります。

事前準備

  1. ブラウザーで Azureポータル にサインインします。

  2. 次にAzure OpenAI Serviceにアクセスします。 (上部の検索フィールドに "openai" と入力してジャンプします)

    01a.png

  3. 作成 をクリックします。

    01b.png

  4. もし作成できない場合には利用するAzureサブスクリプションごとに利用申請が必要となります。https://aka.ms/oai/access のフォームから申請して承認されるまで数日~数週間ほど待ちます。

Azure OpenAI Serviceのリソース作成手順

  • Azure OpenAI Serviceが利用可能であることが確認できましたら実際にリソースを作成します。
  1. Azureポータル > Azure OpenAI Serviceにアクセスし、作成 をクリックします。

  2. 各設定項目を入力します。

    02b.png

    • 既存の リソースグループ を選択するか、新規で作成します。
    • Azure OpenAI Serviceの リージョン を選択します。一般的にはクライアントマシンに近いリージョンとしてJapan Eastなどを選択しますが、リージョンごとに利用できるサービスやモデルが異なります。詳細は Azure OpenAI Service モデル をご参照ください。
    • 名前 はグローバルで一意な名前を入力します。このリソース名は後ほど使用しますのでメモします。
    • 価格レベル として Standard S0 を選択し、次へ をクリックします。
  3. ネットワーク設定は既定値のまま 次へ をクリックします。(後ほど特定IPのみ許可するように変更します)

    03a.png

  4. 必要に応じてタグを指定し、次へ をクリックします。

    04a.png

  5. レビューおよび送信にてチェックが走ります。エラーが発生した場合には内容を確認して修正します。問題なければ 作成 をクリックしてリソースを作成します。

    05b.png

  6. デプロイが成功することを確認します。 リソースに移動 をクリックします。

    06a.png

  7. 左メニューの キーとエンドポイント をクリックし、キー 1 をクリップボードにコピーしてメモします。

    07b.PNG

Azure OpenAI Serviceの簡易動作確認

  1. 簡易的な動作確認のためにブラウザーで Azure OpenAI Studio にアクセスします。サブスクリプションとリソースを選択して リソースの使用 をクリックします。

    08b.PNG

  2. 左メニューの 管理 > デプロイ をクリックし、新しいデプロイの作成 をクリックします。

    09b.png

    • モデルを選択します。今回は gpt-4 を使用します。
    • モデルバージョンを選択します。今回は 0613 を使用します。
    • デプロイ名を入力し、作成 をクリックします。

    10b.PNG

  3. 正常に作成されましたら左メニューの プレイグラウンド > チャット をクリックします。構成として先ほど作成したデプロイが選択されていることを確認します。

  4. チャットセッションにて質問(例: 「自己紹介をして」)を入力して、応答が返ってくることを確認します。

    11b.png

Automation Cloudの設定

  • Automation CloudにてAzure OpenAI Serviceと連携する設定を行います。
  1. ブラウザーで Automation Cloud にサインインします。

  2. 左メニューにて Integration Service のアイコンをクリックします。

    11b.png

  3. 作業対象のOrchestratorフォルダーを選択し、コネクタとして Microsoft Azure OpenAI をクリックします。

    12a.png

  4. Microsoft Azure OpenAI に接続 をクリックします。

  5. 先ほどメモしたAzure OpenAI Serviceのキーとリソース名を入力して、接続 をクリックし、正常に接続できることを確認します。

    12b.png

  • エラーが発生する場合にはキーとリソース名を再確認します。またAzure OpenAI Serviceのリソース作成直後には接続できない場合がありますのでしばらく時間をおいてから再接続します。

Azure OpenAI Serviceのネットワーク設定

  • Azure OpenAI Serviceの既定値ではすべてのネットワークからアクセスが許可されていますので、セキュリティ強化のためAutomation Cloudからのアクセスのみに制限します。
  1. オンプレミス アプリケーション コネクタのサポート にて該当するAutomation CloudのリージョンのIPアドレスを確認し、メモします。コミュニティユーザーの場合には欧州のIPアドレスが使用されます。

  2. Azureポータル > 作成したAzure OpenAI Serviceリソース > ネットワーク をクリックし、選択したネットワークとプライベートエンドポイント を選択します。

    13b.png

  3. 先ほどメモしたIPアドレスをすべて入力し Save をクリックして保存します。

    14b.png

  4. 設定変更が反映されるまで数分ほど待ちます。Automation Cloudにて先ほどコネクションを作成したフォルダーを選択し、コネクションの縦三点リーダー > コネクションを確認 をクリックし、正常に接続できることを確認します。

    20a.png

    • エラーが発生する場合には Azure OpenAI Serviceのネットワーク設定にて Integration Serviceの送信IP が正しく追加されているかを再確認します。

Studio WebからのGPT利用

  • ここまでで準備が整いましたのでUiPath Studio WebからGPTモデルを利用してみましょう!
  1. Automation Cloud の左メニューにて Studio のアイコンをクリックします。

    21a.png

  2. プロジェクト > [新しいプロジェクト] をクリックします。

    22a.png

  3. プロジェクト名と説明を入力して [作成] をクリックします。

    23a.png

  4. プロジェクトが作成されましたら (+) をクリックしてアクティビティを追加します。

  5. チャット補完を生成 を選択します。

    24a.png

    • テキスト補完を生成 はGPT-3, GPT-3.5では使用できますがGPT-4では使用できません。代わりに チャット補完を生成 を使用します。
  6. アクティビティの各項目を設定します。

    15b.png

    • プロンプト に質問内容を記述します。(例: 「UiPath Integration Serviceについて教えて」)
    • モデル はAzure OpenAI Serviceのデプロイ名を選択します。
    • [その他のオプション] にてより細かいパラメーターを指定できます。詳細は チャット補完を生成Azure OpenAI Service の REST API リファレンス をご参照ください。

    26a.png

  7. GPTモデルからの応答を出力するために (+) をクリックし、メッセージをログ アクティビティを追加します。

    27a.png

  8. チャット補完を作成 の出力変数 上位の生成テキスト を選択します。ログレベルは Info を選択します。

    28a.png

  9. テスト をクリックし、ワークフローをテストします。

    16c.png

  10. 質問に対する回答が正常に表示されることを確認します。

    17b.png

StudioからのGPT利用

  • 次にUiPath StudioからGPTモデルを利用してみます。あらかじめStudioをAutomation Cloudに接続しておきます。
  1. Studioを起動しプロジェクトを作成します。対応OSはWindowsまたはクロスプラットフォームを選択します。

    32.png

  2. アクティビティの依存関係を右クリック > 管理 をクリックし、
    Microsoft Azure OpenAI アクティビティをインストールします。

    33.png

  3. Generate Chat Completion(チャット補完を生成) アクティビティを追加し、既定のAzure Open AI コネクションが表示されることを確認します。

    31a.png

  4. アクティビティの各項目を設定します。

    18d.png

    • モデル はAzure OpenAI Serviceのデプロイ名を選択します。
    • プロンプト に質問内容を記述します。(例: 「UiPath Automation Cloudについて教えて」)
    • [プロパティ] にてより細かいパラメーターを指定できます。詳細は チャット補完を生成Azure OpenAI Service の REST API リファレンス をご参照ください。
    • GPTモデルからの応答を出力するために出力 > 上位の生成テキスト に変数(例: genText)を設定します。
  5. メッセージをログ アクティビティを追加し、変数 genText を出力します。

    19c.png

  6. デバッグ実行して質問に対する回答が正常に表示されることを確認します。

    20b.png

  7. 汎用化するために質問文を入力値の引数として渡し、回答文を出力値の引数として受け取ります。またそれぞれをログ出力することによって利用状況を記録することができます。

    22b.png

    40a.png

おわりに

  • このようにAzure OpenAI ServiceとUiPath Automation Cloudを組み合わせて使用することによって、企業向けに安全にGPTモデルを利用し、自動化処理に組み込みできるようになります。ぜひお試しください!
9
4
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
9
4

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?