Rumah >pembangunan bahagian belakang >Tutorial Python >Eksperimen dengan antara muka AI Chainlit dengan RAG pada Upsun
Chainlit: Rangka Kerja AI Perbualan Boleh Skala
Chainlit ialah rangka kerja Python tak segerak sumber terbuka yang direka untuk membina aplikasi AI perbualan yang teguh dan berskala. Ia menawarkan asas yang fleksibel, membolehkan pembangun menyepadukan API luaran, logik tersuai dan model tempatan dengan lancar.
Tutorial ini menunjukkan dua pelaksanaan Retrieval Augmented Generation (RAG) dalam Chainlit:
Persediaan Rantaian Tempatan
Buat persekitaran maya:
<code class="language-bash">mkdir chainlit && cd chainlit python3 -m venv venv source venv/bin/activate</code>
Pasang pakej yang diperlukan dan simpan kebergantungan:
<code class="language-bash">pip install chainlit pip install llama_index # For implementation #2 pip install openai pip freeze > requirements.txt</code>
Mulakan Chainlit:
<code class="language-bash">chainlit hello</code>
Akses pemegang tempat di https://www.php.cn/link/2674cea93e3214abce13e072a2dc2ca5
Pengedaran Upsun
Memulakan repositori Git:
<code class="language-bash">git init .</code>
Buat fail .gitignore
:
<code>.env database/** data/** storage/** .chainlit venv __pycache__</code>
Buat projek Upsun menggunakan CLI (ikut gesaan). Upsun akan mengkonfigurasi repositori jauh secara automatik.
Contoh konfigurasi Upsun untuk Chainlit:
<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>
Tetapkan OPENAI_API_KEY
pembolehubah persekitaran melalui Upsun CLI:
<code class="language-bash">upsun variable:create env:OPENAI_API_KEY --value=sk-proj[...]</code>
Komit dan gunakan:
<code class="language-bash">git add . git commit -m "First chainlit example" upsun push</code>
Semak status penempatan. Penggunaan yang berjaya akan menunjukkan Chainlit berjalan pada persekitaran utama anda.
Pelaksanaan 1: Pembantu OpenAI & Fail Dimuat Naik
Pelaksanaan ini menggunakan pembantu OpenAI untuk memproses dokumen yang dimuat naik.
Buat pembantu OpenAI baharu pada Platform OpenAI. Tetapkan arahan sistem, pilih model (dengan format respons teks) dan pastikan suhu rendah (cth., 0.10). Salin ID pembantu (asst_[xxx]
) dan tetapkannya sebagai pembolehubah persekitaran:
<code class="language-bash">upsun variable:create env:OPENAI_ASSISTANT_ID --value=asst_[...]</code>
Muat naik dokumen anda (Markdown diutamakan) kepada pembantu. OpenAI akan mencipta kedai vektor.
Ganti app.py
kandungan dengan kod yang disediakan. Bahagian penting: @cl.on_chat_start
mencipta urutan OpenAI baharu dan @cl.on_message
menghantar mesej pengguna ke urutan dan menstrimkan respons.
Komit dan gunakan perubahan. Uji pembantu.
Pelaksanaan 2: OpenAI llama_index
Pelaksanaan ini menggunakan llama_index untuk pengurusan pengetahuan tempatan dan OpenAI untuk penjanaan respons.
Buat cawangan baharu:
<code class="language-bash">mkdir chainlit && cd chainlit python3 -m venv venv source venv/bin/activate</code>
Buat folder data
dan storage
. Tambahkan pelekap pada konfigurasi Upsun.
Kemas kini app.py
dengan kod llama_index yang disediakan. Kod ini memuatkan dokumen, mencipta VectorStoreIndex dan menggunakannya untuk menjawab pertanyaan melalui OpenAI.
Letakkan persekitaran baharu dan muat naik folder data
. Uji aplikasi.
Bonus: Pengesahan
Tambahkan pengesahan menggunakan pangkalan data SQLite.
Buat folder database
dan tambah pelekap pada konfigurasi Upsun. Cipta pembolehubah persekitaran untuk laluan pangkalan data:
<code class="language-bash">pip install chainlit pip install llama_index # For implementation #2 pip install openai pip freeze > requirements.txt</code>
Tambah logik pengesahan pada app.py
menggunakan @cl.password_auth_callback
. Ini menambah borang log masuk.
Buat skrip untuk menjana kata laluan cincang. Tambahkan pengguna ke pangkalan data (menggunakan kata laluan cincang). Gunakan pengesahan dan log masuk ujian.
Kesimpulan
Tutorial ini menunjukkan penggunaan aplikasi Chainlit pada Upsun dengan dua pelaksanaan dan pengesahan RAG. Seni bina yang fleksibel membolehkan pelbagai penyesuaian dan penyepaduan.
Atas ialah kandungan terperinci Eksperimen dengan antara muka AI Chainlit dengan RAG pada Upsun. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!