TiDB 6.x 新特性解读 | 离线包变更

TiDB 6.x 新特性解读 | 离线包变更

ShawnYan Lv.6
IMG_2005.JPG

背景

TiDB 6.0 已发版一月有余,相信很多 TiDBer 已经对新版本做了升级测试。对于初装或者升级,都离不开安装介质。而针对数据库这种对信息安全要求级别很高的软件系统,绝大部分场景都应该部署在私有云环境,或者说是内网环境中。那么如何能够顺利、快速地在离线状态下进行安装也是很重要的,伴随着 TiDB 6.0 的发版,离线包也发生了一些变化。
本文将对 TiDB 6.0 离线安装包的变更进行分析,希望对读者在准备离线部署时有所提示或帮助。

离线包变更

先来看下官方文档对 离线包变更 的表述:

离线包变更
TiDB 提供两个离线包下载:v6.0.0 TiDB-community-server 软件包和 v6.0.0 TiDB-community-toolkit 软件包。
在 6.0.0-DMR 版本中,两个离线包的内容物做了一些调整。

接下来,将对 TiDB v6.0 和 v5.4 的离线包进行比对,并具体分析新版本都做了哪些调整。

离线包的内容物

分别下载 TiDB v6.0 和 v5.4 两个版本的离线包,共 4 个压缩包。

下载链接可从 社区版软件包 页面获取。
将这四个压缩包分别解压,并查看解压后的文件。

1
2
for i in `ls tidb-*`; do tar zxf $i; done
ls tidb-*

汇总成如下表格。从表格中可以看出新版本的离线包内容物做了明显调整。分别从 server, toolkit 两个方面展开讲。

1.jpg

tidb-community-server-{version}-linux-amd64.tar.gz 的变化

除常规的组件版本升级之外,有三点主要的变化:

  1. 从表格里可以看出,原先 tidb-community-server-v5.4.0 里的工具,已全部移动到了 tidb-community-toolkit-v6.0.0,只保留基础核心组件。
  2. 组件 diag 的版本号从 v0.5.1 升级到 v0.7.0,超越了其他组件的版本号升级幅度。
  3. 较 v5.4.0 而言,v6.0.0 的离线包中移除了3个组件,client, serverpushgateway

diag

我们知道,TiDB v6.0 新增了 Clinic 诊断服务,而 diag 是该诊断服务的重要组件,负责收集、汇总整个集群的诊断数据,同时可以将诊断数据上报到 Clinic Server,以供技术支持人员远程定位问题。
但由于 diag 目前尚未开源,具体变更不得而知,但我们有理由相信,diag 是为了更好地配合 clinic 的发布而进行了大版本升级。这从 diag 的具体命令和使用方式上可窥视一般。

比较两个版本的 diag 命令,可以看到移除了一个命令 download,新增了一个命令 config

1
2
3
diag help
< download download file
> config set an individual value in diag configuration file

diag config 用于配置上传数据到 Clinic Server 的 Access Token。获取方式和配置方式请参考 官方文档

使用 Diag 上传数据时,你需要通过 Token 进行用户认证,以保证数据上传到组织后被安全地隔离。获取一个 Token 后,你可以重复使用该 Token。Token 只用于上传数据。

在命令行中,对 diag 配置 Token:

1
2
3
4
shawnyan@centos7:~$ tiup diag config clinic.token eyJ***
tiup is checking updates for component diag ...
Starting component `diag`: /home/shawnyan/.tiup/components/diag/v0.7.0/diag /home/shawnyan/.tiup/components/diag/v0.7.0/diag config clinic.token eyJ***
shawnyan@centos7:~$

由于篇幅有限,diag 后接命令的详细参数这里就不展开讲解了,感兴趣的读者可以自行比对。

此外,用于收集操作系统和硬件信息的 insight 工具也已并入 diag 包,便于 Clinic 收集集群节点信息,并输出到 insight.json 文件中。

1
tiup diag collect shawnyan-cluster --include="system"

移除 client, serverpushgateway

  • client-v1.9.0-linux-amd64.tar.gz

tiup client 用于连接 TiDB,以替代 mysql client。

  • server-v1.9.0-linux-amd64.tar.gz

tiup server 用于搭建私有仓库,已在之前的文章 TiUP:TiDBAer 必备利器 中详细介绍过,这里不再赘述。

但是,个人认为这个组件应该保留在离线包中,因为内网环境下,需要使用 server 来搭建内部镜像站,已提 Issue#1876 ,期待这个组件可以回归。

  • pushgateway-v0.7.0-linux-amd64.tar.gz

pushgateway 作为独立组件一直保留,但是对于 Grafana 监控系统而言,从 TiDB 2.1.3 版本开始,去掉了 Pushgateway 这个单点组件 。故在 TiDB v6.0 中彻底将其移除可以理解。

tidb-community-toolkit-{version}-linux-amd64.tar.gz 的变化

在 v5.4 版本的包中,只有 7 个可执行的二进制文件,而在 v6.0 中就非常丰富了,除了从 tidb-community-server 包中转移过来的工具,还发生了一些新的变化。

2.jpg

主要体现在,新增了 binlogctl, etcdctlmydumper

binlogctletcdctl 是 server 包里 ctl (ctl-v6.0.0-linux-amd64.tar.gz) 组件里的两个可执行文件,这次更新是将这两个文件单独放置到 toolkit 包中,以配合 TiDB Binlog 和 PD Recover 工具一同使用。

同样的,TiDB 适配版的 mydumper 放到 toolkit 包中,是为了配合 TiDB Lighting 进行数据备份。

总结

TiDB v6.0 离线包的调整,是 TiDB 可管理性增强的具体体现。对于工具组件包的存储、使用也更加便利、直观。这也是私有云数据库的诉求之一。私有云数据库在云数据库时代占有举足轻重的地位,完备的离线安装包可以助力我们快速、高效地在内网环境下搭建数据库集群。相信 TiDB 在后续的版本中会持续加强离线包,并带来更加稳定、强劲的企业级 HTAP 数据库。

参考资料


https://www.modb.pro/db/401830
https://tidb.net/blog/3a05d13c?shareId=fdf35157
https://tidb.net/book/book-rush/manageability/other-features/offline-package

  • Title: TiDB 6.x 新特性解读 | 离线包变更
  • Author: ShawnYan
  • Created at: 2022-05-11 21:05:42
  • Updated at: 2022-05-11 21:05:42
  • Link: https://shawnyan.cn/2022/tidb/tidb-6.0-offline-package/
  • License: This work is licensed under CC BY-NC-SA 4.0.
if (hexo-config('comment.enable') == true && hexo-config('comment.system') != "") { if (hexo-config('comment.system') == "waline") { @require "./waline.styl" } else if (hexo-config('comment.system') == "gitalk") { @require "./gitalk.styl" } else if (hexo-config('comment.system') == "twikoo") { @require "./twikoo.styl" } } .comments-container display inline-block margin-top $spacing-unit width 100% #comment-anchor width 100% height 10px .comment-area-title width 100% margin 10px 0 font-size 1.38rem color var(--default-text-color) font-family 'Consolas', '宋体', sans-serif font-weight bold i color var(--default-text-color) +redefine-tablet() margin 5px 0 font-size 1.2rem