前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >YashanDB离线升级

YashanDB离线升级

原创
作者头像
用户10349277
修改2025-03-28 15:54:41
修改2025-03-28 15:54:41
4700
代码可运行
举报
运行总次数:0
代码可运行

YashanDB支持通过yasboot工具离线升级已部署的数据库,将数据库二进制文件升级到新版本。

Note: 本文中所有路径、版本号、用户、密码与回显信息等仅为示例,请以实际为准。

注意事项

  • 离线升级要求当前数据库无新业务数据产生,请通过应用手段停止用户业务。
  • 请完成升级前准备要求的各项工作后再进行升级。
  • 升级过程需使用YashanDB内置的yasboot工具,该工具的命令选项含义及说明请查阅yasboot。
  • 若升级未成功,请执行离线升级回退。如果回退仍不成功,请联系YashanDB技术支持解决。
  • 升级成功后,需根据运行日志告警判断是否使用过时参数,告警内容请查阅参数配置中参数初始化章节示例。若使用了过时参数,需根据配置参数中对应参数的介绍判断该参数是否因改名而过时,并且是否需要将该过时参数调整为对应的新参数。若新参数未配置,则过时参数的配置值将自动转换为新参数值。
  • 从23.2.0.0版本开始,yasom仲裁选主功能需依赖于已开启操作系统认证。若23.2.0.0以下版本中已开启yasom仲裁选主(升级前准备中会临时关闭该功能),升级至23.2.0.0或以上版本后仍需开启,需先检查并开启操作系统认证,才能保证仲裁选主功能正常使用。
  • 升级成功后,请先确认数据库运行正常再开放用户业务

操作步骤

步骤1:执行全量备份

YashanDB提供两种备份的方式,分别是通过SQL语句和使用yasrman工具,如需了解更多有关备份的语法及说明请查阅备份恢复。

  • SQL语句方式: SQL语句执行备份需登录数据库实例进行操作,可通过执行如下语句执行全量备份: BACKUP DATABASE FULL FORMAT '/home/yashan/full_20221123' TAG 'full' PARALLELISM 3; Copied!
  • yasrman工具方式: 使用yasrman工具进行全量备份须确保在yasrman工具所在服务器上操作,可通过执行如下命令执行全量备份: # 请将password@IP:port修改成设置的sys密码及对应IP地址:端口号 $ yasrman sys/password@IP:port -c "backup cluster tag 'full_1' format 'full_bak_1'" -D /home/yashan/catalog

步骤2:上传新版本安装包

  1. 在执行数据库安装的服务器中创建一个空目录作为升级安装包的临时存放路径。 $ mkdir ~/tmp_upgrade
  2. 将新版安装包上传至该目录中。
  3. 进入升级安装包的存放目录并解压安装包。 $ cd ~/tmp_upgrade $ tar zxf yashandb-23.3.1.100-linux-x86_64.tar.gz

步骤3:升级yasom/yasagent

以下操作均在升级安装包的存放目录中执行,并请根据实际的升级场景选择对应的操作步骤:

  • 22.2.x.x升级至23.2.x.x及以上
  • 23.2.x.x及以上之间升级
场景1:22.2.x.x升级至23.2.x.x及以上

本文将以22.2.4.100版本升级到23.3.1.100版本为例。

代码语言:txt
复制
$ ps -ef | grep -E "yasom|yasagent" | grep -v grep
yashan 102280      1  0 16:24 ?        00:00:00 /data/yashan/yasdb_home/yashandb/22.2.4.100/bin/yasagent --init -c yashandb -l 192.168.1.2:1676 --host-id host0001 -k                  -d
yashan 102323      1  0 16:24 ?        00:00:00 /data/yashan/yasdb_home/yashandb/22.2.4.100/bin/yasom --init -c yashandb -l 192.168.1.2:1675 -k                  -d
# 获取到yasom和yasagent所在的bin目录,执行-h命令,当前版本为22.2.4.100
$ /data/yashan/yasdb_home/yashandb/22.2.4.100/bin/yasom -h
Usages: yasom [<flags>] <command>

yasom daemon process, version: Debug 22.2.4.1001.查看当前yasom与yasagent版本。

若存在yasom与yasagent进程,执行如下命令或操作系统的进程终止命令将其终止。

代码语言:javascript
代码运行次数:0
运行
复制
$ ./bin/yasboot process yasom stop -c yashandb -t hosts.toml && yasboot process yasagent stop -c yashandb -t hosts.toml
stop yasom successfully
stop agent host0002 successfully
stop agent host0001 successfully

其中:

代码语言:javascript
代码运行次数:0
运行
复制
-c, --cluster:需指定为实际的集群名称
-t, --toml:需指定为旧版本(22.2.x)的服务器配置文件

2.使用目标新版本(23.2.x)的yasboot工具托管数据库,其中,join_demo.toml文件中的yasdb_home和node_path参数需指定旧版本(22.2.x)的相应路径。

场景2:23.2.x.x及以上之间升级

本文将以23.2.4.100版本升级到23.3.1.100版本为例。

1.查看当前yasom与yasagent版本。

代码语言:txt
复制
$ ps -ef | grep -E "yasom|yasagent" | grep -v grep
yashan 102280      1  0 16:24 ?        00:00:00 /data/yashan/yasdb_home/yashandb/23.2.4.100/bin/yasagent --init -c yashandb -l 192.168.1.2:1676 --host-id host0001 -k                  -d
yashan 102323      1  0 16:24 ?        00:00:00 /data/yashan/yasdb_home/yashandb/23.2.4.100/bin/yasom --init -c yashandb -l 192.168.1.2:1675 -k                  -d
# 获取到yasom和yasagent所在的bin目录,执行-h命令,当前版本为23.2.4.100
$ /data/yashan/yasdb_home/yashandb/23.2.4.100/bin/yasom -h
Usages: yasom [<flags>] <command>

yasom daemon process, version: Debug 23.2.4.100

升级yasom与yasagent。

代码语言:javascript
代码运行次数:0
运行
复制
$ ./bin/yasboot package upgrade -t /home/yashan/install/hosts.toml -p yashandb-23.3.1.100-linux-x86_64.tar.gz
upgrade package...
install version: yashandb 23.3.1.100
host0001 100% [====================================================================]    3s
upgrade host to yasom...

如需在升级后使用DBLINK功能和更丰富的内置函数(例如GIS Function、LSFA_LISTAGG),需先下载plugin插件包并在升级命令中指定--plugin参数。升级完成后,无法单独安装该插件包

代码语言:javascript
代码运行次数:0
运行
复制
$ ./bin/yasboot package upgrade -t /home/yashan/install/hosts.toml -p yashandb-23.3.1.100-linux-x86_64.tar.gz --plugin yashandb-plugins-all-23.3.1.100-linux-x86_64.tar.gz

参数介绍:

代码语言:javascript
代码运行次数:0
运行
复制
-t, --toml:需指定为旧版本的服务器配置文件hosts.toml
-p, --package:需指定为新版本YashanDB软件包的绝对路径
--plugin:需指定为插件包的绝对路径

3.检查yasom与yasagent升级后的版本。

代码语言:javascript
代码运行次数:0
运行
复制
$ ps -ef | grep -E "yasom|yasagent" | grep -v grep
yashan 103607      1  0 16:32 ?        00:00:00 /data/yashan/yasdb_home/yashandb/23.3.1.100/bin/yasagent -c yashandb -d
yashan 103650      1  0 16:32 ?        00:00:00 /data/yashan/yasdb_home/yashandb/23.3.1.100/bin/yasom -c yashandb -d
# 版本已升级为23.3.1.100

步骤4:升级数据库

以下操作均在升级安装包的存放目录中执行。

Caution: 数据库升级过程中出现任何错误,请执行离线升级回退恢复环境,升级成功后无法回退。

1.查看当前数据库版本

代码语言:txt
复制
$ ./bin/yasboot sql -d sys/password@192.168.1.2:1688 -s 'select version from v$instance;'

VERSION                                                          
---------------------------------------------------------------- 
Release 23.2.4.100 x86_64        
# 当前版本为23.2.4.100        1.查看当前数据库版本。

2.升级数据库。

代码语言:javascript
代码运行次数:0
运行
复制
$ ./bin/yasboot cluster upgrade --cluster yashandb
type | uuid             | name                | hostid | index    | status  | return_code | progress | cost 
-------------------------------------------------------------------------------------------------------------
task | 9d0041edd55f7d4f | UpgradeYasdbCluster | -      | yashandb | SUCCESS | 0           | 100      | 23   
------+------------------+---------------------+--------+----------+---------+-------------+----------+------
task completed, status: SUCCESS

Note: 升级过程中将对旧版本进行备份,备份文件存储于各个服务器的安装目录下的upgrade_tmp/backup中。

3.检查数据库升级后的版本。

代码语言:javascript
代码运行次数:0
运行
复制
$ ./bin/yasboot sql -d sys/password@192.168.1.2:1688 -s 'select version from v$instance;'

VERSION                                                          
---------------------------------------------------------------- 
Release 23.3.1.100 x86_64   
# 版本已升级为23.3.1.100                                     

Note: 如果是共享集群升级场景,升级成功后需要执行一次重启命令: ./bin/yasboot cluster restart -c yashandb

步骤5(可选):升级后操作

  • 更新环境变量 升级操作不会修改服务器的YASDB_HOMEYASDB_DATALD_LIBRARY_PATH以及PATH等环境变量,若配置过环境变量,升级后需更新为新版本数据库相应的环境变量,若不更新直接使用yasdb/yasql等命令会继续指向旧版本数据库
  • 开启或关闭某些配置 若为顺利执行升级操作而临时调整过某些配置(例如关闭仲裁),在升级完成后应按需还原配置(例如重新开启仲裁)。 Note: 从23.2.0.0版本开始,yasom仲裁选主功能需依赖于已开启操作系统认证。若23.2.0.0以下版本中已开启yasom仲裁选主(升级前准备中会临时关闭该功能),升级至23.2.0.0或以上版本后仍需开启,需先检查并开启操作系统认证,才能保证仲裁选主功能正常使用。
  • 开启守护进程 若升级后需开启monit功能,可参考守护进程完成相关配置。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 注意事项
  • 操作步骤
    • 步骤1:执行全量备份
    • 步骤2:上传新版本安装包
    • 步骤3:升级yasom/yasagent
      • 场景1:22.2.x.x升级至23.2.x.x及以上
      • 场景2:23.2.x.x及以上之间升级
    • 步骤4:升级数据库
    • 步骤5(可选):升级后操作
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档