写点什么

TiDB 6.0 新特性解读 | 离线包变更

  • 2022 年 7 月 11 日
  • 本文字数:2272 字

    阅读完需:约 7 分钟

作者: ShawnYan 原文来源:https://tidb.net/blog/3a05d13c


背景

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 个压缩包。



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


for i in `ls tidb-*`; do tar zxf $i; donels tidb-*
复制代码


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


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


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:


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 文件中。


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 包中转移过来的工具,还发生了一些新的变化。



主要体现在,新增了 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 数据库。

参考资料


发布于: 刚刚阅读数: 2
用户头像

TiDB 社区官网:https://tidb.net/ 2021.12.15 加入

TiDB 社区干货传送门是由 TiDB 社区中布道师组委会自发组织的 TiDB 社区优质内容对外宣布的栏目,旨在加深 TiDBer 之间的交流和学习。一起构建有爱、互助、共创共建的 TiDB 社区 https://tidb.net/

评论

发布
暂无评论
TiDB 6.0 新特性解读 | 离线包变更_6.x 实践_TiDB 社区干货传送门_InfoQ写作社区