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 /data

test=# 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 database
 yangbao   | 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 package
 dbms_output         | 1.0  | sys        | DBMS_OUTPUT system package
 dbms_utility        | 1.0  | sys        | dbms_utility extension package
 kdb_cast            | 1.0  | sys        | kdb_cast extension
 kdb_license         | 1.0  | pg_catalog | kdb_license extension
 kdb_oracle_datatype | 1.1  | sys        | kdb_oracle_datatype extension
 kdb_schedule        | 1.0  | sys        | A KingbaseES job scheduler
 kdb_tinyint         | 1.0  | pg_catalog | Create a new data type tinyint and its functions operators and indexes
 kingbase_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 package
 plpgsql             | 1.0  | pg_catalog | PL/pgSQL procedural language
 plsql               | 1.0  | pg_catalog | PL/SQL procedural language
 sys_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 executed
 sysaudit            | 1.0  | sysaudit   | provides auditing functionality
 sysmac              | 1.0  | sysmac     | Mac for Kingbase
 xlog_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 database
 security  | 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 schemas
                                                            ok
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 cluster
                                                            ok
正在复制用户关系文件
                                                            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 schemas
                                                            ok
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 KBPORT

vacuumdb: 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 database
 security  | 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 database
 yangbao   | 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 | batch2
  2 | batch2
  3 | batch2
  4 | batch2
  5 | batch2
  6 | batch2
  7 | batch2
  8 | batch2
  9 | batch2
 10 | 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

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Django开发5-Django开发知识点快速预览

Django开发知识点快速预览 Django开发1.知识点的回顾:2.Ajax请求3.订单小结图表 各位小伙伴想要博客相关资料的话关注公众号:chuanyeTry即可领取相关资料! Django开发 1.知识点的回顾: 安装Django pip install django创建Django项…

通达信佳庆离散指标公式,衡量价格波动率

佳庆离散指标(Chaikin Volatility)是由股票经纪人Mark Chaikin发明的,通过计算选定时期内最高价和最低价之间的差值来衡量价格波动率,将波动率量化为最高价和最低价之间范围的扩大或缩小。 在技术分析中,波动性具有比…

5 个顶级的免费磁盘分区软件工具评测分享

磁盘分区可能是一个脆弱而复杂的过程,磁盘崩溃或用户设备受到病毒攻击的风险很高。因此,它们很难由用户单独或手动管理。本文详细介绍了可以帮助简化磁盘分区过程的不同软件工具、它们的功能和优点。那么让我们开始吧。 什么是磁盘分区工具?…

常见的锁策略详细讲解(悲观锁 vs 乐观锁,轻量锁 vs 重量锁,自旋锁 vs 互斥锁,公平锁 vs 非公平锁,读写锁等)

文章目录 悲观锁和乐观锁Java中的悲观锁和乐观锁乐观锁常见的两种实现方式版本号机制CAS(compare and swap) 算法乐观锁的缺点 轻量级锁和重量级锁自旋锁 VS 互斥锁公平锁 VS 非公平锁读写锁读写锁的插队策略读写锁的升级策略 可重入锁 VS 不可重入锁 悲观锁和乐观锁 所谓悲观…

Android 13 - Media框架(29)- MediaCodec(四)

上一节我们了解了如何通过 onInputBufferAvailable 和 getInputBuffer 获取到 input buffer index,接下来我们一起学习上层如何拿到buffer并且向下写数据的。 1、获取 input Buffer 获取 MediaCodec 中的 buffer 有两种方式,一种是调用 getInputBuffers…

在vscode中创建任务编译module源文件

接昨天的文章 [创建并使用自己的C模块(Windows10MSVC)-CSDN博客],觉得每次编译转到命令行下paste命令过于麻烦,于是研究了一下在vscode中创建自动编译任务。 经过尝试,在task.json中增加如下代码: {"…

IDEA2023 最新版详细图文安装教程(安装+运行测试+汉化+背景图设置)

IDEA2023 最新版详细图文安装教程 名人说:工欲善其事,必先利其器。——《论语》 作者:Code_流苏(CSDN) o(‐^▽^‐)o很高兴你打开了这篇博客,跟着教程去一步步尝试安装吧。 目录 IDEA2023 最新版详细图文安…

SpringBoot整合Validator

前言 @Validation是一套帮助我们继续对传输的参数进行数据校验的注解,通过配置Validation可以很轻松的完成对数据的约束。 通过对DTO中实体类的约束,可以大大增加代码的简洁性。 错误的状态码 返回的响应码推荐使用400 bad request. 参数注解含义 实体类 /*** @author:…

索引语法SQL性能分析

创建 查看 删除 SQL执行频率 Com后七个下划线 慢查询日志 show profiles explain explain执行计划 各字段含义: 多表查询 根据主键或者唯一索引时会出现const const就已经是很棒的性能了,实际中 NULL几乎不会出现

信息安全管理与评估省赛经验总结

信息技能大赛 在比赛开始之前,一定要检查设配,认真审查注意事项;拿到题之后,把对应设备的基本配置完成,任何异常及时报告,这个时候可以把设备的线链接上配置好,登录清单上管理地址等查看是否能登…

二维码地址门牌系统技术服务:让您的生活更便捷,一码通行,安全无忧

文章目录 前言一、融合二维码技术与门牌的便捷服务二、手机开门便捷功能三、智能化安全保障四、智能化、便捷化的新型技术 前言 在数字化时代,二维码门牌系统技术应运而生,为了满足人们对安全、便捷生活的需求。这项技术将二维码与门牌结合,…

leetcode链表小练(1.反转链表2.链表的中间节点3.合并两个有序链表4.环形链表①5.环形链表②)详解 (୨୧• ᴗ •͈)◞︎ᶫᵒᵛᵉ ♡

目录 一.反转链表 思路一反转指针反向: 思路二头插法: 二.链表的中间节点: 三.合并两个有序数组: 思路一:从头开始,取两个链表中小的那个尾插到新链表。定义指针head,tail指向空,代表新链表的头结点。…

Hive/SparkSQL中UDF/UDTF/UDAF的含义、区别、有哪些函数

Hive官网:https://cwiki.apache.org/confluence/display/Hive/LanguageManualUDF#LanguageManualUDF-Built-inTable-GeneratingFunctions(UDTF) 1.UDF(User-Defined Function) 含义 即用户定义函数,UDF用于处理一行数据并返回一个标量值(单个值)&#x…

测试自动创建设备节点的功能

一. 简介 上一篇文章在 新设备驱动框架代码的基础上,添加了自动创建设备节点的代码。文章地址如下: 自动创建设备节点代码的实现-CSDN博客 本文对自动创建设备节点的功能进行测试。 二. 自动创建设备节点代码的测试 1. 编译驱动,并拷贝…

关于编程模式的总结与思考

淘宝创新业务的优化迭代是非常高频且迅速的,在这过程中要求技术也必须是快且稳的,而为了适应这种快速变化的节奏,我们在项目开发过程中采用了一些面向拓展以及敏捷开发的设计,本文旨在总结并思考其中一些通用的编程模式。 前言 静…

【Vue2+3入门到实战】(19)Vuex状态管理器通过辅助函数 - mapState获取 state中的数据代码实现 详细讲解

目录 一、通过辅助函数 - mapState获取 state中的数据1.第一步:导入mapState (mapState是vuex中的一个函数)2.第二步:采用数组形式引入state属性3.第三步:利用**展开运算符**将导出的状态映射给计算属性 二、开启严格模式及Vuex的单项数据流1…

2024年美赛数学建模ABCDEF题思路选题分析

文章目录 1 赛题思路2 美赛比赛日期和时间3 赛题类型4 美赛常见数模问题5 建模资料 1 赛题思路 (赛题出来以后第一时间在CSDN分享) https://blog.csdn.net/dc_sinor?typeblog 2 美赛比赛日期和时间 比赛开始时间:北京时间2024年2月2日(周五&#xff…

MVCC 并发控制原理-源码解析(非常详细)

基础概念 并发事务带来的问题 1)脏读:一个事务读取到另一个事务更新但还未提交的数据,如果另一个事务出现回滚或者进一步更新,则会出现问题。 2)不可重复读:在一个事务中两次次读取同一个数据时&#xff0c…

Java实现短信发送业务

1、业务需求 发送短信功能是一个很普遍的需求,比如验证码,快递单号,通知信息一类。 而在Java中实现短信功能相对简单,只需要调用短信服务商提供的API。接下来以阿里云为例,介绍如何实现短信发送功能,其他短…

运算符的优先级(规矩是人定的)

运算符的优先级(规矩是人定的) 什么是经典?经典就是理论不随时间变迁而变化。《东方不败》中的很多台词让人时不时想起来振聋发聩。比如 很多事情不是自己想的那样,规矩是人定的。 舔狗和有思想 从小到大,我们都学过…