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.mzph.cn/news/595406.shtml

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

相关文章

STL——vector详解

目录 💡基本概念 💡存放内置数据类型 💡存放自定义数据类型 💡存放自定义数据类型指针 💡vector容器嵌套容器 💡vector构造函数 💡vector赋值操作 💡vector容量和大小 &…

西电期末1018.logistic方程

一.题目 二.分析与思路 根据题目递归即可&#xff0c;用while函数判断是否到达1000项&#xff0c;内部用abs函数&#xff08;绝对值函数&#xff09;判断是否收敛&#xff0c;最后按照结果输出即可。 三.代码实现 #include<bits/stdc.h>//万能头 int main() {double …

React实现简单登录

一 实现效果(样式是之前设置的&#xff09; 二 具体实现代码 2.1 Login.js import {useNavigate} from "react-router-dom"; import React from "react"; // import ./style2.cssfunction Login(){const navigateuseNavigate()func…

nginx在国产服务器上stream配置项无法识别的问题

最近在搭建k8sranchar&#xff0c;需要用到nginx做负载均衡&#xff0c;之前在系统中也会用到&#xff0c;之前一直使用http选项&#xff0c;做转发配置。 基本格式如下图所示&#xff1a; 但是在ranchar的安装中默认方式使用stream配置项。 使用yum默认安装的nginx不支持该关…

Yapi安装配置(CentOs)

环境要求 nodejs&#xff08;7.6) mongodb&#xff08;2.6&#xff09; git 准备工作 清除yum命令缓存 sudo yum clean all卸载低版本nodejs yum remove nodejs npm -y安装nodejs,获取资源,安装高版本nodejs curl -sL https://rpm.nodesource.com/setup_8.x | bash - #安装 s…

Spring Cloud Config相关面试题及答案(2024)

1、什么是 Spring Cloud Config&#xff0c;它解决了哪些问题&#xff1f; Spring Cloud Config 是一个为微服务架构提供集中化外部配置支持的项目。它是构建在 Spring Cloud 生态系统之上&#xff0c;利用 Spring Boot 的开发便利性&#xff0c;简化了分布式系统中的配置管理…

现在的人们如何看待数据隐私?

PrimiHub一款由密码学专家团队打造的开源隐私计算平台&#xff0c;专注于分享数据安全、密码学、联邦学习、同态加密等隐私计算领域的技术和内容。 在当前时代&#xff0c;每一次点击、触摸或按键都留下了数字痕迹。但是我们对自己的个人数据几乎没有控制的权限&#xff0c;这让…

百度自由DIY小程序源码:PHP+MySQL组合开发 带完整的搭建教程

随着移动互联网的快速发展&#xff0c;小程序已成为企业与用户互动的重要平台。然而&#xff0c;对于许多中小企业和开发者来说&#xff0c;从零开始开发一款小程序需要投入大量的时间和资源。 以下是部分代码示例&#xff1a; 系统特色功能一览&#xff1a; 1.高度自定义&…

三、C语言中的分支与循环—if语句 (1)

在这一章节中我们的学习内容如下&#xff0c;咱们一步步来。 分支结构 1. if语句 2. 关系操作符 3. 条件操作符 4. 逻辑操作符&#xff1a;&& , || , &#xff01; 5. switch语句 循环结构 6. while循环 7. for循环 8. do-while循环 9. break和conti…

Python 微服务架构指南

概要 微服务架构作为一种设计风格&#xff0c;它将应用程序构建为一套小服务的集合&#xff0c;每个服务实现特定的业务功能&#xff0c;这些服务可以独立部署、扩展并围绕特定业务能力构建。Python 凭借其简洁易读的语法和强大的库生态系统成为实现微服务的受欢迎选择。本文将…

【番外】【Airsim in Windows ROS in WSL2-Ubuntu20.04】环境配置大全

【番外】【Airsim in Windows &ROS in WSL2-Ubuntu20.04】环境配置大全 【前言&#xff08;可省略不看&#xff09;】1.在windows上面部署好UE4AirSim联合仿真环境2.在windows上面部署wsl2系统以及在wsl2上面部署ubuntu系统3.安装好ubuntu系统之后&#xff0c;目前只能在命…

河北首例:黑科技人工心脏为终末期心衰患者带来新希望

近日&#xff0c;河北工程大学附属医院心脏中心成功完成河北省首例左心室辅助装置植入&#xff08;人工心脏&#xff09;&#xff0c;为终末期心衰患者提供了除心脏移植以外新的解决方案。 55岁刘女士因间断胸闷气短7年&#xff0c;诊断为扩张型心肌病&#xff0c;经过规范的“…

Unity AVProVideo安卓播放视频问题

Pico4播放全景8K视频播放不了&#xff0c;普通视频也播放不了解决方案&#xff1a; 1.Vulkan去掉&#xff0c;或者优先级放下面2.Pico4打包ARM64&#xff0c;插件里arm64里的几个库都设置arm64&#xff0c;平台选择安卓 Pico其他设置参考官方文档即可。

LDD学习笔记 -- Linux内核模块

LDD学习笔记 -- 内核模块 简介LKM类型Static Linux Kernel ModuleDynamic Linux Kernel ModuleLKM编写语法 syntax详细描述内核头文件用户空间头文件Module Initialization FunctionModule Cleanup FunctionKeyword & Tag宏 __init __exitLKM入口注册Module Metadate&#…

win10提示“KBDSF.DLL文件缺失”,游戏或软件无法启动运行,快速修复方法

很多用户在日常使用电脑的时候&#xff0c;或多或少都遇到过&#xff0c;在启动游戏或软件的时候&#xff0c;Windows桌面会弹出错误提示框“KBDSF.DLL文件缺失&#xff0c;造成软件无法启动或运行&#xff0c;请尝试重新安装解决”。 首先&#xff0c;先来了解DLL文件是什么&a…

基于springboot的java读取文档内容(超简单)

读取一个word文档里面的内容&#xff0c;并取出来。 代码&#xff1a; SneakyThrowsGetMapping(value "/readWordDoc")ApiOperationSupport(order 1)ApiOperation(value "文档读取 ", notes "文档读取 ")public R ReadWordDoc () {System.o…

使用vue实现一个网页的贴边组件。

使用vue实现一个网页的贴边组件。 先来看效果&#xff1a; 2024-01-04 10.46.22 https://www.haolu.com/share/V00O6HWYR8/36207fc21c35b2a8e09bf22787a81527 下面是具体代码实现&#xff1a; 1、父组件。&#xff08;用于贴边展示的组件&#xff09; <template>&…

XCTF-Misc1 USB键盘流量分析

m0_01 附件是一个USB流量文件 分析 1.键盘流量 USB协议数据部分在Leftover Capture Data域中&#xff0c;数据长度为八个字节&#xff0c;其中键盘击健信息集中在第三个字节中。 usb keyboard映射表&#xff1a;USB协议中HID设备描述符以及键盘按键值对应编码表 2.USB…

PC网站或H5网站接入客服系统

网页链接接入 PC网站或H5网站可以通过多种方式接入客服系统&#xff0c;直接访问或跳转聊天链接&#xff0c;是最简单的一种方式 获取聊天链接 前往【部署】【团队设置】【网站接入】可以找到聊天链接&#xff0c;直接把该链接放入自己网站的任何位置&#xff0c;就可以点击直…

Ansible的Shell命令配置自动补全

一、【Ansible简介】 Ansible一词据笔者所知最早来源于小说《安德的游戏》&#xff0c;其中的人族势力为了解决星际间远距离通信对星舰控制的延迟问题&#xff0c;作者贴心的虚构了一个叫做安塞波的概念&#xff0c;这个概念甚至在之后被很多小说复用&#xff0c;比如《盲视》…