位置: IT常识 - 正文

docker部署chat-web,实现自己的ChatGPT(Docker部署nginx)

编辑:rootadmin
docker部署chat-web,实现自己的ChatGPT

推荐整理分享docker部署chat-web,实现自己的ChatGPT(Docker部署nginx),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:Docker部署的项目文件在哪里,Docker部署k8s,Docker部署nginx,docker部署chat-next-web,Docker部署的项目文件在哪里,Docker部署的好处,Docker部署的项目文件在哪里,Docker部署宝塔面板,内容如对您有帮助,希望把文章链接给更多的朋友!

本篇文章的前提是请确认已获得openai 的API-KEYS,即以sk-开头的keys;是否在服务器上安装了docker以及docker-compose

docker以及docker-compose安装请参考我的博文:CENTOS8.0安装DOCKER&DOCKER-COMPOSE_wd520521的博客-CSDN博客

一、(方式一)docker部署chat-web,实现自己的ChatGPT1、创建docker-compose.yml文件

(1)在服务器上创建一个目录:chatgpt_web

mkdir chatgpt_web && cd chatgpt_web

(2)创建docker-compose.yml文件

vim docker-compose.yml

(3)以下内容填写到yml配置文件中并保存

version: '3'services: app: image: chenzhaoyu94/chatgpt-web:latest ports: - 3002:3002 environment: # api秘钥 OPENAI_API_KEY: sk-xxx(修改为自己申请的秘钥) # 超时,单位毫秒,可选 TIMEOUT_MS: 60000保存: 按下Esc,然后输入 :wq 回车

注意:大家在编写yml文件时。要把注释删掉,否则有可能会报错。

2、部署并启动运行docker-compose up -d3、登录chatgpt_web页面

运行成功后直接访问(需要开放3002端口)

http://服务器ip:3002

 4、其他问题解决

(1)如果遇到 fetch failed,可以点上面的圈刷新

docker部署chat-web,实现自己的ChatGPT(Docker部署nginx)

 如果刷新没有用的话,大家重启一下docker,然后重新启动服务

#重启dockersystemctl restart docker#docker 启动服务docker start 容器id#查看容器IDdocker ps -a5、配置反向代理 --可以不配置

nginx配置文件如下:

server{ listen 80;listen 443 ssl http2;listen [::]:443 ssl http2; listen [::]:80; server_name 你的域名; location / {proxy_pass http://127.0.0.1:3002/; # 注意端口号} ssl_certificate /www/m/fn.pem; ssl_certificate_key /www/m/py.pem; ssl_protocols TLSv1.1 TLSv1.2 TLSv1.3;}二、docker部署Chuanhu ChatGPT1、docker 拉取镜像docker pull tuchuanhuhuhu/chuanhuchatgpt:latest2、启动镜像docker run -d --name chatgpt \-e my_api_key="替换成API" \-e USERNAME="替换成用户名" \-e PASSWORD="替换成密码" \-v ~/chatGPThistory:/app/history \-p 7860:7860 \tuchuanhuhuhu/chuanhuchatgpt:latest

注意:(1)USERNAME 和 PASSWORD 两行可省略。若省略则不会启用认证。

(2)个人建议,省略掉USERNAME 和 PASSWORD 两行为好。

3、查看运行状态docker logs chatgpt

 这样就可以使用IP访问了,访问链接如下

http://IP:78604、配置反向代理

注意:配置反向代理不是必须的。如果需要使用域名,则需要配置 Nginx 反向代理。

nginx配置文件如下:

server{ listen 80;listen 443 ssl http2;listen [::]:443 ssl http2; listen [::]:80; server_name 你的域名; #location部分是统一的必须一致 location / {proxy_pass http://127.0.0.1:7860; # 注意端口号proxy_redirect off;proxy_set_header Host $host;proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;proxy_set_header Upgrade $http_upgrade;# Websocket配置proxy_set_header Connection $connection_upgrade;#Websocket配置proxy_max_temp_file_size 0;client_max_body_size 10m;client_body_buffer_size 128k;proxy_connect_timeout 90;proxy_send_timeout 90;proxy_read_timeout 90;proxy_buffer_size 4k;proxy_buffers 4 32k;proxy_busy_buffers_size 64k;proxy_temp_file_write_size 64k;} #SSL部分的配置,大家可以自行配置 ssl_certificate /www/m/fn.pem; ssl_certificate_key /www/m/py.pem; ssl_protocols TLSv1.1 TLSv1.2 TLSv1.3;}server{ listen 80; server_name 你的域名; #rewrite ^(.*)$ https://$host$1 permanent; #return 301 https://$server_name$request_uri; location / {proxy_pass http://127.0.0.1:7860; # 注意端口号proxy_redirect off;proxy_set_header Host $host;proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;proxy_set_header REMOTE-HOST $remote_addr;proxy_set_header Upgrade $http_upgrade;# Websocket配置proxy_set_header Connection $connection_upgrade;#Websocket配置proxy_max_temp_file_size 0;client_max_body_size 10m;client_body_buffer_size 128k;proxy_connect_timeout 90;proxy_send_timeout 90;proxy_read_timeout 90;proxy_buffer_size 4k;proxy_buffers 4 32k;proxy_busy_buffers_size 64k;proxy_temp_file_write_size 64k;}}server{listen 443 ssl;listen [::]:443 ssl;server_name 你的域名; ssl_certificate /www/m/fn.pem; ssl_certificate_key /www/m/py.pem; ssl_protocols TLSv1.1 TLSv1.2 TLSv1.3; ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:HIGH:!aNULL:!MD5:!RC4:!DHE;#按照这个套件配置 ssl_prefer_server_ciphers on;if ($scheme = http) { return 301 https://$server_name$request_uri; }location / { proxy_pass http://127.0.0.1:7860; # 注意端口号proxy_redirect off;proxy_set_header Host $host;proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;proxy_set_header REMOTE-HOST $remote_addr;proxy_set_header Upgrade $http_upgrade;# Websocket配置proxy_set_header Connection $connection_upgrade;#Websocket配置proxy_max_temp_file_size 0;client_max_body_size 10m;client_body_buffer_size 128k;proxy_connect_timeout 90;proxy_send_timeout 90;proxy_read_timeout 90;proxy_buffer_size 4k;proxy_buffers 4 32k;proxy_busy_buffers_size 64k;proxy_temp_file_write_size 64k; }}

这样就配置好nginx了,大家就可以使用自己的域名访问了。

注意(1)目前配置认证后,Nginx 必须配置 SSL,否则会出现 Cookie 不匹配问题。

(2)配置好nginx后,启动nginx报错

nginx: [emerg] unknown "connection_upgrade" variable nginx: configuratio

解决方案:修改nginx.conf配置文件,向http部分添加如下配置: (这一步是为了配置websocket连接)

map $http_upgrade $connection_upgrade { default upgrade; '' close;}
本文链接地址:https://www.jiuchutong.com/zhishi/288868.html 转载请保留说明!

上一篇:CSDN独家原创|YOLOv5改进、YOLOv7改进、YOLOv8改进、YOLOX改进目录一览|YOLO改进模型全系列目录(芒果书系列) | 人工智能专家老师联袂推荐(csdn创作)

下一篇:Educoder/头歌JAVA——jQuery基础(头歌java入门运算符和表达式答案)

  • 取得的证券投资业绩
  • 什么是税收滞纳金请举例说明
  • 分期付款进项税额怎么算
  • 向投资者支付的股息红利等权益性投资收益款项
  • 增值税需要计入入账价值吗
  • 小规模纳税人消费税怎么计算
  • 对外投资借款费用计入
  • 现金流量表年报期末现金余额
  • 餐饮店投资入股注意事项
  • 销售旧货时的售后是什么
  • 资产负债表的编制时间
  • 境外所得抵免税额是什么意思
  • 房屋租赁发票能抵扣几个点
  • 增值税专用发票电子版
  • 哪些进项税不能转出
  • 房地产广告公司月费一般多少
  • 计提个税怎么做
  • 系统安全保障体系
  • 转让金融商品应交增值税计算公式
  • efi bios u盘启动
  • 现金流量表与资产负债表不符
  • 行纪人的权利
  • 股票溢价净收入计入
  • win10系统如何禁用驱动强制签名
  • laravel自动生成接口文档
  • 吉隆坡石油双塔有多高
  • 收回已确认的坏账准备
  • 工资薪金所得具体包括哪些
  • php图片加文字水印
  • uniapp 信息推送
  • 工程施工下的间接费用下有什么科目
  • 未分配利润可以转实收吗
  • 利用php实现一个数组
  • addr指令
  • 应付职工薪酬账户
  • 财务报表季报应付职工薪酬为负数
  • 营改增后还有企业所得税吗?
  • 接受捐赠收入要缴纳企业所得税吗
  • 备抵法账务处理方式
  • 工资只计提没有发放需要申报个税吗
  • 信息技术服务有限公司是干什么的
  • 套期保值是什么意思举个例子
  • 无形资产出租如何入账
  • sql server触发器的作用
  • 一次性取得租赁合同
  • 微信小程序 滚动 变色
  • 资产处置开票填什么项目
  • 文化事业建设税是含税还是不含税
  • 银行承兑贴现需要多久
  • 质量问题的扣款计入什么科目
  • 港币转人民币差多少钱
  • 土地勘测费收费标准
  • 国家土地补偿款
  • 出口退税的范围是多少
  • 电力安装工程合同税率能开13%
  • 公司分期付款买车怎么抵税
  • 库存商品盘点流程
  • 申报工资总额除以在职人员人数
  • 员工伤残补助会计分录
  • 填制凭证的主要内容和注意事项
  • 搭赠商品如何开票
  • mysql 表分区
  • centos7.6 yum源
  • mac的command键相当于pc的什么键
  • explorer.exe是什么指令
  • win10系统浏览器设置主页
  • win7关闭xhci
  • winpe怎么弄
  • win8怎么设置
  • win10系统更改
  • editplus怎么配置java
  • jquery animate源码
  • 安卓退出界面
  • unity字符串
  • jQuery实现ToolTip元素定位显示功能示例
  • nodejs和jsp
  • Unity for Absolute Beginners(一)
  • 很全面的成语
  • python 分析
  • js图片轮播和点击切换
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设