使用 Docker 和 Streamlit 构建和部署 LangChain 支持的聊天应用程序

news2024/11/15 13:49:54

文章目录

  • 前言
  • 聊天应用程序组件和技术
  • LangChain Python框架
  • 开放人工智能模型
  • 前端 Streamlit UI
  • 使用 Docker 进行部署
  • Docker 优化以实现轻量级和快速构建
  • Docker-compose.yaml 文件
  • 基础设施
  • Streamlit 公共云
  • 谷歌应用引擎
  • 使用 Google Cloud Run 部署应用
    • 1.启动服务
    • 2. 创建角色并将其添加到服务帐户
    • 3.生成并推送Docker镜像
  • 结论
  • 🍀小结🍀

🎉博客主页:小智_x0___0x_

🎉欢迎关注:👍点赞🙌收藏✍️留言

🎉系列专栏:小智带你闲聊

🎉代码仓库:小智的代码仓库

前言

本文强调了 Docker 为 AI/ML 项目带来的价值 - 部署的速度和一致性、一次构建并随处运行的能力,以及 Docker Desktop 中提供的可加速整体开发工作流程的省时工具。

在本文中,我们将探索使用 LangChain、OpenAI API 和 Streamlit 框架创建聊天应用程序的过程。我们将演示如何使用 Docker 和Docker Compose在内部或云服务器上轻松部署应用程序。
在这里插入图片描述
我们在 Streamlit 公共云和 Google App Engine 上创建并部署了一个演示应用程序(图 1),以便进行快速预览。
在这里插入图片描述

图 1:聊天应用程序截图:LangChain 演示。

聊天应用程序组件和技术

我们将简要描述用于创建模板应用程序的应用程序组件和框架。

LangChain Python框架

LangChain框架使开发人员能够使用强大的大型语言模型(LLMs)创建应用程序。我们的演示聊天应用程序是基于Python框架构建的,其中OpenAI模型是默认选项。但是,用户可以灵活选择他们喜欢的任何LLM。

LongChain框架轻松管理输入提示,并在LLMs API生成的响应之间建立连接。

开放人工智能模型

出于演示目的,我们使用 OpenAI API 在提交提示时生成响应。

前端 Streamlit UI

Streamlit是一种轻量级且更快的构建和共享数据应用程序的方式。开发了一个带有 Streamlit 框架的简单 UI 来与聊天应用程序交互。

使用 Docker 进行部署

Docker可用于开发应用程序并将其部署到任何服务器,而无需担心依赖项和环境。在演示应用程序开发完成并在本地运行良好后,我们添加了 Docker 支持。

FROM python:3.10-slim-bullseye
 
ENV HOST=0.0.0.0
 
ENV LISTEN_PORT 8080
 
EXPOSE 8080
 
RUN apt-get update && apt-get install -y git
 
COPY ./requirements.txt /app/requirements.txt
 
RUN pip install --no-cache-dir --upgrade -r /app/requirements.txt
 
WORKDIR app/
 
COPY ./demo_app /app/demo_app
COPY ./.streamlit /app/.streamlit
 
CMD ["streamlit", "run", "demo_app/main.py", "--server.port", "8080"]

前面的代码显示了用于生成演示应用程序的 Docker 映像的 Dockerfile 的内容。为了构建图像,我们使用:

docker build -t langchain-chat-app .

Docker 优化以实现轻量级和快速构建

在为企业应用程序部署应用程序时,我们必须注意所利用的资源以及执行/部署生命周期计算。

我们还解决了如何优化 Docker 构建过程以解决镜像大小问题并在每次源代码更改迭代时快速构建的问题。

# 用于构建虚拟环境的构建器镜像
FROM python:3.11-buster as builder
 
RUN apt-get update && apt-get install -y git
 
RUN pip install poetry==1.4.2
 
ENV POETRY_NO_INTERACTION=1 \
POETRY_VIRTUALENVS_IN_PROJECT=1 \
POETRY_VIRTUALENVS_CREATE=1 \
POETRY_CACHE_DIR=/tmp/poetry_cache
 
ENV HOST=0.0.0.0
ENV LISTEN_PORT 8080
EXPOSE 8080
 
WORKDIR /app
 
#COPY pyproject.toml ./app/pyproject.toml
#COPY poetry.lock ./app/poetry.lock
COPY pyproject.toml poetry.lock ./
 
RUN poetry install --without dev --no-root && rm -rf $POETRY_CACHE_DIR
 
# 用于仅运行提供的代码及其虚拟环境的运行时镜像
FROM python:3.11-slim-buster as runtime
 
ENV VIRTUAL_ENV=/app/.venv \
PATH="/app/.venv/bin:$PATH"
 
COPY --from=builder ${VIRTUAL_ENV} ${VIRTUAL_ENV}
 
COPY ./demo_app ./demo_app
COPY ./.streamlit ./.streamlit
 
CMD ["streamlit", "run", "demo_app/main.py", "--server.port", "8080"]

在此 Dockerfile 中,我们有两个运行时映像标签。在第一个中,我们创建一个 Poetry 环境来形成一个虚拟环境。尽管应用程序在第二运行时映像中运行,但应用程序是在激活第一步中创建的虚拟环境后运行的。

接下来,我们将使用 构建 Docker 映像DOCKER_BUILDKIT,它提供了现代工具来快速安全地创建 Docker 映像。

DOCKER_BUILDKIT=1 docker build --target=runtime . -t langchain-chat-app:latest

Docker-compose.yaml 文件

为了运行该应用程序,我们还包含docker-compose.yml以下内容:

version: '3'
services:
langchain-chat-app:
image: langchain-chat-app:latest
build: ./app
command: streamlit run demo_app/main.py --server.port 8080
volumes:
- ./demo_app/:/app/demo_app
ports:
- 8080:8080

要在本地服务器上运行该应用程序,请使用以下命令:

docker-compose up

基础设施

借助对 Docker 的支持,可以按照基本指南将该应用程序部署到任何云基础设施。我们在以下基础设施上部署了该应用程序

Streamlit 公共云

使用 GitHub 帐户和存储库在其公共云上部署 Streamlit 应用程序

谷歌应用引擎

我们尝试使用 Docker 在 Google App Engine 上部署应用程序。该存储库包含一个app.yaml用于部署以下内容的配置文件:

# 使用Dockerfile
runtime: custom
env: flex
# 运行此示例会产生 App Engine 弹性环境的费用。
# 下面的设置是为了在测试期间降低成本,不适用于生产环境。
 
manual_scaling:
instances: 1
resources:
cpu: 1
memory_gb: 0.5
disk_size_gb: 10

为了在 Google App Engine 上部署聊天应用程序,我们在安装 gcloud Python SDK 后使用了以下命令:

gcloud app create --project=[YOUR_PROJECT_ID]
gcloud config set project [YOUR_PROJECT_ID]
gcloud app deploy app.yaml

可以通过以下方式访问部署在 Google App Engine 上的示例应用程序:
在这里插入图片描述

使用 Google Cloud Run 部署应用

我们还可以使用GCP的Cloud Run服务将应用程序部署在Google Cloud上。使用 Cloud Run 部署应用程序比 Google App Engine 更快。

以下是采用该方法的相关特点:

  • 将应用程序打包在容器中。
  • 将容器推送到工件注册表。
  • 从推送的容器部署服务。

让我们逐步了解使用 Google Cloud Run 部署应用程序所遵循的步骤。我们假设已经在 Google Cloud 上创建了一个项目。

1.启动服务

可以使用以下方式启用服务gcloud sdk

gcloud services enable cloudbuild.googleapis.com
gcloud services enable run.googleapis.com

2. 创建角色并将其添加到服务帐户

使用以下命令集,我们创建一个服务帐户并设置适当的权限。修改服务SERVICE_ACCOUNT and PROJECT_ID

gcloud iam service-accounts create langchain-app-cr \
--display-name="langchain-app-cr"
 
gcloud projects add-iam-policy-binding langchain-chat \
--member="serviceAccount:langchain-app-cr@langchain-chat.iam.gserviceaccount.com" \
--role="roles/run.invoker"
 
gcloud projects add-iam-policy-binding langchain-chat \
--member="serviceAccount:langchain-app-cr@langchain-chat.iam.gserviceaccount.com" \
--role="roles/serviceusage.serviceUsageConsumer"
 
gcloud projects add-iam-policy-binding langchain-chat \
--member="serviceAccount:langchain-app-cr@langchain-chat.iam.gserviceaccount.com" \
--role="roles/run.admin"

3.生成并推送Docker镜像

使用以下命令,我们可以生成镜像并将其推送到ArtifactsRegistry。但是,如果这是第一次,我们需要创建具有 Docker 占位符权限的存储库:

DOCKER_BUILDKIT=1 docker build --target=runtime . -t australia-southeast1-docker.pkg.dev/langchain-chat/app/langchain-chat-app:latest
docker push australia-southeast1-docker.pkg.dev/langchain-chat/app/langchain-chat-app:latest

以下是生成工件存储库和分配权限所需的命令:

gcloud auth configure-docker australia-southeast1-docker.pkg.dev
 
gcloud artifacts repositories create app \
--repository-format=docker \
--location=australia-southeast1 \
--description="A Langachain Streamlit App" \
--async

现在将部署该应用程序。

结论

本文深入探讨了开发和部署由 LangChain、OpenAI API 和 Streamlit 提供支持的聊天应用程序所需的各种工具和技术。在此过程中还利用了Docker框架。

该应用程序演示可在 Streamlit 公共云和 Google App Engine 上使用。由于 Docker 支持,开发人员可以将其部署在他们喜欢的任何云平台上。

🍀小结🍀

今天我们认识了"使用 Docker 和 Streamlit 构建和部署 LangChain 支持的聊天应用程序"相信大家看完有一定的收获。
种一棵树的最好时间是十年前,其次是现在! 把握好当下,合理利用时间努力奋斗,相信大家一定会实现自己的目标!加油!创作不易,辛苦各位小伙伴们动动小手,三连一波💕💕~~~,本文中也有不足之处,欢迎各位随时私信点评指正!

This post was originally published on Level Up Coding and is reprinted with permission.

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/855132.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

水产养殖产量低?教你个万能的方法!

水产养殖业作为重要的食品生产和经济活动之一,为人们提供了丰富的水产品,但如果不加以适当监测和管理,也可能对水质和生态系统造成负面影响。因此,水产养殖用水监测显得尤为重要。 在养殖过程中,水质的优劣直接影响着养…

Linux小型操作系统项目,《操作系统真象还原》第三章——完善MBR

前引 上一章我们完成了MBR的雏形编写,但是只打印了几个字符,这一章我们才要真正地去完成MBR的功能。 在完成MBR的功能之前我们要先了解一些知识,首先介绍什么是实模式。 书上的内容实在繁杂,简单地说,实模式没有虚拟和…

【算法|数组】双指针

算法|数组——双指针 引入 给你一个按 非递减顺序 排序的整数数组 nums,返回 每个数字的平方 组成的新数组,要求也按 非递减顺序 排序。 示例 1: 输入:nums [-4,-1,0,3,10] 输出:[0,1,9,16,100] 解释:…

77. 组合

题目链接&#xff1a;力扣 解题思路&#xff1a; AC代码 class Solution {List<Integer> tem new ArrayList<>();List<List<Integer>> result new ArrayList<>();public List<List<Integer>> combine(int n, int k) {process(n…

重试框架入门:Spring-RetryGuava-Retry

前言 在日常工作中&#xff0c;随着业务日渐庞大&#xff0c;不可避免的涉及到调用远程服务&#xff0c;但是远程服务的健壮性和网络稳定性都是不可控因素&#xff0c;因此&#xff0c;我们需要考虑合适的重试机制去处理这些问题&#xff0c;最基础的方式就是手动重试&#xf…

Vue3:页面A搜索后跳转到页面B,然后从页面B退回页面A重新搜索,但是得到的页面B得刷新一下才会显示正确的数据

问题 Vue3&#xff1a; 从页面A进行搜索后跳转到页面B&#xff0c;然后从页面B退回页面A重新搜索&#xff0c;但是得到的页面B得刷新一下才会显示正确的数据。 读取数据的代码格式大致如下&#xff08;代码做了一些删减&#xff09;&#xff1a; 解决 会出现上述情况&#…

DIY 一个 Docker Base Image

1. 我们先使用C语言写一个hello-world程序 vim hello.c # include <stdio.h>int main() {print("hello docker\n"); } 2. 将hello.c文件编译成二进制文件, 需要安装工具 yum install gcc yum install glibc-static 开始编译 gcc -static hello.c -o hello 编译…

低代码平台“高”效率开发的5个能力

迫于智改数转的压力&#xff0c;促使企业要不停地思考如何从低代码的角度释放一些重复枯燥又高成本的人力投入。历经多次重大重构及大量项目实战验证之后&#xff0c;个人认为一款高效率的低代码开发平台&#xff0c;应有以下几点能力。 一、低代码平台“高”效率开发的5个能力…

ES索引重建reindex详解

目录 一、使用场景 二、reindex介绍 三、使用手册 1、覆盖更新 2、创建丢失的文档并更新旧版本的文档 3、仅创建丢失的文档 4、冲突处理 5、source中添加查询条件 6、source中包含多个源索引 7、限制处理的记录数 8、从远程ES集群中重建索引 9、提取随机子集 10、…

Java实现轻量型Web服务器接收http协议提交的RFID读卡信息

示例使用的读卡器&#xff1a;RFID网络WIFI无线TCP/UDP/HTTP可编程二次开发读卡器POE供电语音-淘宝网 (taobao.com) import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.io.PrintWriter; import java.net.ServerSock…

Java-day07(面向对象-3,4)

继承 将多个类中共有的属性&#xff0c;方法剥离出来单独创建一个共有类&#xff0c;当需要使用共有的属性与方法时&#xff0c;就可以通过继承(extends)来调用共有的属性与方法。通过"class A extends B" 来实现类的继承&#xff08;子类&#xff1a;A 父类&#x…

手把手教你 使用SpringBoot 实现业务数据动态脱敏

文章目录 什么是数据脱敏静态数据脱敏动态数据脱敏 需求实现1. 切面AOP实现脱敏是否脱敏注解定义切入点测试单条记录结果多条记录结果分页记录结果 2. 自定义注解和自定义消息转换器实现数据脱敏自定义DataDesensitization注解定义脱敏类型枚举实现AnnotationFormatterFactory接…

SAP度量单位转换功能

针对今天N2项目提出业务痛点&#xff1a;物料30011110的基本单位是KG&#xff0c;在XXX的BOM里单位是G&#xff0c;由于物料没配单位转换关系&#xff0c;但系统又能正常进行转换&#xff0c;开发需要技术支持。 经专项调查&#xff0c;G和KG的转换是SAP相同量纲转换标准功能&…

econml双机器学习实现连续干预和预测

连续干预 在这个示例中&#xff0c;我们使用LinearDML模型&#xff0c;使用随机森林回归模型来估计因果效应。我们首先模拟数据&#xff0c;然后模型&#xff0c;并使用方法来effect创建不同干预值下的效应&#xff08;Conditional Average Treatment Effect&#xff0c;CATE&…

现在转行搞嵌入式找工作难不难啊?

对于应届生来说&#xff0c;嵌入式开发的经验不会有太多&#xff0c;所以要求也不会太高。 嵌入式开发常用的是C语言&#xff0c;所以需要你有扎实的功底&#xff0c;这一点很重要&#xff0c;数据结构算法&#xff0c;指针&#xff0c;函数&#xff0c;网络编程 有了上面的基…

微服务——数据同步

问题分析 mysql和redis之间有数据同步问题&#xff0c;ES和mysql之间也有数据同步问题。 单体项目可以在crud时就直接去修改&#xff0c;但在微服务里面不同的服务不行。 方案一 方案二 方案三 总结 导入酒店管理项目 倒入完成功启动后可以看见数据成功获取到了 声明队列和…

word横向页面侧面页码设置及转pdf后横线变竖线的解决方案

在处理材料的时候&#xff0c;会遇到同一个文档里自某一页开始&#xff0c;页面布局是横向的&#xff0c;这时候页码要设置在侧面&#xff0c;方法是双击页脚&#xff0c;然后在word工具栏上选择“插入”——>“文本框”——>“绘制竖版文本框”&#xff0c;然后在页面左…

Air001基于Arduino点灯实验

Air001基于Arduino点灯实验 &#x1f449;&#x1f3fb;Arduino平台环境搭建可以参考&#xff1a;https://wiki.luatos.com/chips/air001/Air001-Arduino.html &#x1f516;使用国内的json&#xff0c;安装不仅成功率高还非常的快速。&#xff08;当然取决于个人网络环境&…

Windows安装Redis

自己电脑做个测试&#xff0c;需要用到Redis&#xff0c;把安装过程记录下&#xff0c;方便有需要的人 1、找到下载地址&#xff1a;Releases microsoftarchive/redis GitHub Windows的Redis需要到GitHub上下载&#xff1a; 2、下载完后设置密码&#xff0c;打开文件夹&…

RemObjects Suite Subscription for Delphi Crack

RemObjects Suite Subscription for Delphi Crack Delphi的RemObjects套件订阅提供了一种方便且经济高效的方式&#xff0c;可以随时了解所有RemObjects Delphi产品的最新情况。它允许您访问所有当前和即将推出的产品&#xff0c;而不必担心错过重要的更新或新产品。当您的平台…