ホームページ > バックエンド開発 > Python チュートリアル > Upsun 上の RAG を使用した Chainlit AI インターフェイスの実験

Upsun 上の RAG を使用した Chainlit AI インターフェイスの実験

Patricia Arquette
リリース: 2025-01-21 00:14:14
オリジナル
425 人が閲覧しました

Chainlit: スケーラブルな会話型 AI フレームワーク

Chainlit は、堅牢でスケーラブルな会話型 AI アプリケーションを構築するために設計されたオープンソースの非同期 Python フレームワークです。 柔軟な基盤を提供し、開発者が外部 API、カスタム ロジック、ローカル モデルをシームレスに統合できるようにします。

Experiment with Chainlit AI interface with RAG on Upsun

このチュートリアルでは、Chainlit 内の 2 つの取得拡張生成 (RAG) 実装を示します。

  1. アップロードされたドキュメントで OpenAI アシスタントを活用します。
  2. ローカル ドキュメント フォルダーで llama_index を使用します。

ローカルチェーンライトセットアップ

仮想環境

仮想環境を作成します:

<code class="language-bash">mkdir chainlit && cd chainlit
python3 -m venv venv
source venv/bin/activate</code>
ログイン後にコピー
ログイン後にコピー

依存関係をインストールする

必要なパッケージをインストールし、依存関係を保存します:

<code class="language-bash">pip install chainlit
pip install llama_index  # For implementation #2
pip install openai
pip freeze > requirements.txt</code>
ログイン後にコピー
ログイン後にコピー

Chainlit をテストします

Chainlit を開始します:

<code class="language-bash">chainlit hello</code>
ログイン後にコピー

https://www.php.cn/link/2674cea93e3214abce13e072a2dc2ca5

のプレースホルダーにアクセスします。

Experiment with Chainlit AI interface with RAG on Upsun

アップサンの展開

Git の初期化

Git リポジトリを初期化します:

<code class="language-bash">git init .</code>
ログイン後にコピー

.gitignore ファイルを作成します:

<code>.env
database/**
data/**
storage/**
.chainlit
venv
__pycache__</code>
ログイン後にコピー

アップサンプロジェクトの作成

CLI を使用して Upsun プロジェクトを作成します (プロンプトに従います)。 Upsun はリモート リポジトリを自動的に構成します。

構成

Chainlit の Upsun 構成の例:

<code class="language-yaml">applications:
  chainlit:
    source:
      root: "/"
    type: "python:3.11"
    mounts:
      "/database":
        source: "storage"
        source_path: "database"
      ".files":
        source: "storage"
        source_path: "files"
      "__pycache__":
        source: "storage"
        source_path: "pycache"
      ".chainlit":
        source: "storage"
        source_path: ".chainlit"
    web:
      commands:
        start: "chainlit run app.py --port $PORT --host 0.0.0.0"
      upstream:
        socket_family: tcp
      locations:
        "/":
          passthru: true
        "/public":
          passthru: true
    build:
      flavor: none
    hooks:
      build: |
        set -eux
        pip install -r requirements.txt
      deploy: |
        set -eux
      # post_deploy: |
routes:
  "https://{default}/":
    type: upstream
    upstream: "chainlit:http"
  "https://www.{default}":
    type: redirect
    to: "https://{default}/"</code>
ログイン後にコピー

Upsun CLI を使用して OPENAI_API_KEY 環境変数を設定します。

<code class="language-bash">upsun variable:create env:OPENAI_API_KEY --value=sk-proj[...]</code>
ログイン後にコピー

展開

コミットとデプロイ:

<code class="language-bash">git add .
git commit -m "First chainlit example"
upsun push</code>
ログイン後にコピー

展開ステータスを確認します。 デプロイが成功すると、Chainlit がメイン環境で実行されていることが表示されます。

Experiment with Chainlit AI interface with RAG on Upsun

実装 1: OpenAI アシスタントとアップロードされたファイル

この実装では、OpenAI アシスタントを使用して、アップロードされたドキュメントを処理します。

作成アシスタント

OpenAI プラットフォーム上に新しい OpenAI アシスタントを作成します。システム命令を設定し、モデル (テキスト応答形式) を選択し、温度を低く保ちます (例: 0.10)。 アシスタント ID (asst_[xxx]) をコピーし、環境変数として設定します:

<code class="language-bash">upsun variable:create env:OPENAI_ASSISTANT_ID --value=asst_[...]</code>
ログイン後にコピー

コンテンツのアップロード

ドキュメント (Markdown を推奨) をアシスタントにアップロードします。 OpenAI はベクター ストアを作成します。

Experiment with Chainlit AI interface with RAG on Upsun

Experiment with Chainlit AI interface with RAG on Upsun

アシスタントロジック (app.py)

app.py の内容を提供されたコードに置き換えます。 重要な部分: @cl.on_chat_start は新しい OpenAI スレッドを作成し、@cl.on_message はユーザー メッセージをスレッドに送信し、応答をストリーミングします。

変更をコミットしてデプロイします。アシスタントをテストします。

Experiment with Chainlit AI interface with RAG on Upsun

実装 2: OpenAI llama_index

この実装では、ローカルのナレッジ管理に llama_index を使用し、応答の生成に OpenAI を使用します。

ブランチの作成

新しいブランチを作成します:

<code class="language-bash">mkdir chainlit && cd chainlit
python3 -m venv venv
source venv/bin/activate</code>
ログイン後にコピー
ログイン後にコピー

フォルダーの作成とマウント

data フォルダーと storage フォルダーを作成します。 Upsun 構成にマウントを追加します。

app.py アップデート

提供された llama_index コードで app.py を更新します。 このコードはドキュメントをロードし、VectorStoreIndex を作成し、それを使用して OpenAI 経由でクエリに応答します。

新しい環境をデプロイし、data フォルダーをアップロードします。アプリケーションをテストします。

Experiment with Chainlit AI interface with RAG on Upsun

ボーナス: 認証

SQLite データベースを使用した認証を追加します。

データベースのセットアップ

database フォルダーを作成し、Upsun 構成にマウントを追加します。データベース パスの環境変数を作成します:

<code class="language-bash">pip install chainlit
pip install llama_index  # For implementation #2
pip install openai
pip freeze > requirements.txt</code>
ログイン後にコピー
ログイン後にコピー

認証ロジック (app.py)

app.py を使用して認証ロジックを @cl.password_auth_callback に追加します。 これにより、ログイン フォームが追加されます。

ハッシュされたパスワードを生成するスクリプトを作成します。ユーザーをデータベースに追加します (ハッシュされたパスワードを使用)。認証をデプロイし、ログインをテストします。

Experiment with Chainlit AI interface with RAG on Upsun

結論

このチュートリアルでは、2 つの RAG 実装と認証を使用して、Upsun に Chainlit アプリケーションをデプロイする方法を示しました。 柔軟なアーキテクチャにより、さまざまな適応と統合が可能になります。

以上がUpsun 上の RAG を使用した Chainlit AI インターフェイスの実験の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート