共计 1956 个字符,预计需要花费 5 分钟才能阅读完成。
PolarDB-X 为了不便用户体验,提供了收费的试验环境,您能够在试验环境里体验 PolarDB-X 的装置部署和各种内核个性。除了收费的试验,PolarDB-X 也提供收费的视频课程,手把手教你玩转 PolarDB-X 分布式数据库。
本期试验将领导您应用对 PolarDB-X 进行 Online DDL。
本期收费试验地址
本期教学视频地址
前置筹备
假如曾经依据前一讲内容实现了 PolarDB- X 的搭建部署,能够胜利链接上 PolarDB- X 数据库。
试验步骤
本步骤将带您体验 PolarDB-X Online DDL 个性。咱们首先用 Sysbench OLTP 场景来模仿业务负载,之后在负载失常运行(也就是压测进行中)时进行 DDL 操作,同时察看 DDL 执行状况和负载受影响状况。
筹备 Sysbench OLTP 场景数据
a. 执行如下 SQL 语句,创立压测数据库 sysbench_test。
CREATE DATABASE sysbench_test;
留神:如果您遇到 mysql: [Warning] Using a password on the command line interface can be insecure.ERROR 2013 (HY000): Lost connection to MySQL server at ‘reading initial communication packet’, system error: 0 报错,请您急躁期待一分钟后,再次执行 SQL 语句。
b. 在试验页面,单击右上角的 + 图标,创立新的终端。
c. 执行如下命令,切换到账号 galaxykube。
su galaxykube
d. 执行如下命令,进入到 home/galaxykube 目录。
cd /home/galaxykube
e. 执行如下命令,下载初始化数据文件 sysbench-prepare.yaml 和压测文件 sysbench-oltp.yaml。
wget https://labfileapp.oss-cn-han…
wget https://labfileapp.oss-cn-han…
f. 执行如下命令,运行 sysbench-prepare.yaml 文件,初始化测试数据。
kubectl apply -f sysbench-prepare.yaml
g. 执行如下命令,获取工作进行状态。
kubectl get jobs
返回后果如下,请您急躁期待大概 1 分钟,当工作状态 COMPLETIONS 为 1 / 1 时,示意数据曾经初始化实现。
开始压测
a. 执行以下命令,运行 sysbench-oltp.yaml 文件,开始压测。
kubectl apply -f sysbench-oltp.yaml
b. 执行如下命令,查找压测脚本运行的 POD。
kubectl get pods
返回后果如下,以 ’sysbench-oltp-test-‘ 结尾的 POD 即为指标 POD。
c. 执行如下命令,查看 QPS 等信息。
阐明:您须要将命令中的指标 POD 替换为上一步骤中以 ’sysbench-oltp-test-‘ 结尾的 POD。
kubectl logs -f 指标 POD
返回后果如下,您能够查看到 QPS 等信息。
进行 Online DDL 操作
留神:如下子步骤请您在终端二中进行 DDL 操作,并同时在终端三中察看压测 QPS 等信息的变动状况。
a. 执行如下 SQL 语句,应用数据库 sysbench_test。
USE sysbench_test;
b. 执行如下 SQL 语句,查看 sbtest1 表构造。
show create table sbtest1;
c. 执行如下 SQL 语句,将 sbtest1 表减少一列。
alter table sbtest1 add column x char(20) not null default ” after c;
d. 执行如下 SQL 语句,将 sbtest1 表删除一列。
alter table sbtest1 drop column x;
e. 执行如下 SQL 语句,将 sbtest1 表增加全局二级索引。
create global index k_2 on sbtest1(k) dbpartition by hash(k);
f. 执行如下 SQL 语句,将 sbtest1 表删除全局二级索引。
drop index k_2 on sbtest1;
g. 执行如下 SQL 语句,将分表调整为单表。
alter table sbtest1 single;
h. 执行如下 SQL 语句,查看 sbtest1 表的表拓扑。
show topology from sbtest1;
i. 执行如下 SQL 语句,将单表调整为分表。
alter table sbtest1 dbpartition by hash(id);
j. 执行如下 SQL 语句,查看 sbtest1 表的表拓扑。
show topology from sbtest1;
能够看到 Online DDL 执行胜利,表拓扑产生了变动。
原文链接
本文为阿里云原创内容,未经容许不得转载。