SonarQube升级更新说明

2023-02-27 15:50:10 浏览数 (1)

本文介绍了SonarQube版本更新升级的方法。包括SonarQube升级指南和9.9版本更新说明。

9.9 版升级说明

数据库支持已更新

  • SonarQube不再支持Oracle版本12C和18C。
  • 现在支持 Oracle 版本 21C。
  • 现在支持 SQL Server 2022。 SonarQube 服务器需要 Java 17
  • Java 17 需要 SonarQube 服务器。不再支持使用 Java 11。 SonarScanner for .NET 兼容性
  • 在SonarQube中对C#/VB.NET 进行增量分析需要SonarScanner for .NET 5.11 。 社区版、开发者版和企业版的单一Helm图表
  • sonarqube lts Helm图表不再维护,无法用于安装sonarqube 9.9 lts。要安装Community、Developer或Enterprise Edition,请使用sonarqube Helm图表。数据中心版随sonarqube dce Helm图表提供。 已更新 Docker 映像
  • 如果你使用自签名的证书,你可能需要调整你的Docker配置:Java的安装路径已经改变为

    /opt/java/openjdk/

  • 废弃的和变量已被删除

最新的配置变量请参见环境变量。 

代码语言:javascript复制
SONARQUBE_JDBC_USERNAMESONARQUBE_JDBC_PASSWORDSONARQUBE_JDBC_URL
  • Docker镜像上的标签被替换成新的LTS版本。如果你想避免任何自动的重大升级,我们建议使用相应的标签来代替.lts9.9-<edition>lts-<edition>。

SonarQube升级指南

迁移路径

跨多个非 LTS 版本的升级会自动处理。但是,如果迁移路径中有一个或多个 LTS 版本,则必须先迁移到每个中间 LTS,然后再迁移到目标版本,如下面的示例 3 所示。

升级到 LTS 版本时,应直接升级到其最新修补程序。这使您可以确保使用该补丁一切运行良好(请参阅下面的升级练习部分)。

您可以直接从最新的 LTS 版本升级到最新的非 LTS 版本。请参阅下面的示例 4。

如果要从 LTS 的早期修补程序版本迁移,则可以直接升级到下一个 LTS。您无需安装任何中间修补程序版本。

迁移路径示例:

  • 示例 1 – 从 8.1 > 9.8,迁移路径为 8.1 > 8.9 LTS > 9.8 
  • 示例 2 – 从 9.6 > 9.9 LTS,迁移路径为 9.6 > 9.9 LTS 
  • 示例 3 – 从 7.9 LTS > 9.9 LTS,迁移路径为 7.9 LTS > 8.9 LTS > 9.9 LTS
  • 示例 4 – 从 8.9LTS > 9.9 LTS,迁移路径为 8.9 LTS > 9.9 LTS

升级指南

这是跨 SonarQube 版本升级的通用指南。仔细阅读目标版本和任何中间版本的发行升级说明。

在升级之前,我们建议在尽可能与生产环境相似的过渡环境中练习升级。有关此概念和其他重要升级概念的详细信息,请通读升级之前页面。

在升级之前,请备份您的SonarQube数据库。升级问题很少见,但如果发生任何事情,您将需要备份。

数据库磁盘使用建议

在升级过程中,可能会复制表以加快迁移过程。这可能会导致数据库磁盘使用量暂时增加到正常使用量的两倍。因此,我们建议在开始迁移之前将数据库磁盘使用率保持在 50% 以下。

升级说明

您可以使用 ZIP 文件、Docker 镜像或 Helm Chart 升级 SonarQube 实例。

如果您的升级需要重新构建 Elasticsearch 索引,您的项目和应用程序将在重新索引时可用。在所有项目都编制索引之前,项目组合将不可用。

从 ZIP 文件升级

  • 下载并将您的版本的SonarQube发行版解压缩到一个新目录中,假设<NEW_SONARQUBE_HOME>
  • 如果您使用的是第三方插件,请手动安装与您的 SonarQube 版本兼容的插件。使用插件版本矩阵来确保您安装的版本与您的服务器版本兼容。不建议简单地将插件从旧服务器复制到新服务器;不兼容或重复的插件可能会导致启动错误。默认情况下,无需插件即可分析您的版本提供的所有语言。
  • 使用目录中的设置(Web 服务器 URL、数据库、LDAP 设置等)更新文件 (in ) 的内容。不要复制粘贴旧文件。如果您使用的是 Oracle DB,请将其 JDBC 驱动程序复制到sonar.properties <NEW_SONARQUBE_HOME>/conf  <OLD_SONARQUBE_HOME>/conf <NEW_SONARQUBE_HOME>/extensions/jdbc-driver/oracle
  • 停止旧的SonarQube服务器
  • 启动您的新 SonarQube 服务器
  • 浏览并按照设置说明进行操作 http://yourSonarQubeServerURL/setup
  • 重新分析您的项目以获取最新数据

从 Docker 映像升级

如果使用 Oracle 数据库升级或使用插件,则可以重复使用以前版本的扩展卷,以避免移动插件或驱动程序。使用插件版本矩阵来确保您的插件与您的版本兼容。默认情况下,无需插件即可分析您的版本提供的所有语言。

要使用 Docker 镜像升级 SonarQube,请执行以下操作:

1. 停止并删除现有的 SonarQube 容器(从 UI 重新启动是不够的,因为环境变量仅在第一次运行期间计算,而不是在重新启动期间):

代码语言:javascript复制
$ docker stop <container_id>$ docker rm <container_id>

2. 运行Docker

代码语言:javascript复制
$> docker run -d --name sonarqube     -p 9000:9000     -e SONAR_JDBC_URL=...     -e SONAR_JDBC_USERNAME=...     -e SONAR_JDBC_PASSWORD=...     -v sonarqube_data:/opt/sonarqube/data     -v sonarqube_extensions:/opt/sonarqube/extensions     -v sonarqube_logs:/opt/sonarqube/logs     <image_name>

3. 转到并按照设置说明进行操作。http://yourSonarQubeServerURL/setup

4. 重新分析您的项目以获取最新数据。

从 8.9.x LTS 到 9.9.x LTS

请注意,Docker 镜像上的标签会替换为每个新的 LTS 版本。如果要避免自动主要升级,我们建议使用相应的标记,而不是依赖标记。lts9.9-<edition>lts-<edition>

除非您打算在运行映像时删除数据库并重新开始,否则请注意不要使用 and ,在运行 or 等命令时要小心;无论您是否使用参数,您的数据库卷都不会在 SonarQube 的初始启动和关闭之后持续存在。-v docker-compose downdocker system prunedocker volume pruneexternal: true

恢复到以前的版本

如果您需要恢复到以前版本的 SonarQube,则所有部署的高级回滚过程如下所示:

  • 关闭您的 SonarQube 实例或集群。
  • 将数据库回滚到开始升级之前创建的备份。
  • 切换回以前版本的 SonarQube 安装。
  • 启动您的 SonarQube 实例或集群。

更改您的版本

您可以在升级版本时移动到其他 SonarQube 版本(例如,从社区版移动到商业版)。只需使用上述升级说明中的相应版本文件或 Docker 映像标记即可。

如果您想在不升级 SonarQube 版本的情况下迁移到其他版本,则步骤与上述升级说明中的步骤完全相同,而无需导航到或重新分析您的项目。http://yourSonarQubeServerURL/setup

从 ZIP 文件实例迁移到 Docker 实例

要从 ZIP 文件迁移到 Docker,请执行以下操作:

  • 将 Docker 实例配置为指向现有数据库。
  • 关闭您的 ZIP 实例。
  • 启动您的 Docker 实例。

其他步骤和信息

Oracle清理

  • 从版本 6.6 开始,如果您使用的是 Oracle,则可能需要执行一个额外的步骤。在 Oracle 上,要删除的数据库列现在标记为未使用,并且不再物理删除。要回收磁盘空间,Oracle 管理员必须手动删除这些未使用的列。SQL 请求是 。系统表中列出了相关表。ALTER TABLE foo DROP UNUSED COLUMNSall_unused_col_tabs

其他数据库维护

  • 完成技术升级后,您应该刷新数据库的统计信息并重建数据库的索引,然后再启动 SonarQube 并重新分析您的项目。
  • 对于PostgreSQL,这意味着执行.根据PostgreSQL文档:VACUUM FULL

In normal PostgreSQL operation, tuples that are deleted or obsoleted by an update are not physically removed from their table; they remain present until a VACUUM is done.

Scanner更新

升级SonarQube时,您还应该确保使用的是最新版本的SonarQube Scanner

,以利用扫描仪端的功能和修复。

SonarQube 作为 Linux 或 Windows 服务

如果使用外部配置(如脚本或 Windows 服务)来控制服务器,则需要将其更新为指向 。<NEW_SONARQUBE_HOME>

对于 Linux,这取决于您如何实现服务

对于 Windows,您可以通过运行以下命令来更新服务:

> sc delete SonarQube

> $NEW_SONARQUBE_HOMEbinwindows-x86-64SonarService.bat install

重建索引

如果您的升级需要重新构建 Elasticsearch 索引,您的项目和应用程序将在重新编制索引时可用。在所有项目都编制索引之前,项目组合将不可用。

相关内容:

SonarQube 9.9 LTS - 规模、安全性、速度:有史以来最好的

0 人点赞