历史版本5 :5.X-6.0.5备份升级回退方案 返回文档
编辑时间: 内容长度:图片数:目录数: 修改原因:

目录:

1. 概述编辑

有些情况下,用户可能需要恢复到升级前的版本。

文档提供升级后回退至原版本,再进行升级的操作步骤。

2. 确认数据库类型编辑

进入「管理系统>系统管理>常规」可以看到是否使用了外接数据库,如下图所示:

2022-09-14_11-19-43.png

  • 如果显示「待配置」:则数据库类型为内置数据库

  • 如果显示「已配置」:则数据库类型为外置数据库

3. 使用内置数据库的回退操作编辑

3.1 升级前备份

回退使用内置数据库的工程,需要用户在升级前进行以下备份:

关闭 FineBI 工程,在路径%FineBI%\webapps\webroot下拷贝 webroot 文件夹(备份的 webroot 文件不能放在 FineBI 的安装路径下)

注:如果 webroot 比较大(超过4G),备份需要的时间太长,可以只备份 webroot 下的 WEB-INF 文件夹;如果 WEB-INF 也非常大(超过2G),备份需要的时间还是特别长,可以只备份 WEB-INF 下的 dashboards、embed、lib、plugins、reportlets、resources 文件夹。

3.2 回退步骤

1)关闭 BI 服务器

2)替换工程

若在升级前使用内置数据库,将备份的旧工程 webroot 文件,替换%FineBI%\webapps路径下的 webroot 文件即可,如下图所示:

2022-09-14_15-14-22.png

注:如果只备份了WEB-INF,就恢复备份的WEB-INF,启动工程;如果只备份了 WEB-INF 下的 dashboards、embed、lib、plugins、reportlets 文件夹,那么就恢复对应的文件夹。

3)重启 BI 服务器。

3.3 升级

详情参考:6.0升级

4. 使用外置数据库回退操作编辑

4.1 方法一(推荐)

4.1.1 升级前备份

方法一要求用户在升级前进行过以下备份:

1)关闭 FineBI 工程,在路径%FineBI%\webapps\webroot下拷贝 webroot 文件夹(备份的 webroot 文件不能放在 FineBI 的安装路径下)

注:如果 webroot 比较大(超过 4G),备份需要的时间太长,可以只备份 webroot 下的 WEB-INF 文件夹;如果 WEB-INF 也非常大(超过 2G ),备份需要的时间还是特别长,可以只备份 WEB-INF 下的 dashboards、embed、lib、plugins、reportlets 文件夹。

2)手动备份好外接数据库,备份数据库的密码需要和之前数据库的一致。

4.1.2 回退步骤

1)关闭 BI 服务器。

2)替换工程

将备份的旧工程 webroot 文件,替换%FineBI%\webapps路径下的 webroot 文件,如下图所示:

2022-09-14_15-14-22.png

注:如果只备份了 WEB-INF,就恢复备份的 WEB-INF;如果只备份了 WEB-INF 下的 dashboards、embed、lib、plugins、reportlets文件夹,那么就恢复对应的文件夹。

3)恢复外接数据库

若为新建一个数据库备份外接数据库,即备份恢复的数据库名、用户名、密码等与之前的数据库名不一致,则修改%FineBI%/webapps/webroot/WEB-INF/config路径下的 db.properties ,根据备份的数据库的连接信息对文件进行修改,如下图所示:

33.png

若备份恢复的数据库的数据库名、用户名、密码等跟之前的数据库的名字一样,则不需要修改其他的配置。

4)启动  FineBI 完成回退。

4.2 方法二

4.2.1 升级前备份

使用方法二需要用户在升级前进行过以下备份:

1)进入「管理系统>智能运维>备份还原」,分别对「平台配置 、报表模板、BI模板、Jar包、插件」进行「手动备份」,如下图所示:

1611646188572529.png

4.2.2 回退步骤

1)关闭 FineBI 工程。

2)恢复报表模板。

%FineBI%/webapps/webroot/WEB-INF目录下的 reportlets 文件夹删除;在%FineBI%/webapps/webroot/backup/reportlets/manual下,根据文件夹的名字(备份时间),找到备份的内容,将 reportlets 文件夹复制到%FineBI%/webapps/webroot/WEB-INF目录下。

3)恢复 BI 模板。

%FineBI%/webapps/webroot/WEB-INF目录下的 dashboards 文件夹删除;在%FineBI%/webapps/webroot/backup/dashboards/manual下,根据文件夹的名字(备份时间),找到备份的内容,将dashboards 文件夹复制到%FineBI%/webapps/webroot/WEB-INF目录下;

4)恢复 jar包。

%FineBI%/webapps/webroot/WEB-INF目录下的 lib 文件夹删除;

%FineBI%/webapps/webroot/backup/jar/manual下,根据文件夹的名字(备份时间),找到备份的内容,将lib文件夹复制到%FineBI%/webapps/webroot/WEB-INF目录下;

5)恢复插件。

%FineBI%/webapps/webroot/WEB-INF目录下的 plugins 文件夹删除;

%FineBI%/webapps/webroot/backup/plugins/manual下,根据文件夹的名字(备份时间),找到备份的内容,将 plugins 文件夹复制到%FineBI%/webapps/webroot/WEB-INF目录下;

6)恢复外置数据库。

%FineBI%/webapps/webroot/backup/config/manual下,根据文件夹的名字(备份时间),找到备份的内容,将备份的config.zip 解压得到的 finedb,替换%FineBI%/webapps/webroot/WEB-INF/embed下的 finedb 文件,如下图所示:

1601027166260835.png

%FineBI%/webapps/webroot/WEB-INF/config下的 db.properties 文件删除;此文件删除后,工程启动就读内置 finedb 的内容。

7)启动工程,完成回退,用户可以根据需要,重新配置外接数据库。

4.3 升级

详情参考:6.0升级

5. 集群编辑

5.1 备份还原

5.1.1 使用文件服务器

5.1.1.1 方法一(推荐使用)

【备份】

1)关闭工程所有的节点;

2)备份各个节点的webroot文件夹;

注:如果webroot比较大(超过4G),备份需要的时间太长,各节点下可以只备份webroot下的WEB-INF文件夹;如果WEB-INF也非常大(超过2G),备份需要的时间还是特别长,可以只备份WEB-INF下的lib、plugins文件夹。

3)备份文件服务器上的WEB-INF文件夹;

注:如果WEB-INF比较大(超过2G),备份需要的时间太长,文件服务器上可以只备份WEB-INF下的dashboards、reportlets文件夹。

4)数据库端备份外置数据库。备份的数据库的密码要跟之前的外置数据库一样。

【还原】

1)各节点恢复之前备份的webroot;

注:如果只备份了WEB-INF,就恢复备份的WEB-INF;如果只备份了WEB-INF下的lib、plugins文件夹,那么就恢复对应的文件夹;

2)恢复文件服务器上的WEB-INF文件夹;

如果只备份了WEB-INF下的dashboards、reportlets文件夹,那么就恢复对应的文件夹;

3)恢复外置数据库;

  • 备份恢复的数据库的数据库名、用户名等跟之前的不一样,恢复时需要修改以下配置:

修改集群各节点%FineBI%/webapps/webroot/WEB-INF/config路径下的db.properties,根据备份的数据库的连接信息进行修改

1601363507979903.png

  • 备份恢复的数据库的数据库名、用户名、密码等跟之前的数据库的名字一样,则不需要修改db.properties的配置;

4)依次启动集群各节点。

5.1.1.2 方法二

【备份】

1)进入「管理系统>智能运维>备份还原」,分别对「平台配置 、报表模板、BI模板、Jar包、插件」进行「手动备份」,如下图所示:

1611646188572529.png

【还原】

备份的内容在文件服务器上,到文件服务器上 WEB-INF 同层级目录下找到 backup 文件夹。

1)恢复报表模板。

将文件服务器 WEB-INF 目录下的 reportlets 文件夹删除;

在文件服务器backup/reportlets/manual下,根据文件夹的名字(备份时间),找到备份的内容,将 reportlets 文件夹复制到文件服务器的 WEB-INF 目录下;

2)恢复 BI模板。

将文件服务器 WEB-INF 目录下的 dashboards 文件夹删除;

在文件服务器backup/dashboards/manual下,根据文件夹的名字(备份时间),找到备份的内容,将 dashboards 文件夹复制到文件服务器的 WEB-INF 目录下;

3)恢复jar包。

将集群各节点/webapps/webroot/WEB-INF目录下的 lib 文件夹删除;

backup/jar/manual下,根据文件夹的名字(备份时间),找到备份的内容,将lib文件夹复制到集群各节点%FineBI%/webapps/webroot/WEB-INF目录下。

4、恢复插件。

将集群各节点下的 plugins 文件夹删除;

在文件服务器backup/plugins/manual下,根据文件夹的名字(备份时间),找到备份的内容,将 plugins 文件夹复制到集群各节点%FineBI%/webapps/webroot/WEB-INF目录下。

5、恢复外置数据库。

在文件服务器backup/config/manual下,根据文件夹的名字(备份时间),找到备份的内容,将备份的 config.zip 解压得到的 finedb ,替换集群一个节点%FineBI%/webapps/webroot/WEB-INF/embed下的 finedb 文件;

2022-09-14_15-29-37.png

将集群这个节点下的%FineBI%/webapps/webroot/WEB-INF/config下的 db.properties 文件删除。(此文件删除后,工程启动就读内置 finedb 的内容了)

6、启动集群的这个节点。

7、启动成功后,配置外接数据库。

8、将这个节点%FineBI%/webapps/webroot/WEB-INF/config下的 db.properties 文件,拷贝到集群其他节点的FineBI/webapps/webroot/WEB-INF/config下。

7、启动其他的节点。

5.1.2 使用节点间同步

5.1.2.1 方法一(推荐使用)

【备份】

1)关闭工程所有的节点;

2)备份各个节点的 webroot 文件夹;

注:如果webroot比较大(超过4G),备份需要的时间太长,各节点下可以只备份webroot下的WEB-INF文件夹;如果WEB-INF也非常大(超过2G),备份需要的时间还是特别长,可以只备份WEB-INF下的dashboards、lib、plugins、reportlets文件夹。

3)数据库端备份外置数据库。备份的数据库的密码要跟之前的外置数据库一样。

【还原】

1)集群各节点恢复之前备份的 webroot。

注:如果只备份了WEB-INF,就恢复备份的WEB-INF;如果只备份了WEB-INF下的dashboards、lib、plugins、reportlets文件夹,那么就恢复对应的文件夹。

2)恢复外置数据库;

  • 备份恢复的数据库的数据库名、用户名等跟之前的不一样,恢复时需要修改以下配置:

修改集群各节点%FineBI%/webapps/webroot/WEB-INF/config路径下的 db.properties ,根据备份的数据库的连接信息进行修改

1601363507979903.png

  •  备份恢复的数据库的数据库名、用户名、密码等跟之前的数据库的名字一样,则不需要修改db.properties的配置;

3)依次启动集群各节点。

5.1.2.2 方法二

【备份】

1)进入「管理系统>智能运维>备份还原」,分别对「平台配置 、报表模板、BI模板、Jar包、插件」进行「手动备份」,如下图所示:

1611646188572529.png

【还原】

备份的内容在集群主节点的FineBI/webapps/webroot/backup下。

1)恢复报表模板。

将集群各节点%FineBI%/webapps/webroot/WEB-INF目录下的 reportlets 文件夹删除;

%FineBI%/webapps/webroot/backup/reportlets/manual下,根据文件夹的名字(备份时间),找到备份的内容,将 reportlets 文件夹复制到集群各节点%FineBI%/webapps/webroot/WEB-INF目录下。

2、恢复BI模板。

将集群各节点%FineBI%/webapps/webroot/WEB-INF目录下的 dashboards 文件夹删除;

%FineBI%/webapps/webroot/backup/dashboards/manual下,根据文件夹的名字(备份时间),找到备份的内容,将 dashboards 文件夹复制到集群各节点%FineBI%/webapps/webroot/WEB-INF目录下;

3、恢复 jar 包。

将集群各节点%FineBI%/webapps/webroot/WEB-INF目录下的 lib 文件夹删除;

%FineBI%/webapps/webroot/backup/jar/manual下,根据文件夹的名字(备份时间),找到备份的内容,将 lib 文件夹复制到集群各节点%FineBI%/webapps/webroot/WEB-INF目录下;

4、恢复插件。

将集群各节点%FineBI%/webapps/webroot/WEB-INF目录下的 plugins 文件夹删除;

%FineBI%/webapps/webroot/backup/plugins/manual下,根据文件夹的名字(备份时间),找到备份的内容,将 plugins 文件夹复制到集群各节点%FineBI%/webapps/webroot/WEB-INF目录下;

5)恢复外置数据库。

%FineBI%/webapps/webroot/backup/config/manual下,根据文件夹的名字(备份时间),找到备份的内容,将备份的 config.zip 解压得到的 finedb,替换%FineBI%/webapps/webroot/WEB-INF/embed下的 finedb 文件,如下图所示:

%FineBI%/webapps/webroot/WEB-INF/config下的 db.properties 文件删除;此文件删除后,工程启动就读内置 finedb 的内容。

6)启动集群的这个节点;

7)启动成功后,配置外接数据库。

8)将这个节点%FineBI%/webapps/webroot/WEB-INF/config下的db.properties文件,拷贝到集群其他节点的%FineBI%/webapps/webroot/WEB-INF/config下。

9)启动其他的节点。

5.2 升级

5.2.1 升级前准备

1)额外开启端口:50050、50051、50100、50101、50200,若不开启会导致启动失败,现象是 BI 进程直接消失;

2)原开启进程分离参数的集群需要关闭该参数('DistributedOptimizationConfig.spiderConfig.spider_engine_mode','local')为开启状态,删除该参数即可;

3)修改参数:INSERT INTO `fine_conf_entity`(`id`, `value`) VALUES ('RedisConfig.connectionTimeout', '100000');

4)修改参数:INSERT INTO `fine_conf_entity`(`id`, `value`) VALUES ('RedisConfig.soTimeout', '100000');

5.2.2 升级

1)关闭工程所有的节点;

2)在主节点(存放更新的db数据的节点)执行升级工具,执行步骤见文档:6.0升级

3)单个节点可以正常访问之后,将运行升级工具节点的 /webroot 目录下的 WEB-INF、scripts、upm 拷贝到其他节点;如果WEB-INF比较大的话,可以只拷贝WEB-INF下的dashboards、lib、plugins、reportlets文件夹;

4)启动其他节点,检查集群状态界面正常(一般是一个节点sync,另外都是recover,因为数据正在同步中),即可正常访问工程;

5)修改 nginx 配置,所有请求都配成随机转发。可忽略此步骤 6.0 自动随机转发。

详见:抽取集群nginx配置

6.0 抽取集群 nginx 配置示例文件 nginx.conf:nginx.conf.zip

抽取集群请求均为随机转发,较 5.1 集群配置简单了很多;配置时IP、端口需要修改为自身环境对应的 IP 和端口;
需要根据具体环境修改的地方:

2022-09-14_16-51-46.png

修改后保存配置。

cd /usr/nginx/sbin  #进入sbin目录  
./nginx -s reload #启动nginx

6. 回退注意事项(单机&集群)编辑

6.1 更新

因为升级后会将所有的设置了随父表更新的自助数据集都更新一遍,因此自助数据集更新的 db 文件结构会改变,如果回退到 5.1 版本,一些自助数据集可能因为更新的 db 文件结构变动导致预览失败,需要重新更新一下才能正常展示;

如果需要更新的表太多,又不方便进行全局更新,可以设置如下参数:

  • 表:fine_conf_entity

  • id:DistributedOptimizationConfig.spiderConfig.spider_ignore_base_update   

  • value:true

设置参数后,工程需要重启才能生效;

设置这个参数后,再触发全局更新,遇到基础表会直接跳过更新,只更新自助数据集。

6.2 插件

5.1.18及之前(FR10)和 5.1.18 之后(FR11)的版本插件商城资源不一样。

如果是 FR10 版本升级到 FR11 版本,升级工具会直接将插件商城资源替换为 FR11 的资源;这种情况下如果要回退的话,内网客户需要手动将插件商城资源替换为 FR10 版本的资源;

5.1.18及之前(FR10)版本插件商城资源路径:%FineBI%/webapps/webroot下,资源文件 scripts.zipupm.zip,下载下来后,解压到%FineBI%/webapps/webroot下。