mirror of
https://github.com/labring/FastGPT.git
synced 2026-05-05 01:02:59 +08:00
5c8f2f95f7
Signed-off-by: Carson Yang <yangchuansheng33@gmail.com>
67 lines
1.7 KiB
Markdown
67 lines
1.7 KiB
Markdown
---
|
|
title: '升级到 V4.0'
|
|
description: 'FastGPT 从旧版本升级到 V4.0 操作指南'
|
|
icon: 'upgrade'
|
|
draft: false
|
|
toc: true
|
|
weight: 850
|
|
---
|
|
|
|
如果您是**从旧版本升级到 V4**,由于新版 MongoDB 表变更比较大,需要按照本文档的说明执行一些初始化脚本。
|
|
|
|
## 重命名表名
|
|
|
|
需要连接上 MongoDB 数据库,执行两条命令:
|
|
|
|
```mongodb
|
|
db.models.renameCollection("apps")
|
|
db.sharechats.renameCollection("outlinks")
|
|
```
|
|
|
|
{{% alert context="warning" %}}
|
|
注意:从旧版更新到 V4, MongoDB 会自动创建空表,你需要先手动删除这两个空表,再执行上面的操作。
|
|
{{% /alert %}}
|
|
|
|
## 初始化几个表中的字段
|
|
|
|
依次执行下面 3 条命令,时间比较长,不成功可以重复执行(会跳过已经初始化的数据),直到所有数据更新完成。
|
|
|
|
```mongodb
|
|
db.chats.find({appId: {$exists: false}}).forEach(function(item){
|
|
db.chats.updateOne(
|
|
{
|
|
_id: item._id,
|
|
},
|
|
{ "$set": {"appId":item.modelId}}
|
|
)
|
|
})
|
|
|
|
db.collections.find({appId: {$exists: false}}).forEach(function(item){
|
|
db.collections.updateOne(
|
|
{
|
|
_id: item._id,
|
|
},
|
|
{ "$set": {"appId":item.modelId}}
|
|
)
|
|
})
|
|
|
|
db.outlinks.find({shareId: {$exists: false}}).forEach(function(item){
|
|
db.outlinks.updateOne(
|
|
{
|
|
_id: item._id,
|
|
},
|
|
{ "$set": {"shareId":item._id.toString(),"appId":item.modelId}}
|
|
)
|
|
})
|
|
```
|
|
|
|
## 初始化 API
|
|
|
|
部署新版项目,并发起 3 个 HTTP 请求(记得携带 `headers.rootkey`,这个值是环境变量里的)
|
|
|
|
1. https://xxxxx/api/admin/initv4
|
|
2. https://xxxxx/api/admin/initChat
|
|
3. https://xxxxx/api/admin/initOutlink
|
|
|
|
1 和 2 有可能会因为内存不足挂掉,可以重复执行。
|