# 数据库一键搬家工具
下载地址与文档
# 一键搬家的优势
1、
官方的web控制台
需要一个一个表导出导入,操作繁琐。而一键搬家
不需要。2、直接用
官方的web控制台
导出的json文件导入腾讯云,会出现24位id和外键搜索查不到的bug。而一键搬家
自动帮你所有24位id增加1位解决此bug。3、不仅支持将
A账号
下的A1空间
搬家到A2空间
,还支持将A账号
下的A1空间
搬家到B账号
下的B1空间
。4、支持全端(阿里云、腾讯云、支付宝云)
5、省心、省力、解放双手!
# 一键搬家最重要的优势
如果你用 官方的web控制台
从阿里云空间导出的json文件导入腾讯云空间,你会发现根据 _id
搜索时,有可能无法搜索到数据,那是因为腾讯云不支持阿里云生成的24位 _id
,阿里云生成的24位 _id
导入到腾讯云空间后,会造成无法根据 _id
来查询数据,而 一键搬家
可以帮你完美解决这个棘手问题。
# 效果视频
# 名词定义
1、旧空间:就是你需要搬家的空间。
2、新空间:就是你需要把旧空间搬到这的空间。
# 注意事项
1、请确保
旧空间
和新空间
是可以正常访问的空间。2、
新空间
数据库的数据在导入前会被全部清空
(需要注意空间别选错了,否则后果自负)。3、
旧空间
数据库的数据不会被清空
(也不会被修改)4、搬家会消耗数据库查询次数、写入次数,以及云函数流量(请确保资源充足)。
6、目前大致耗时 = (你数据量总记录数 / 1000) 秒(即每秒搬1000条数据)(后面会继续优化这个速度)
7、如有问题,可以加Q群:
22466457
进行反馈(关于插件问题必定会得到处理)。
# 插件市场地址
# 一键搬家配置
配置文件为【一键搬家】项目根目录下的 vk.db.config.js
文件
/**
* 一键搬家配置
*/
export default {
// 旧环境
"oldEnv": {
"cloud": "uniCloud", // 通用参数 固定为 uniCloud
"platform": "aliyun", // 通用参数 阿里云:aliyun 腾讯云:tencent 支付宝云:alipay
"spaceId": "mp-9dd9a70d-0000-6666-a520-105287d47ff4", // 通用参数 从 https://unicloud.dcloud.net.cn/home 获取 对应SpaceId参数
"clientSecret": "阿里云专属参数", // 阿里云专属参数 从 https://unicloud.dcloud.net.cn/home 获取 对应ClientSecret参数
"spaceAppId": "支付宝云专属参数", // 支付宝云专属参数 从 https://unicloud.dcloud.net.cn/home 获取 对应SpaceAppId参数
"accessKey": "支付宝云专属参数", // 支付宝云专属参数 从 https://unicloud.dcloud.net.cn/home 获取 对应AK参数
"secretKey": "支付宝云专属参数", // 支付宝云专属参数 从 https://unicloud.dcloud.net.cn/home 获取 对应SK参数
"actionsecret": "5d44a032652974c3e53644945a95b126", // 通用参数 请求密钥,从 uniCloud/cloudfunctions/vk-db-migration/vk.db.config.js 获取(两者保持一样即可)
},
// 新环境
"newEnv": {
"cloud": "uniCloud", // 通用参数 固定为 uniCloud
"platform": "alipay", // 通用参数 阿里云:aliyun 腾讯云:tencent 支付宝云:alipay
"spaceId": "env-00jx6s6j6mnt", // 通用参数 空间id 从 https://unicloud.dcloud.net.cn/home 获取 对应SpaceId参数
"clientSecret": "阿里云专属参数", // 阿里云专属参数 从 https://unicloud.dcloud.net.cn/home 获取 对应ClientSecret参数
"spaceAppId": "支付宝云专属参数", // 支付宝云专属参数 从 https://unicloud.dcloud.net.cn/home 获取 对应SpaceAppId参数
"accessKey": "支付宝云专属参数", // 支付宝云专属参数 从 https://unicloud.dcloud.net.cn/home 获取 对应AK参数
"secretKey": "支付宝云专属参数", // 支付宝云专属参数 从 https://unicloud.dcloud.net.cn/home 获取 对应SK参数
"actionsecret": "5d44a032652974c3e53644945a95b126", // 通用参数 请求密钥,从 uniCloud/cloudfunctions/vk-db-migration/vk.db.config.js 获取(两者保持一样即可)
},
"maxPageSize": 500, // 数据库单次请求获取数量,默认500,如果前端报内存超出大小限制的错误,可以尝试调小此值来解决。如设置为100或50或更小的值,最小为1,最大1000
"concurrencyImport": false, // 是否并发导入?设置为true可以提高性能,但无法保证迁移后的数据与原始顺序一致(一般业务进行查询时都会加排序条件,此时基本无影响),设置为false则可保证迁移后的数据与原始数据顺序一致
"debug": false, // 浏览器控制台是否打印请求日志,设置为 false 可以提升性能
"errorReconnectionCount": 20, // 数据库连接失败后重新连接次数,默认20次,一般无需修改
"maxImportQueueCount": 10, // 最大等待的导入队列数,默认10,一般无需修改(太大会影响前端性能)最小为1,最大为20
"maxLogCount": 200, // 控制台显示的最大日志数量,默认200,一般无需修改(太大会影响前端性能)
"handleObjectKeyName": true, // 是否需要同时处理满足阿里云_id格式的字段名,一般无需修改(true:同时处理字段名和字段值 false:只处理字段值,默认true)
// 数据库内存储链接地址域名替换规则
// 打开 fileRule 内的注释,编写旧域名和新域名,导入后数据库内的文件链接会用新域名代替旧域名
"fileRule": [
// { "old": "https://test1.xxx.com", "new": "https://test2.xxx.com" }
],
// 数据库集合(表)列表,目前没有接口可以直接获取表列表,故需要在此手动填写数据库中需要搬家的表信息
// 可以自动根据 database 目录内的文件 生成数据库表名列表 方法:在项目根目录执行 node vk.create-db-config.js 详见文档 https://vkdoc.fsq.pub/db-migration/#如何生成数据库初始化文件
"db": [
{ "name": "uni-id-users" },
{ "name": "uni-id-roles" },
{ "name": "uni-id-permissions" },
{ "name": "opendb-admin-menus" },
{ "name": "opendb-app-list" },
]
};
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
如何获取空间环境参数?
登录unicloud-web控制台 (opens new window),在总览页面即可看到对应的参数。
# 操作步骤
- 1、打开【一键搬家】项目根目录
vk.db.config.js
配置文件,修改oldEnv
、newEnv
配置
- 2、生成
database
目录下的数据库初始化文件
# 如何生成数据库初始化文件?
在 uniCloud控制台
云数据库菜单下点击 生成初始化数据
选择只导出首条记录,生成不包含ID(包含也没事)【一键搬家】运行时,会自动清空新空间的数据。
注意:如果生成失败,不要慌,过一会再试
- 3、把生成并解压的
database
文件全部复制到【一键搬家】项目根目录的uniCloud/database目录下
注意:如果【一键搬家】项目的 uniCloud/database目录下
有 db_init.json
文件,则需要删除Ta(这步很重要,因为上面介绍的是使用新的数据库初始化方式的,当然老的 db_init.json
方式目前也还是支持的)
然后在项目根目录执行 node vk.create-db-config.js
- 4、【一键搬家】项目绑定
旧空间
,并上传云函数vk-db-migration
- 5、【一键搬家】项目切换到
新空间
,在新空间
也上传云函数vk-db-migration
如何切换空间?
右键 uniCloud
目录,点击关联空间,选择需要切换的空间。
如何切换阿里云、腾讯云、支付宝云空间
右键 uniCloud
目录,点击重命名,腾讯云为: uniCloud-tcb
,阿里云为 uniCloud-aliyun
,支付宝云为 uniCloud-alipay
,然后再右键 uniCloud
目录,点击关联空间,选择需要切换的空间。
# 特别注意:如果你购买的是普通授权版(非源码授权版),你可能需为两个空间各购买1次插件。
- 6、切换到
新空间
后,在新空间
初始化你自己数据库 (注意:如果初始化报错,不要急,再初始化一次,直到提示成功或提示没有任何表数据要上传时,则代表成功)
- 7、启动
一键搬家
项目(请使用连接云端云函数)
注意:运行前先确认下,旧空间和新空间没有填错,否则运行时,新空间数据会清空(旧空间数据不会变)
8、启动【一键搬家】项目,访问首页,当看到页面控制台上打印
点击上方【开始一键搬家】按钮可进行一键搬家
时,点击此按钮即可。9、点击【开始一键搬家】按钮
10、如不出意外,等待进度条到100%即可。如果出了意外(比如阿里云数据库不稳定导致连续20次数据库连接失败(目前会自动重试20次),则需要刷新页面并重新点击【开始一键搬家】按钮
11、完成后请将
uniCloud/cloudfunctions/vk-db-migration/vk.db.config.js
的runKey
设置为false,再分别上传到旧空间
和新空间
(这步很关键,防止后面误点导致数据被清空,也可以直接去web控制台删除云函数vk-db-migration
)12、完成。
# 常见问题
# 如你已付费购买,缺还提示[vk-database-one-click-migration]:不能在当前云服务空间使用
如果使用数据库搬家项目的时候遇到 data undefined
同时提示 [vk-database-one-click-migration]:不能在当前云服务空间使用
则去项目根目录下的 package.json
文件内查看看是否有名为 sn
的属性,把Ta删除后再试试。
# 当需要迁移的数据条数非常多时,且迁移的时候不想停服太长时间时,支持先迁移部分数据(这部分数据需要保证不会再被修改和删除)
只有表存在不会再被修改和删除的数据时才能先迁移这部分数据,迁移的时候旧空间是不需要停服的
假设表 uni-id-log
有2000万条数据,其中这2000万条数据都不会再被修改和删除(因为这是日志表,不会被修改和删除,只会新增),这些数据的最后一条数据的 _id
是 666c48a1a891ba9fb989fb30
(请必须通过 _id
降序排序后拿第一条数据的_id,千万不要去控制台翻最后一页)
拿到目前最后一条 _id
的数据库语句如下,请在云函数中自己执行并获取到 endId
const db = uniCloud.database();
let dbRes = await db.collection('uni-id-log').orderBy("_id", "desc").limit(1).get();
let endId = dbRes.data[0]._id;
console.log('endId: ', endId);
2
3
4
vk.db.config.js
配置的时候这样写,多配置一个参数 endId
,配置如下
解释:endId
代表只迁移到这个 _id
(包含此id) 后就结束此表
...其他配置
"db": [
...其他表
{ "name": "uni-id-log", "endId": "666c48a1a891ba9fb989fb30" },
]
2
3
4
5
6
下次停服全量迁移的时候,再多配置一个参数 startId
,并去掉之前的参数 endId
,配置如下
...其他配置
"db": [
...其他表
{ "name": "uni-id-log", "startId": "666c48a1a891ba9fb989fb30" },
]
2
3
4
5
6
解释:startId
代表迁移时从这个 _id
(不包含此id,即此id的下一条记录)开始
# 数据库里的文件URL域名如何替换?
修改配置 fileRule
数组,如下所示
注意:文件本身不会迁移,这里只替换域名,适用于云存储文件已迁移完成只需要改数据库内字段的URL值的情况。
"fileRule": [
{ "old": "https://test1.xxx.com", "new": "https://test2.xxx.com" }
],
2
3
# 特别注意
搬家完成后请将 uniCloud/cloudfunctions/vk-db-migration/vk.db.config.js
的 runKey
设置为false,再分别上传到 旧空间
和 新空间
(这步很关键,防止后面误点导致数据被清空,也可以直接去web控制台删除云函数 vk-db-migration
)