mirror of
https://github.com/labring/FastGPT.git
synced 2025-07-22 12:20:34 +00:00
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 有可能会因为内存不足挂掉,可以重复执行。
|