V8R6小版本升级步骤(单机环境)

在KingbaseES V8R6版本提供了sys_upgrade的升级工具。

sys_upgade介绍

sys_upgrade实现KingbaseES服务器实例版本升级。
sys_upgrade 允许将存储在KingbaseES数据文件中的数据升级到一个更高的KingbaseES主版本,而无需进行主版本升级(例如从 V8R6C4 到 V8R6C5)通常所需的数据转储/重载。
主 KingbaseES 版本通常会加入新的特性,这些新特性常常会更改系统表的布局,但是内部数据存储格式很少改变。 sys_upgrade 使用这一事实来通过创建新系统表并且重用旧的用户数据文件来执行快速升级。
如果未来的主要版本以一种使旧数据格式不可读的方式更改数据存储格式,则 sys_upgrade 将无法用于此类升级。 sys_upgrade 会尽最大努力确保新旧集簇是二进制兼容的,例如,通过检查编译设置是否兼容(是否以 32/64 位编译二进制文件)。
保持外部模块也是二进制兼容的也很重要,尽管 sys_upgrade 无法检查这一点。 sys_upgrade 支持从 V8R6(20211031版本) 及其后版本升级到当前的KingbaseES主版本,包括快照和beta版本。
sys_upgrade 目前暂不支持 Windows 版本的KingbaseES升级。

sys_upgade相关参数

sys_upgrade { -b | --old-bindir } oldbindir { -B | --new-bindir } newbindir { -d | --old-datadir } olddatadir { -D | --new-datadir } newdatadir [ option ...]

参数说明

sys_upgrade 接受下列命令行参数:

-b bindir --old-bindir= bindir  --旧的 KingbaseES 可执行文件目录; 环境变量 KBBINOLD
-B bindir --new-bindir= bindir  --新的 KingbaseES 可执行文件目录; 环境变量 KBBINNEW
-c --check  --只检查集簇,不更改任何数据。
-d datadir --old-datadir= datadir  旧的集簇数据目录;环境变量 KBDATAOLD
-D datadir --new-datadir= datadir  新的集簇数据目录;环境变量 KBDATANEW 
-j --jobs  --要同时使用的进程或线程数。
-k --link  --使用硬链接来代替将文件拷贝到新集簇。
-o options --old-options options --直接传送给旧 kingbase 命令的选项,多个选项可以追加在后面。
-O options --new-options options --直接传送给新 kingbase 命令的选项,多个选项可以追加在后面。
-p port --old-port= port --旧的集簇端口号;环境变量 KBPORTOLD 。
-P port --new-port= port --新的集簇端口号;环境变量 KBPORTNEW 。
-r --retain  --即使在成功完成后也保留 SQL 和日志文件。
-s dir --socketdir=dir  --升级期间用于 kingbase 套接字的目录;默认为当前工作目录;环境变量 KINGBASE_SOCKETDIR 。
-U username --username= username --集簇的安装用户名;环境变量 KBUSER 。
-v --verbose  --启用详细的内部日志。
-V --version  --显示版本信息,然后退出。
--clone --使用高效的文件拷贝(在某些系统上也称为 reflinks ),而不是将文件复制到新集簇。这会导致数据文件近乎即时复制,从而在不影响旧集簇的同时提供 -k/--link 的速度优势。
文件拷贝仅在某些操作系统和文件系统上受支持。如果它被选中但不受支持,则 sys_upgrade 运行将出错。目前,它在带有 Btrfs 和 XFS(在使用 reflink 支持创建的文件系统上)的 Linux(内核 4.5 或更高版本)以及带有 APFS 的 macOS 上受支持。
-? --help  --显示帮助,然后退出。

参考文档:https://help.kingbase.com.cn/v8/admin/reference/ref-server/sys_upgrade.html?highlight=sys_upgr

升级需求

将Kingbase V008R006C005B0023升级至V008R006C008B0014

原版本库构建测试数据

ksql -Usystem test -p 54321
create database fuwa;
\c fuwa system
create table tbl_batch2 (id int4,info text); 
insert into tbl_batch2(id,info) 
select generate_series(1,1000),'batch2'; 
select * from tbl_batch2;create database yangbao;
\c yangbao system
create table tbl_batch2 (id int4,info text); 
insert into tbl_batch2(id,info) 
select generate_series(1,1000),'batch2'; 
select * from tbl_batch2;

升级步骤

升级前查看数据库版本信息

--查看进程,确定正在使用的安装目录和数据目录
[root@node1 ~]# ps -ef | grep Kingbase 
kingbase  12139      1  0 15:38 ?        00:00:00 /KingbaseES/V8/Server/bin/kingbase -D /data#升级前查数据库版本
法一:
[root@node1 ~]# /KingbaseES/V8/Server/bin/ksql -V
ksql (Kingbase) V008R006C005B0023法二:
[kingbase@node1 ~]$ ksql -Usystem -W test -p 54327
口令:
ksql (V8.0)
test=# select version();version                                                        
----------------------------------------------------------------------------------------------------------------------KingbaseES V008R006C005B0023 on x86_64-pc-linux-gnu, compiled by gcc (GCC) 4.1.2 20080704 (Red Hat 4.1.2-46), 64-bit
(1 行记录)版本说明:
V008R006C005B0023 为整个详细版本号
V008为大版本号
R006为版本号 R006即为R6 R003为R3
C005B0023为小版本号

如果旧版本数据库中有新增插件相关的so 库,而新版本数据库中没有的,需要把相关so 拷贝到新版本数据库lib 目录下。

升级前查看原版本相关参数配置

必须保证升级前后版本的数据库字符集及lc_ctype一致。
将sys_hba.conf的认证改为trust,升级期间,便于新旧版本之间访问连接。

--查看进程,确定正在使用的安装目录和数据目录
[root@node1 ~]# ps -ef | grep Kingbase 
kingbase  12139      1  0 15:38 ?        00:00:00 /KingbaseES/V8/Server/bin/kingbase -D /data--关闭原版本的归档
[kingbase@node1 ~]$ cd /data/
[kingbase@node1 data]$ cp kingbase.conf kingbase.conf_bak_`date +%F`
[kingbase@node101 data]$ cat kingbase.conf |grep archive_mode
archive_mode = off              # enables archiving; off, on, or always--编辑原版本sys_hba.conf文件
[kingbase@node101 ]$ cd /data
[kingbase@node101 data]$ cp sys_hba.conf sys_hba.conf_bak_`date +%F`
[kingbase@node101 data]$ sed -i "s/scram-sha-256/trust/g" sys_hba.conf
[kingbase@node101 data]$ cat sys_hba.conf
.......
# TYPE  DATABASE        USER            ADDRESS                 METHOD# "local" is for Unix domain socket connections only
local   all             all                                     trust
# IPv4 local connections:
host    all             all             127.0.0.1/32            trust
host    all             all             0.0.0.0/0               trust
# IPv6 local connections:
host    all             all             ::1/128                 trust
host    all             all             ::0/0                   trust
# Allow replication connections from localhost, by a user with the
# replication privilege.
local   replication     all                                     trust
host    replication     all             127.0.0.1/32            trust
host    replication     all             ::1/128                 trust--编辑原版本kingbase.conf文件
将端口更改为54327
[kingbase@node1 bin]$ vi /data/kingbase.conf
port = 54327 --重启老的数据库实例
[kingbase@node1 ~]$ /KingbaseES/V8/Server/bin/sys_ctl restart -D /datatest=# show server_encoding;server_encoding 
-----------------UTF8
(1 row)test=# show port;port  
-------54327
(1 行记录)--重启数据库test=# \l+List of databases
yangbao=# \l+数据库列表名称    | 拥有者 | 字元编码 |  校对规则   |    Ctype    |     存取权限      | 大小  |   表空间    |                    描述                    
-----------+--------+----------+-------------+-------------+-------------------+-------+-------------+--------------------------------------------fuwa      | system | UTF8     | zh_CN.UTF-8 | zh_CN.UTF-8 |                   | 13 MB | sys_default | security  | system | UTF8     | zh_CN.UTF-8 | zh_CN.UTF-8 |                   | 12 MB | sys_default | template0 | system | UTF8     | zh_CN.UTF-8 | zh_CN.UTF-8 | =c/system        +| 12 MB | sys_default | unmodifiable empty database|        |          |             |             | system=CTc/system |       |             | template1 | system | UTF8     | zh_CN.UTF-8 | zh_CN.UTF-8 | =c/system        +| 13 MB | sys_default | default template for new databases|        |          |             |             | system=CTc/system |       |             | test      | system | UTF8     | zh_CN.UTF-8 | zh_CN.UTF-8 |                   | 13 MB | sys_default | default administrative connection databaseyangbao   | system | UTF8     | zh_CN.UTF-8 | zh_CN.UTF-8 |                   | 13 MB | sys_default | 
(6 行记录)test=# show block_size;block_size 
------------8192
(1 row)test=# show wal_segment_size;wal_segment_size 
------------------16MB
(1 row)test=# show enable_ci;   --off是敏感,on是不敏感enable_ci 
-----------off
(1 row)test=# show database_mode;database_mode 
---------------oracle
(1 row)--查看已创建的扩展
test=# \dx已安装扩展列表名称         | 版本 |  架构模式  |                                                        描述                                                    ---------------------+------+------------+----------------------------------------------------------------------------------------------------------------
-----dbms_ddl            | 1.0  | sys        | DBMS_DDL system packagedbms_output         | 1.0  | sys        | DBMS_OUTPUT system packagedbms_utility        | 1.0  | sys        | dbms_utility extension packagekdb_cast            | 1.0  | sys        | kdb_cast extensionkdb_license         | 1.0  | pg_catalog | kdb_license extensionkdb_oracle_datatype | 1.1  | sys        | kdb_oracle_datatype extensionkdb_schedule        | 1.0  | sys        | A KingbaseES job schedulerkdb_tinyint         | 1.0  | pg_catalog | Create a new data type tinyint and its functions operators and indexeskingbase_version    | 1.0  | pg_catalog | This is a utility that provides function related to version number,  it is used to get the Kingbase version num
ber.owa_util            | 1.0  | sys        | owa_util system packageplpgsql             | 1.0  | pg_catalog | PL/pgSQL procedural languageplsql               | 1.0  | pg_catalog | PL/SQL procedural languagesys_freespacemap    | 1.2  | sys        | examine the free space map (FSM)sys_stat_statements | 1.9  | public     | track parsing, planning and execution statistics of all SQL statements executedsysaudit            | 1.0  | sysaudit   | provides auditing functionalitysysmac              | 1.0  | sysmac     | Mac for Kingbasexlog_record_read    | 1.0  | pg_catalog | xlog_record_read functions
(17 行记录)

安装新版本数据库软件及初始化新的实例

注意:

  • 新版本和旧版本的相关参数:字符集、lc_ctype、数据块大小保证一致。
  • 必须使用旧版本数据库initdb时使用的操作系统用户。
  • 必须使用和旧版本数据库一样的数据库用户,及-U 参数保持一致。
  • block_size 和wal_segsize 必须和旧版本数据库的data 保持一致。
  • initdb 初始化的所有参数必须和旧版本数据库initdb 时保持一致。
  • 若不一致,在后续的升级兼容性检查也会检测出具体信息。

安装新版数据库软件

下载新版数据库软件和相应的授权文件
  • 新版数据库软件下载地址:

https://kingbase.oss-cn-beijing.aliyuncs.com/KESV8R3/V008R006C008B0014/KingbaseES_V008R006C008B0014_Lin64_install.iso
上传至/opt
image.png

  • 数据库授权文件下载地址:https://www.kingbase.com.cn/xzzx/index.htm

授权文件下载后本地解压然后再上传至服务器/home/kingbase目录下
image.png

规划新版本数据库安装目录和数据目录

新安装目录:/KingbaseESV8R60814
新数据目录:/dataV8R60814
新实例端口:54321

su - root
mkdir -p /KingbaseESV8R60814
mkdir -p /dataV8R60814
mkdir -p /home/kingbase/installdir_`date +%F`
chown kingbase:kingbase /home/kingbase/license*.dat
chown -R kingbase:kingbase /KingbaseESV8R60814
chown -R kingbase:kingbase /dataV8R60814
chown -R kingbase:kingbase /home/kingbase/installdir*
安装新版本数据库软件和初始化数据库实例
--挂载镜像
[root@node1 opt]# mount /opt/KingbaseES_V008R006C008B0014_Lin64_install.iso /mnt
mount: /dev/loop0 写保护,将以只读方式挂载--安装
[root@node1 opt]# cd /mnt
[root@node1 mnt]# ls -l
总用量 6
dr-xr-xr-x. 2 root root 2048 9月   2 04:59 setup
-r-xr-xr-x. 1 root root 3933 9月   2 04:59 setup.sh[root@node1 mnt]# cp -r /mnt/* /home/kingbase/installdir_2024-01-02/
[root@node1 mnt]# chown -R kingbase:kingbase /home/kingbase/installdir_2024-01-02/[kingbase@node1 ~]$ cd installdir_2024-01-02/
[kingbase@node1 installdir_2024-01-02]$ export LANG=zh_CN.UTF-8
[kingbase@node1 installdir_2024-01-02]$ ./setup.sh -i console或
分成2个步骤:
(1)安装数据库软件
(2)初始化实例
export LANG=zh_CN.UTF-8
cd /KingbaseESV8R60814/Server/bin/
./initdb -U system -W --enable-ci -E utf8 --lc-ctype="zh_CN.UTF-8" -D /dataV8R60814--更改端口为54327
[kingbase@node1 bin]$ vi /dataV8R60814/kingbase.conf
port = 54321 --启动数据库
/KingbaseESV8R60814/Server/bin/sys_ctl start -D /dataV8R60814[kingbase@node1 installdir_2024-01-02]$ cat /KingbaseESV8R60814/install/script/root.sh
#查看新版本数据库信息
[root@node1 opt]# /KingbaseESV8R60814/Server/bin/ksql -Usystem test  -p 54327
ksql (V8.0)
Type "help" for help.test=# \l+数据库列表名称    | 拥有者 | 字元编码 |  校对规则   |    Ctype    |     存取权限      | 大小  |   表空间    |                    描述                    
-----------+--------+----------+-------------+-------------+-------------------+-------+-------------+--------------------------------------------kingbase  | system | UTF8     | zh_CN.UTF-8 | zh_CN.UTF-8 |                   | 11 MB | sys_default | default administrative connection databasesecurity  | system | UTF8     | zh_CN.UTF-8 | zh_CN.UTF-8 |                   | 11 MB | sys_default | template0 | system | UTF8     | zh_CN.UTF-8 | zh_CN.UTF-8 | =c/system        +| 11 MB | sys_default | unmodifiable empty database|        |          |             |             | system=CTc/system |       |             | template1 | system | UTF8     | zh_CN.UTF-8 | zh_CN.UTF-8 | =c/system        +| 11 MB | sys_default | default template for new databases|        |          |             |             | system=CTc/system |       |             | test      | system | UTF8     | zh_CN.UTF-8 | zh_CN.UTF-8 |                   | 11 MB | sys_default | default administrative connection database
(5 行记录)test=# show block_size;block_size 
------------8192
(1 行记录)test=# show wal_segment_size;wal_segment_size 
------------------16MB
(1 行记录)test=# show enable_ci;   --off是敏感,on是不敏感enable_ci 
-----------off
(1 row)test=# show database_mode;database_mode 
---------------oracle
(1 row)--对system用户登录信息加入密码文件
[kingbase@node1 ~]$ sys_encpwd -H \* -P \* -D \* -U system -W kingbase
[kingbase@node1 ~]$ cat .encpwd 
*:*:*:system:a2luZ2Jhc2U=

安装扩展共享对象文件

许多扩展和自定义模块,无论是来自contrib还是其他来源,都使用共享对象文件(或 DLL),例如 kbcrypto.so ,如果旧集簇使用它,则必须在新集簇中安装与新服务器二进制文件匹配的共享对象文件,通常通过操作系统命令。
不要加载模式定义,例如,CREATE EXTENSION kbcrypto,因为它们将从旧集群中复制。如果扩展更新可用, sys_upgrade 将报告此情况并创建一个可以稍后运行以更新它们的脚本。

将原版本相关配置文件拷贝到新版本下

[kingbase@node1 bin]$ cp /data/kingbase.conf /dataV8R60814/kingbase.conf 
[kingbase@node1 bin]$ cp /data/kingbase.auto.conf /dataV8R60814/kingbase.auto.conf 
[kingbase@node1 bin]$ cp /data/sys_hba.conf /dataV8R60814/sys_hba.conf --更改端口为54327
[kingbase@node1 bin]$ vi /dataV8R60814/kingbase.conf
port = 54327 --去掉kingbase.conf中
[kingbase@node1 data]$ vi /dataV8R60814/kingbase.conf 
shared_preload_libraries = 'liboracle_parser, synonym, plsql, force_view, kdb_flashback,plugin_debugger, plsql_plugin_debugger, plsql_plprofiler, ora_commands,kdb_ora_expr, sepapower, dblink, sys_kwr, sys_ksh, sys_spacequota, sys_stat_statements, backtrace, kdb_utils_function'
去掉ora_commands  和 sys_ksh

关闭新旧2套数据库服务

--关闭老的数据库实例
[kingbase@node1 ~]$ /KingbaseES/V8/Server/bin/sys_ctl stop -D /data--关闭新的数据库实例
[kingbase@node1 ~]$ /KingbaseESV8R60814/Server/bin/sys_ctl stop -D /dataV8R60814/

原数据库执行物理备份

备份数据目录

[kingbase@node1 ~]$ cp -r /data /home/kingbase/data_bak_`date +%F`
或压缩备份(不建议)
[kingbase@node1 ~]$ tar -cvf /home/kingbase/data_bak_`date +%F`.tar.gz /data

版本升级前兼容性检查

在新版本数据库bin目录下执行sys_upgrade工具

[kingbase@node1 ~]$ /KingbaseESV8R60814/Server/bin/sys_upgrade -b /KingbaseES/V8/Server/bin -B /KingbaseESV8R60814/Server/bin -d /data -D /dataV8R60814 -c -p 54321 -P 54327 -U system
正在执行一致性检查
-----------------------------
Checking cluster versions                                   ok
Checking database safety function switch is off             ok
Checking for extension that do not support upgrading        ok
Checking database user is the install user                  ok
Checking database connection settings                       ok
Checking for prepared transactions                          ok
Checking for reg* data types in user tables                 ok
Checking for contrib/isn with bigint-passing mismatch       ok
Checking for presence of required libraries                 ok
Checking database user is the install user                  ok
Checking for prepared transactions                          ok*集簇是兼容的*

如上所示,新旧版本之间兼容性检查通过。
参数说明:

-b bindir --old-bindir= bindir  --旧的 KingbaseES 可执行文件目录 绝对路径; 环境变量 KBBINOLD 。
-B bindir --new-bindir= bindir  --新的 KingbaseES 可执行文件目录 绝对路径; 环境变量 KBBINNEW 。
-c --check --只检查集簇,不更改任何数据。
-d datadir --old-datadir= datadir  --旧的集簇数据目录 绝对路径;环境变量 KBDATAOLD 。
-D datadir --new-datadir= datadir --新的集簇数据目录 绝对路径;环境变量 KBDATANEW 。
-j --jobs --要同时使用的进程或线程数。
-k --link --使用硬链接来代替将文件拷贝到新集簇。
-o options --old-options options --直接传送给旧 kingbase 命令的选项,多个选项可以追加在后面。
-O options --new-options options --直接传送给新 kingbase 命令的选项,多个选项可以追加在后面。
-p port --old-port= port --旧的集簇端口号;环境变量 KBPORTOLD 。
-P port --new-port= port --新的集簇端口号;环境变量 KBPORTNEW 。
-r --retain --即使在成功完成后也保留 SQL 和日志文件。
-s dir --socketdir=dir  --升级期间用于 kingbase 套接字的目录;默认为当前工作目录;环境变量 KINGBASE_SOCKETDIR 。
-U username --username= username  --集簇的安装用户名;环境变量 KBUSER 。
-v --verbose  --启用详细的内部日志。
-V --version --显示版本信息,然后退出。
--clone --使用高效的文件拷贝(在某些系统上也称为 reflinks ),而不是将文件复制到新集簇。这会导致数据文件近乎即时复制,从而在不影响旧集簇的同时提供 -k/--link 的速度优势。
文件拷贝仅在某些操作系统和文件系统上受支持。如果它被选中但不受支持,则 sys_upgrade 运行将出错。目前,它在带有 Btrfs 和 XFS(在使用 reflink 支持创建的文件系统上)的 Linux(内核 4.5 或更高版本)以及带有 APFS 的 macOS 上受支持。
-? --help  --显示帮助,然后退出。

问题处理

好像有一个KingbaseES正在为新集簇服务
--问题描述:
/KingbaseESV8R60814/Server/bin/sys_upgrade -b /KingbaseES/V8/Server/bin -B /KingbaseESV8R60814/Server/bin -d /data -D /dataV8R60814 -c -p 54327 -P 54321 -U system
好像有一个KingbaseES正在为新集簇服务。
请关闭那个KingbaseES,然后再试一次。
故障,退出--解决办法:
新旧2套数据库实例服务均需要停止,升级过程中有启动实例的操作。
无法访问文件 “ora_commands”
--问题处理
command: "/KingbaseESV8R60814/Server/bin/sys_ctl" -w -l "sys_upgrade_server.log" -D "/dataV8R60814" -o "-p 54327 -b -c synchronous_commit=off -c fsync=off -c full_page_writes=off  -c listen_addresses='' -c unix_socket_permissions=0700 -c unix_socket_directories='/data'" start >> "sys_upgrade_server.log" 2>&1
等待服务器进程启动 ....2024-01-02 11:50:30.696 GMT [10222] 警告:  max_connections should be less than or equal than 10 (restricted by license)
2024-01-02 11:50:30.696 GMT [10222] 提示:  max_connect的值设置为 10
2024-01-02 11:50:30.696 GMT [10222] 警告:  max_connections should be less than or equal than 10 (restricted by license)
2024-01-02 11:50:30.696 GMT [10222] 提示:  max_connect的值设置为 10
2024-01-02 19:50:30.699 CST [10222] 致命错误:  无法访问文件 "ora_commands": 没有那个文件或目录
2024-01-02 19:50:30.699 CST [10222] 日志:  数据库系统已关闭已停止等待
sys_ctl: 无法启动服务器进程
检查日志输出.--解决办法
[kingbase@node1 data]$ vi /dataV8R60814/kingbase.conf 
shared_preload_libraries = 'liboracle_parser, synonym, plsql, force_view, kdb_flashback,plugin_debugger, plsql_plugin_debugger, plsql_plprofiler, ora_commands,kdb_ora_expr, sepapower, dblink, sys_kwr, sys_ksh, sys_spacequota, sys_stat_statements, backtrace, kdb_utils_function'
去掉ora_commands
无法访问文件 “sys_ksh”: 没有那个文件或目录
--问题处理
等待服务器进程启动 ....2024-01-02 11:52:16.226 GMT [10348] 警告:  max_connections should be less than or equal than 10 (restricted by license)
2024-01-02 11:52:16.226 GMT [10348] 提示:  max_connect的值设置为 10
2024-01-02 11:52:16.226 GMT [10348] 警告:  max_connections should be less than or equal than 10 (restricted by license)
2024-01-02 11:52:16.226 GMT [10348] 提示:  max_connect的值设置为 10
2024-01-02 19:52:16.229 CST [10348] 日志:  sepapower扩展初始化完成
2024-01-02 19:52:16.231 CST [10348] 日志:  太多后台工作进程
2024-01-02 19:52:16.231 CST [10348] 详细信息:  当前设置里最多可以注册2个后台工作进程.
2024-01-02 19:52:16.231 CST [10348] 提示:  考虑增大配置参数 "max_worker_processes"的值.
2024-01-02 19:52:16.231 CST [10348] 日志:  太多后台工作进程
2024-01-02 19:52:16.231 CST [10348] 详细信息:  当前设置里最多可以注册2个后台工作进程.
2024-01-02 19:52:16.231 CST [10348] 提示:  考虑增大配置参数 "max_worker_processes"的值.
2024-01-02 19:52:16.231 CST [10348] 致命错误:  无法访问文件 "sys_ksh": 没有那个文件或目录
2024-01-02 19:52:16.231 CST [10348] 日志:  数据库系统已关闭已停止等待
sys_ctl: 无法启动服务器进程
检查日志输出.--解决办法
[kingbase@node1 data]$ vi /dataV8R60814/kingbase.conf 
shared_preload_libraries = 'liboracle_parser, synonym, plsql, force_view, kdb_flashback,plugin_debugger, plsql_plugin_debugger, plsql_plprofiler, ora_commands,kdb_ora_expr, sepapower, dblink, sys_kwr, sys_ksh, sys_spacequota, sys_stat_statements, backtrace, kdb_utils_function'
去掉sys_ksh
连接到数据库失败: fe_sendauth: no password supplied
--问题描述
[kingbase@node1 ~]$ /KingbaseESV8R60814/Server/bin/sys_upgrade -b /KingbaseES/V8/Server/bin -B /KingbaseESV8R60814/Server/bin -d /data -D /dataV8R60814 -c -p 54321 -P 54327 -U system
正在执行一致性检查
-----------------------------
Checking cluster versions                                   ok
Checking database safety function switch is off             ok
Checking for extension that do not support upgrading        ok
Checking database user is the install user                  ok
Checking database connection settings                       ok
Checking for prepared transactions                          ok
Checking for reg* data types in user tables                 ok
Checking for contrib/isn with bigint-passing mismatch       ok连接到数据库失败: fe_sendauth: no password supplied无法连接到用命令启动的目标KingbaseES :
"/KingbaseESV8R60814/Server/bin/sys_ctl" -w -l "sys_upgrade_server.log" -D "/dataV8R60814" -o "-p 54327 -b -c synchronous_commit=off -c fsync=off -c full_page_writes=off  -c listen_addresses='' -c unix_socket_permissions=0700 -c unix_socket_directories='/home/kingbase'" start
故障,退出--解决办法
创建密码文件
[kingbase@node1 ~]$ sys_encpwd -H \* -P \* -D \* -U system -W kingbase
再次升级检查
[kingbase@node1 ~]$ /KingbaseESV8R60814/Server/bin/sys_upgrade -b /KingbaseES/V8/Server/bin -B /KingbaseESV8R60814/Server/bin -d /data -D /dataV8R60814 -c -p 54321 -P 54327 -U system
正在执行一致性检查
-----------------------------
Checking cluster versions                                   ok
Checking database safety function switch is off             ok
Checking for extension that do not support upgrading        ok
Checking database user is the install user                  ok
Checking database connection settings                       ok
Checking for prepared transactions                          ok
Checking for reg* data types in user tables                 ok
Checking for contrib/isn with bigint-passing mismatch       ok
Checking for presence of required libraries                 ok
Checking database user is the install user                  ok
Checking for prepared transactions                          ok*集簇是兼容的*

执行版本升级

Tips: 升级前对原数据库执行物理备份。
在新版本数据库bin目录下执行sys_upgrade工具

[kingbase@node1 ~]$ /KingbaseESV8R60814/Server/bin/sys_upgrade -b /KingbaseES/V8/Server/bin -B /KingbaseESV8R60814/Server/bin -d /data -D /dataV8R60814  -p 54321 -P 54327 -U system
正在执行一致性检查
-----------------------------
Checking cluster versions                                   ok
Checking database safety function switch is off             ok
Checking for extension that do not support upgrading        ok
Checking database user is the install user                  ok
Checking database connection settings                       ok
Checking for prepared transactions                          ok
Checking for reg* data types in user tables                 ok
Checking for contrib/isn with bigint-passing mismatch       ok
Creating dump of global objects                             ok
Creating dump of database schemasok
Checking for presence of required libraries                 ok
Checking database user is the install user                  ok
Checking for prepared transactions                          ok如果sys_upgrade在这一点之后失败,在继续之前必须重新初始化新集群.正在执行升级
------------
Analyzing all rows in the new cluster                       ok
Freezing all rows in the new cluster                        ok
Deleting files from new sys_xact                            ok
Copying old sys_xact to new server                          ok
Setting next transaction ID and epoch for new cluster       ok
Deleting files from new sys_multixact/offsets               ok
Copying old sys_multixact/offsets to new server             ok
Deleting files from new sys_multixact/members               ok
Copying old sys_multixact/members to new server             ok
Setting next multixact ID and offset for new cluster        ok
Resetting WAL archives                                      ok
Copying wallet files                                        ok
Setting frozenxid and minmxid counters in new cluster       ok
Restoring global objects in the new cluster                 ok
Restoring database schemas in the new clusterok
正在复制用户关系文件ok
复制用户cstotre_fdw文件ok
复制全局关系文件ok
Setting next OID for new cluster                            ok
Sync data directory to disk                                 ok
Creating script to analyze new cluster                      ok
Creating script to delete old cluster                       ok升级完成
--------
Optimizer statistics are not transferred by sys_upgrade so,
once you start the new server, consider running:./analyze_new_cluster.sh --port KBPORT运行此脚本将删除旧集簇的数据文件:./delete_old_cluster.sh

问题处理

[kingbase@node1 data]$ /KingbaseESV8R60814/Server/bin/sys_upgrade -b /KingbaseES/V8/Server/bin -B /KingbaseESV8R60814/Server/bin -d /data -D /dataV8R60814  -p 54321 -P 54327 -U system
正在执行一致性检查
-----------------------------
Checking cluster versions                                   ok
Checking database safety function switch is off             ok
Checking for extension that do not support upgrading        ok
Checking database user is the install user                  ok
Checking database connection settings                       ok
Checking for prepared transactions                          ok
Checking for reg* data types in user tables                 ok
Checking for contrib/isn with bigint-passing mismatch       ok
Creating dump of global objects                             ok
Creating dump of database schemasok
Checking for presence of required libraries                 ok
Checking database user is the install user                  ok
Checking for prepared transactions                          ok如果sys_upgrade在这一点之后失败,在继续之前必须重新初始化新集群.正在执行升级
------------
Analyzing all rows in the new cluster                       ok
Freezing all rows in the new cluster                        ok
Deleting files from new sys_xact                            ok
Copying old sys_xact to new server                          ok
Setting next transaction ID and epoch for new cluster       ok
Deleting files from new sys_multixact/offsets               ok
Copying old sys_multixact/offsets to new server             ok
Deleting files from new sys_multixact/members               ok
Copying old sys_multixact/members to new server             ok
Setting next multixact ID and offset for new cluster        ok
Resetting WAL archives                                      ok
Copying wallet files                                        
*failure*有关故障的可能原因,请查阅"sys_upgrade_utility.log"的最后几行。
故障,退出--查看日志
tail -500f sys_upgrade_utility.log
command: "/KingbaseESV8R60814/Server/bin/sys_resetwal" -O 0 -m 1,1 "/dataV8R60814" >> "sys_upgrade_utility.log" 2>&1
重置预写日志
command: "/KingbaseESV8R60814/Server/bin/sys_resetwal" -l 000000010000000000000003 "/dataV8R60814" >> "sys_upgrade_utility.log" 2>&1
重置预写日志
command: cp -Rf "/data/.wallet" "/dataV8R60814" >> "sys_upgrade_utility.log" 2>&1
cp: 无法获取"/data/.wallet" 的文件状态(stat): 没有那个文件或目录
....--原因
将原版本/data目前删除,解压备份文件至/data
/data/目录下无.wallet导致,恢复快照

启动新数据库实例

[kingbase@node1 ~]$ /KingbaseESV8R60814/Server/bin/sys_ctl start -D /dataV8R60814/

对升级后的数据库执行统计分析

-查看统计分析脚本文件位置
[kingbase@node1 ~]$ ls -l
总用量 20
-rwx------. 1 kingbase kingbase  991 1月   2 15:13 analyze_new_cluster.sh
-rwx------. 1 kingbase kingbase   26 1月   2 15:13 delete_old_cluster.sh--执行统计分析脚本
[kingbase@node1 ~]$ ./analyze_new_cluster.sh --port 54327
This script will generate minimal optimizer statistics rapidly
so your system is usable, and then gather statistics twice more
with increasing accuracy.  When it is done, your system will
have the default level of optimizer statistics.If you have used ALTER TABLE to modify the statistics target for
any tables, you might want to remove them and restore them after
running this script because they will delay fast statistics generation.If you would like default statistics as quickly as possible, cancel
this script and run:"/KingbaseESV8R60814/Server/bin/vacuumdb" -U system --all --analyze-only --port KBPORTvacuumdb: processing database "kingbase": Generating minimal optimizer statistics (1 target)
警告:  跳过 “_kingbase_loginfo”---无法分析全局临时表
vacuumdb: processing database "security": Generating minimal optimizer statistics (1 target)
警告:  跳过 “_kingbase_loginfo”---无法分析全局临时表
vacuumdb: processing database "template1": Generating minimal optimizer statistics (1 target)
警告:  跳过 “_kingbase_loginfo”---无法分析全局临时表
vacuumdb: processing database "test": Generating minimal optimizer statistics (1 target)
警告:  跳过 “_kingbase_loginfo”---无法分析全局临时表
vacuumdb: processing database "kingbase": Generating medium optimizer statistics (10 targets)
警告:  跳过 “_kingbase_loginfo”---无法分析全局临时表
vacuumdb: processing database "security": Generating medium optimizer statistics (10 targets)
警告:  跳过 “_kingbase_loginfo”---无法分析全局临时表
vacuumdb: processing database "template1": Generating medium optimizer statistics (10 targets)
警告:  跳过 “_kingbase_loginfo”---无法分析全局临时表
vacuumdb: processing database "test": Generating medium optimizer statistics (10 targets)
警告:  跳过 “_kingbase_loginfo”---无法分析全局临时表
vacuumdb: processing database "kingbase": Generating default (full) optimizer statistics
警告:  跳过 “_kingbase_loginfo”---无法分析全局临时表
vacuumdb: processing database "security": Generating default (full) optimizer statistics
警告:  跳过 “_kingbase_loginfo”---无法分析全局临时表
vacuumdb: processing database "template1": Generating default (full) optimizer statistics
警告:  跳过 “_kingbase_loginfo”---无法分析全局临时表
vacuumdb: processing database "test": Generating default (full) optimizer statistics
警告:  跳过 “_kingbase_loginfo”---无法分析全局临时表Done
[kingbase@node1 ~]$ "/KingbaseESV8R60814/Server/bin/vacuumdb" -U system --all --analyze-only --port 54327
vacuumdb: vacuuming database "kingbase"
警告:  跳过 “_kingbase_loginfo”---无法分析全局临时表
vacuumdb: vacuuming database "security"
警告:  跳过 “_kingbase_loginfo”---无法分析全局临时表
vacuumdb: vacuuming database "template1"
警告:  跳过 “_kingbase_loginfo”---无法分析全局临时表
vacuumdb: vacuuming database "test"
警告:  跳过 “_kingbase_loginfo”---无法分析全局临时表

如上所示,数据库升级完成。

查看新版本数据库数据(应该和原版本数据一致)


[kingbase@node1 ~]$ cd /KingbaseESV8R60814/Server/bin/
[kingbase@node1 bin]$ ./ksql -U system test -p 54327
输入 "help" 来获取帮助信息.test=# \l+数据库列表名称    | 拥有者 | 字元编码 |  校对规则   |    Ctype    |     存取权限      | 大小  |   表空间    |                    描述                    
-----------+--------+----------+-------------+-------------+-------------------+-------+-------------+--------------------------------------------fuwa      | system | UTF8     | zh_CN.UTF-8 | zh_CN.UTF-8 |                   | 15 MB | sys_default | kingbase  | system | UTF8     | zh_CN.UTF-8 | zh_CN.UTF-8 |                   | 14 MB | sys_default | default administrative connection databasesecurity  | system | UTF8     | zh_CN.UTF-8 | zh_CN.UTF-8 |                   | 14 MB | sys_default | template0 | system | UTF8     | zh_CN.UTF-8 | zh_CN.UTF-8 | =c/system        +| 14 MB | sys_default | unmodifiable empty database|        |          |             |             | system=CTc/system |       |             | template1 | system | UTF8     | zh_CN.UTF-8 | zh_CN.UTF-8 | system=CTc/system+| 15 MB | sys_default | default template for new databases|        |          |             |             | =c/system         |       |             | test      | system | UTF8     | zh_CN.UTF-8 | zh_CN.UTF-8 |                   | 15 MB | sys_default | default administrative connection databaseyangbao   | system | UTF8     | zh_CN.UTF-8 | zh_CN.UTF-8 |                   | 15 MB | sys_default | 
(7 行记录)test=# \c fuwa system
You are now connected to database "fuwa" as userName "system".
fuwa=# select * from tbl_batch2 limit 10;id |  info  
----+--------1 | batch22 | batch23 | batch24 | batch25 | batch26 | batch27 | batch28 | batch29 | batch210 | batch2
(10 行记录)

删除原版本数据(慎重)

如果服务器磁盘空间充足,该步骤可省略。

--在新版本数据库bin目录下执行清理脚本
[kingbase@node1 ~]$ cd
[kingbase@node1 ~]$ ls -l
总用量 113668
-rwx------. 1 kingbase kingbase       991 1月   2 19:25 analyze_new_cluster.sh
-rw-rw-r--. 1 kingbase kingbase 116367360 1月   2 19:25 data_bak_2024-01-02.tar.gz
-rwx------. 1 kingbase kingbase        26 1月   2 19:25 delete_old_cluster.sh[root@node1 ~]# cd /home/kingbase/
[root@node1 kingbase]# ./delete_old_cluster.sh #原版本data目录下数据已经被删除
[root@node1 kingbase]# ls -l /data
ls: 无法访问/data: 没有那个文件或目录

原版本数据库相关数据文件被删除。
参考链接:https://juejin.cn/post/7236930067078742071#heading-3
https://help.kingbase.com.cn/v8/admin/reference/ref-server/sys_upgrade.html?highlight=sys_upgr#id5

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/316469.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

20240102使用python3将视频切片改名之后合并

20240102使用python3将视频切片改名之后合并 2024/1/2 22:12 缘起:将迅雷下载的视频切片排序之后再通过ffmpeg合并!https://pri-cdn-tx.xiaoeknow.com/app1cE7gLFM1187/confusion_index/1703599111EAPoRE.m3u8?signf17e1a2cc0ddd77801f3c5110116369e&am…

【华为数据之道学习笔记】9-3构建以元数据为基础的安全隐私保护框架

以元数据为基础的安全隐私治理 有决策权的公司高层已经意识到安全隐私的重要性,在变革指导委员会以及各个高层会议纪要中都明确指明安全隐私是变革优先级非常高的主题,安全是一切业务的保障。 基于这个大前提,我们构建了以元数据为基础的安全…

流媒体学习之路(WebRTC)——GCC分析(4)

流媒体学习之路(WebRTC)——GCC分析(4) —— 我正在的github给大家开发一个用于做实验的项目 —— github.com/qw225967/Bifrost目标:可以让大家熟悉各类Qos能力、带宽估计能力,提供每个环节关键参数调节接口并实现一个json全配置…

Hive学习(13)lag和lead函数取偏移量

hive里面lag函数 在数据处理和分析中,窗口函数是一种重要的技术,用于在数据集中执行聚合和分析操作。Hive作为一种大数据处理框架,也提供了窗口函数的支持。在Hive中,Lag函数是一种常用的窗口函数,可以用于计算前一行…

解决grafana模板分区展示数值和使用率不准的问题

我们看监控数据无非就是要准确,但grafana的模板上有时候会遇到数值计算不够准、显示位数不够全的问题,经过自己摸索与实践已经达到了目的,收录到此文分享。 下文分两个方面,我们来看看怎样解决. 目录 1,小数位数修改 …

Rockchip平台Android应用预安装功能(基于Android13)

Rockchip平台Android应用预安装功能(基于Android13) 1. 预安装应用类型 Android上的应用预安装功能,主要是指配置产品时,根据厂商要求,将事先准备好的第三方应用预置进Android系统。预安装分为以下几种类型: 安装不可卸载应用安…

《Vue3 前端构建工具》 Vue-cli 与 Vite 创建项目的插件和配置对比

前言 2024 年 啦!Vue2 也于 2023.12.31 寿终正寝 ! 然而我的 Vue3 升级一再拖延(惭愧不已)~ 赶起来吧~ 今天用 vue-cli 和 vite 分别创建了 Vue3 项目,具体实现步骤见如下两篇。 《基于 Vue Cli4.x Vue3 TS styl…

人工智能_机器学习087_DBSCAN聚类案例_聚类数据创建---人工智能工作笔记0127

之前我们把DBSCAN的原理以及参数都理解了,现在我们看如何使用 首先我们导包 import numpy as np 导入数学计算包 import matplotlib.pyplot as plt 导入画图包 from sklearn.cluster import KMeans,DBSCAN 导入算法 from sklearn import datasets 导入数据集包 X,y = data…

【IDEA——连接MySQL数据库,创建库和表】

IDEA——连接MySQL数据库,创建库和表 1、打开idea数据库操作页面(两种打开方法都可以) 2、点击加号,选择Driver,方便导入连接数据库的驱动jar包 然后选择MySQL进行添加驱动 3、点击上一步页面的左上方的Data Sources连接本地数据…

初始py和py开发工具

前言:上一章节给友友们讲解了如何安装py环境,这一章节就来练习一下如何写py的程序以及注意事项。 目录 一.你好世界 1.因为主播liunx用习惯的缘故所以所有的操作都在liunx上面执行,下面我们来看怎么写py的程序, 1.1首先打开liu…

【QT搭建】搭建可以生成手机APP的环境

一.问题分析 1.在原来的QT版本上安装Android(不推荐) 此方法暂时未实践成功,记录调试过程,可跳过 如果原来安装过QT桌面级PC软件的,可能没有配置JDK和SDK就会在QT选项的设备栏目种看到报错的提示。 并且Kits的选项里面没有Android,所以解决的问题是,缺少Kit套件Andro…

Qt(三):udp组播的发送与接收

1. 创建UDP套接字 使用QUdpSocket类创建一个UDP套接字。 udpSendnew QUdpSocket(this);udpRecenew QUdpSocket(this); 2. 绑定套接字 绑定套接字到一个本地地址和端口。可以使用bind()函数来完成。 如果要在组播中发送数据,可以将套接字绑定到一个通配符地址&#…