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

本文涉及的产品
云原生数据库 PolarDB PostgreSQL 版,标准版 2核4GB 50GB
云原生数据库 PolarDB MySQL 版,通用型 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开源数据库
本实验环境已内置PostgreSQL数据库以及PolarDB开源数据库:PolarDB PostgreSQL版和PolarDB分布式版,支持一键拉起使用,方便各位开发者学习使用。
相关文章
|
26天前
|
存储 SQL 安全
应用案例|开源 PolarDB-X 在互联网安全场景的应用实践
中盾集团采用PolarDB-X云原生分布式数据库开源版本,有效解决了大数据量处理、复杂查询以及历史数据维护等难题,实现了业务的高效扩展与优化。
|
1月前
|
存储 Cloud Native 关系型数据库
PolarDB 高可用架构设计与实践
【8月更文第27天】 在现代互联网应用中,数据库作为核心的数据存储层,其稳定性和可靠性尤为重要。阿里云的 PolarDB 作为一款云原生的关系型数据库服务,提供了高可用、高性能和自动化的特性,适用于各种规模的应用。本文将详细介绍 PolarDB 的高可用架构设计,并探讨其实现数据安全性和业务连续性的关键技术。
52 0
|
4月前
|
监控 关系型数据库 分布式数据库
【PolarDB 开源】PolarDB HTAP 实践:混合事务与分析处理的性能优化策略
【5月更文挑战第21天】PolarDB开源后在HTAP领域表现出色,允许在同一系统处理事务和分析工作负载,提高数据实时性。通过资源分配、数据分区、索引优化等策略提升性能。示例代码展示了创建和查询事务及分析表的基本操作。PolarDB还提供监控工具,帮助企业优化系统并应对业务变化。其HTAP能力为开发者和企业提供了强大支持,推动技术进步,加速数字化时代的业务发展。
420 1
|
1月前
|
SQL 存储 关系型数据库
|
2月前
|
存储 关系型数据库 MySQL
深度评测:PolarDB-X 开源分布式数据库的优势与实践
本文对阿里云开源分布式数据库 PolarDB-X 进行了详细评测。PolarDB-X 以其高性能、强可用性和出色的扩展能力在云原生数据库市场中脱颖而出。文章首先介绍了 PolarDB-X 的核心产品优势,包括金融级高可靠性、海量数据处理能力和高效的混合负载处理能力。随后,分析了其分布式架构设计,包括计算节点、存储节点、元数据服务和日志节点的功能分工。评测还涵盖了在 Windows 平台通过 WSL 环境部署 PolarDB-X 的过程,强调了环境准备和工具安装的关键步骤。使用体验方面,PolarDB-X 在处理分布式事务和实时分析时表现稳定,但在网络问题和性能瓶颈上仍需优化。最后,提出了改进建
6775 2
|
2月前
|
关系型数据库 分布式数据库 数据库
基于PolarDB的图分析:保险数据分析实践
本文以公开的保险数据集为例,示例了基于云原生数据库PolarDB上,在保险理赔场景下,执行图查询来发现异常理赔记录和欺诈团伙:例如,查询与欺诈保单有相同理赔病人的其他保单,或者找出欺诈保单的投保人社交关系,以便进行欺诈预警。PolarDB在关系型数据库的基础上,提供了图分析能力,为企业的统一数据管理和分析,提供了强有力的支撑。
|
2月前
|
存储 关系型数据库 数据库
关系型数据库设计范式:深入理解与实践
【7月更文挑战第20天】关系型数据库设计范式是数据库设计中的重要指导原则,它通过一系列规范来减少数据冗余、提高数据一致性和优化查询性能。在实际应用中,我们应该根据具体需求和数据特点,灵活选择和应用不同的范式级别,以构建高效、可靠和可扩展的数据库系统。同时,也需要注意范式设计带来的挑战和限制,根据实际情况进行权衡和调整。
|
4月前
|
SQL 监控 关系型数据库
【PolarDB开源】PolarDB SQL优化实践:提升查询效率与资源利用
【5月更文挑战第24天】PolarDB是高性能的云原生数据库,强调SQL查询优化以提升性能。本文分享了其SQL优化策略,包括查询分析、索引优化、查询重写、批量操作和并行查询,以及性能监控与调优方法。通过这些措施,可以减少响应时间、提高并发处理能力和降低成本。文中还提供了相关示例代码,展示如何分析查询和创建索引,帮助用户实现更高效的数据库管理。
246 1
|
4月前
|
安全 关系型数据库 分布式数据库
【PolarDB 开源】PolarDB 在金融行业中的实践:高可用与安全合规解决方案
【5月更文挑战第28天】PolarDB,一款适用于金融行业的强大数据库,以其高可用性和安全合规性脱颖而出。通过多副本机制和自动故障转移确保业务连续性,结合严格的访问控制和数据加密技术保护信息安全。在实际应用中,如银行核心系统,PolarDB 负责处理海量交易数据,同时支持主从架构以备故障切换。此外,设置强密码策略和加密存储确保合规性,并通过监控预警及时解决问题。随着金融科技发展,PolarDB 将在云原生架构和人工智能等领域发挥更大作用,助力金融行业创新与进步。
137 0
|
4月前
|
负载均衡 关系型数据库 分布式数据库
【PolarDB开源】PolarDB读写分离实践:优化读取性能与负载均衡策略
【5月更文挑战第26天】PolarDB是云原生关系型数据库,通过读写分离优化性能和扩展性。它设置主节点处理写操作,从节点处理读操作,异步复制保证数据一致性。优化读取性能的策略包括增加从节点数量、使用只读实例和智能分配读请求。负载均衡策略涉及基于权重、连接数和地理位置的分配。实践示例中,电商网站通过主从架构、只读实例和负载均衡策略提升商品查询效率。PolarDB的读写分离与负载均衡为企业应对大数据和高并发提供了有效解决方案。
209 0

热门文章

最新文章

相关产品

  • 云原生数据库 PolarDB