实践教程之如何在PolarDB-X中进行Online DDL

本文涉及的产品
云原生数据库 PolarDB MySQL 版,通用型 2核8GB 50GB
云原生数据库 PolarDB PostgreSQL 版,标准版 2核4GB 50GB
简介: PolarDB-X 为了方便用户体验,提供了免费的实验环境,您可以在实验环境里体验 PolarDB-X 的安装部署和各种内核特性。除了免费的实验,PolarDB-X 也提供免费的视频课程,手把手教你玩转 PolarDB-X 分布式数据库。

PolarDB-X 为了方便用户体验,提供了免费的实验环境,您可以在实验环境里体验 PolarDB-X 的安装部署和各种内核特性。除了免费的实验,PolarDB-X 也提供免费的视频课程,手把手教你玩转 PolarDB-X 分布式数据库。

本期实验将指导您使用对 PolarDB-X 进行Online DDL。

PolarDB-X 分布式数据库免费试用地址

本期免费实验地址

本期教学视频地址

前置准备

假设已经根据前一讲内容完成了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-hangzhou.aliyuncs.com/learn-some-polardb-x-main-class-5/sysbench-prepare.yaml wget https://labfileapp.oss-cn-hangzhou.aliyuncs.com/learn-some-polardb-x-main-class-5/sysbench-oltp.yaml

f.执行如下命令,运行sysbench-prepare.yaml文件,初始化测试数据。

kubectl apply -f sysbench-prepare.yaml

g.执行如下命令,获取任务进行状态。

kubectl get jobs
返回结果如下,请您耐心等待大约1分钟,当任务状态COMPLETIONS为1/1时,表示数据已经初始化完成。

a1.jpg

开始压测

a.执行以下命令,运行sysbench-oltp.yaml文件,开始压测。

kubectl apply -f sysbench-oltp.yaml

b.执行如下命令,查找压测脚本运行的POD。

kubectl get pods
返回结果如下, 以'sysbench-oltp-test-'开头的POD即为目标POD。

b2.jpg
c.执行如下命令,查看QPS等信息。

说明 :您需要将命令中的目标POD替换为上一步骤中以'sysbench-oltp-test-'开头的POD。

kubectl logs -f 目标POD
返回结果如下,您可以查看到QPS等信息。
b3.jpg

进行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执行成功,表拓扑发生了变化。

如果您想了解更多有关PolarDB-X DDL知识,详情请参见如下内容

PolarDB-X Online Schema Change
PolarDB-X:让“Online DDL”更Online
PolarDB-X分布式MDL死锁检测
PolarDB-X源码解读(六):分布式死锁检测
PolarDB-X DDL也要追求ACID?

本文来源:PolarDB-X知乎机构号

相关文章
|
关系型数据库 测试技术 数据库连接
实践教程之使用PolarDB-X进行冷热数据归档
PolarDB-X 为了方便用户体验,提供了免费的实验环境,您可以在实验环境里体验 PolarDB-X 的安装部署和各种内核特性。除了免费的实验,PolarDB-X 也提供免费的视频课程,手把手教你玩转 PolarDB-X 分布式数据库。
|
SQL 存储 关系型数据库
|
SQL 关系型数据库 测试技术
实践教程之在PolarDB-X中进行Online DDL
PolarDB-X 为了方便用户体验,提供了免费的实验环境,您可以在实验环境里体验 PolarDB-X 的安装部署和各种内核特性。除了免费的实验,PolarDB-X 也提供免费的视频课程,手把手教你玩转 PolarDB-X 分布式数据库。
实践教程之在PolarDB-X中进行Online DDL
|
SQL canal 大数据
实践教程之将PolarDB-X与大数据等系统互通
PolarDB-X 为了方便用户体验,提供了免费的实验环境,您可以在实验环境里体验 PolarDB-X 的安装部署和各种内核特性。除了免费的实验,PolarDB-X 也提供免费的视频课程,手把手教你玩转 PolarDB-X 分布式数据库。
实践教程之将PolarDB-X与大数据等系统互通
|
SQL Kubernetes 关系型数据库
实践教程之快速安装部署PolarDB-X
PolarDB-X 为了方便用户体验,提供了免费的实验环境,您可以在实验环境里体验 PolarDB-X 的安装部署和各种内核特性。除了免费的实验,PolarDB-X 也提供免费的视频课程,手把手教你玩转 PolarDB-X 分布式数据库。
3551 0
实践教程之快速安装部署PolarDB-X
|
Java 数据库 数据安全/隐私保护
实践教程之快速使用PolarDB-X
PolarDB-X 为了方便用户体验,提供了免费的实验环境,您可以在实验环境里体验 PolarDB-X 的安装部署和各种内核特性。除了免费的实验,PolarDB-X 也提供免费的视频课程,手把手教你玩转 PolarDB-X 分布式数据库。
实践教程之快速使用PolarDB-X
|
SQL 弹性计算 测试技术
实践教程之如何在PolarDB-X中优化慢SQL
PolarDB-X 为了方便用户体验,提供了免费的实验环境,您可以在实验环境里体验 PolarDB-X 的安装部署和各种内核特性。除了免费的实验,PolarDB-X 也提供免费的视频课程,手把手教你玩转 PolarDB-X 分布式数据库。本期实验将指导您使用对 PolarDB-X 进行慢SQL优化。...
实践教程之如何在PolarDB-X中优化慢SQL
|
SQL 弹性计算 分布式数据库
实践教程之如何对PolarDB-X集群做动态扩缩容
PolarDB-X 为了方便用户体验,提供了免费的实验环境,您可以在实验环境里体验 PolarDB-X 的安装部署和各种内核特性。除了免费的实验,PolarDB-X 也提供免费的视频课程,手把手教你玩转 PolarDB-X 分布式数据库。本期实验将指导您使用对 PolarDB-X 进行动态扩缩容。本...
实践教程之如何对PolarDB-X集群做动态扩缩容
|
7月前
|
关系型数据库 分布式数据库 数据库
一库多能:阿里云PolarDB三大引擎、四种输出形态,覆盖企业数据库全场景
PolarDB是阿里云自研的新一代云原生数据库,提供极致弹性、高性能和海量存储。它包含三个版本:PolarDB-M(兼容MySQL)、PolarDB-PG(兼容PostgreSQL及Oracle语法)和PolarDB-X(分布式数据库)。支持公有云、专有云、DBStack及轻量版等多种形态,满足不同场景需求。2021年,PolarDB-PG与PolarDB-X开源,内核与商业版一致,推动国产数据库生态发展,同时兼容主流国产操作系统与芯片,获得权威安全认证。
|
4月前
|
存储 关系型数据库 分布式数据库
喜报|阿里云PolarDB数据库(分布式版)荣获国内首台(套)产品奖项
阿里云PolarDB数据库管理软件(分布式版)荣获「2024年度国内首版次软件」称号,并跻身《2024年度浙江省首台(套)推广应用典型案例》。

相关产品

  • 云原生数据库 PolarDB