PolarDB-X云数据库与MySql数据库的应用与分析

本文涉及的产品
云原生数据库 PolarDB 分布式版,标准版 2核8GB
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
简介: PolarDB-X 2.0 从 5.4.14 版本开始,推出了新类型的 New Sequence,并将其与 AUTO 模式库中的表 AUTO_INCREMENT 属性相关联,达成了与 MySQL AUTO_INCREMENT 一致的功能和性能体验。

首先第一部分我讲解一下PolarDB-X和Mysql的一些实践,第二部分我讲一些PolarDB-X与MySql的对比分析

1. PolarDB-X的使用

首先安装Docker命令

curl -fsSL https://get.docker.com | bash -s docker --mirror Aliyun

然后进行启动

systemctl start docker

接下来我们通过Docker命令来安装PolarDB-X数据库

docker run -d --name some-polardb-x -p 8527:8527 polardbx/polardb-x:2.1.0

PolarDB-X支持通过MySQL Client命令行、第三方客户端以及符合MySQL交互协议的第三方程序代码进行连接。

接下来我们安装MySql,使用yum命令进行安装

yum install mysql -y

如果安装成功的话我们可以看一看数据库的版本,这个通过version命令即可查看

最后我们进行PolarDB-X数据库的登录

mysql -h127.0.0.1 -P8527 -upolardbx_root -p123456

登录之后我们就可以进行相应的数据库的开发操作,这款数据库对开发者而言是十分友好的,欢迎大家使用.

2. MySql数据库

以下是我写的一个比较完备的语法正确的数据库表,欢迎大家的使用

CREATETABLE `sys_numberkey_info` (  `number_key_id` BIGINT(20)NOTNULL AUTO_INCREMENT COMMENT '数字钥匙ID',  `number_key_code` VARCHAR(255) DEFAULT '' COMMENT '数字钥匙识别码',  `number_key_user` VARCHAR(255) DEFAULT '' COMMENT '用户信息',  `number_key_vehicle` VARCHAR(255) DEFAULT '' COMMENT '车辆信息',  `number_key_status` CHAR(1) DEFAULT '0' COMMENT '数字钥匙状态(0冻结 1解冻)',  `create_time` DATETIME DEFAULT NULL COMMENT '创建时间',  `number_key_date` DATETIME DEFAULT NULL COMMENT '数字钥匙有效期',  PRIMARY KEY (`number_key_id`) USING BTREE
) ENGINE=INNODB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC COMMENT='数字钥匙表'

3. 两款数据库的对比分析

与PolarDB不同,PolarDB-X是一个真正的分布式服务。他的计算节点CN,数据节点DN都是可以进行扩容的。相较与MySQL的服务架构,PolarDB的DBServer可以认为就是MySQL本身,而DataServer则是文件服务。而PolarDB-X的CN节点可以认为是MySQL的Server部分,DN节点为MySQL的InnoDB部分。与PolarDB的主从架构不同,PolarDB-X的计算节点是完全分布式的。DN节点基于Paxos提供数据高可靠、强一致保障。同时通过MVCC维护分布式事务可见性。且DN支持PB级别的数据量.PolarDB-X将数据表以水平分区的方式,分布在多个存储节点(DN)上。数据分区方式由分区函数决定,PolarDB-X支持哈希(Hash)、范围(Range)等常用的分区函数。PolarDB-X支持并行计算,将SQL拆分为不同的Task分配给多个CN,并行计算。

从MySQL迁移至PolarDB-X的理由:

PolarDB-X将兼容MySQL以及周边生态作为核心设计目标之一。兼容MySQL协议,兼容绝大部分MySQL函数。PolarDB-X作为分布式服务,在可支撑并发量及容量上都是可以线性扩展的。

迁移成本:

  1. PolarDB 100%兼容MySQL协议,不需要改变客户端
  2. 学习成本低,除了部分由于分布式导致的SQL使用限制
  3. 由云完全托管,没有新的运维成本开销。
  4. 历史数据可以通过相关工具自动迁移至PolarDB-X。

4. 总结

要是我理解正确的话,这款数据库对于开发者是十分友好的,强烈推荐大家使用,大家可以不用考虑版本问题,比如我现在的使用Mysql 8.0.23版本,这个版本的数据库可太不稳定了,很多语句在Mysql 5.7版本可以运行,但是在Mysql 8.0版本却会出现各种各样的Bug,这就让人很烦恼了,而PolarDB-X是兼容的,这一点深受我的喜欢.

我想提出的建议就是是否官方可以直接推出兼容数据库以及桌面的数据库操作软件,方便大家使用,并进行大量的推广,不然大家都不知道还有这么个东西.

相关实践学习
快速体验PolarDB开源数据库
本实验环境已内置PostgreSQL数据库以及PolarDB开源数据库:PolarDB PostgreSQL版和PolarDB分布式版,支持一键拉起使用,方便各位开发者学习使用。
相关文章
|
7天前
|
NoSQL 关系型数据库 分布式数据库
基于PolarDB的图分析:通过DTS将其它数据库的数据表同步到PolarDB的图
本文介绍了使用DTS任务将数据从MySQL等数据源实时同步到PolarDB-PG的图数据库中的步骤.
|
11天前
|
存储 Oracle 关系型数据库
数据库传奇:MySQL创世之父的两千金My、Maria
《数据库传奇:MySQL创世之父的两千金My、Maria》介绍了MySQL的发展历程及其分支MariaDB。MySQL由Michael Widenius等人于1994年创建,现归Oracle所有,广泛应用于阿里巴巴、腾讯等企业。2009年,Widenius因担心Oracle收购影响MySQL的开源性,创建了MariaDB,提供额外功能和改进。维基百科、Google等已逐步替换为MariaDB,以确保更好的性能和社区支持。掌握MariaDB作为备用方案,对未来发展至关重要。
39 3
|
11天前
|
安全 关系型数据库 MySQL
MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!
《MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!》介绍了MySQL中的三种关键日志:二进制日志(Binary Log)、重做日志(Redo Log)和撤销日志(Undo Log)。这些日志确保了数据库的ACID特性,即原子性、一致性、隔离性和持久性。Redo Log记录数据页的物理修改,保证事务持久性;Undo Log记录事务的逆操作,支持回滚和多版本并发控制(MVCC)。文章还详细对比了InnoDB和MyISAM存储引擎在事务支持、锁定机制、并发性等方面的差异,强调了InnoDB在高并发和事务处理中的优势。通过这些机制,MySQL能够在事务执行、崩溃和恢复过程中保持
41 3
|
10天前
|
SQL 关系型数据库 分布式数据库
夺冠在即 | PolarDB数据库创新设计赛(天池杯)决赛答辩通知
2024年全国大学生计算机系统能力大赛PolarDB数据库创新设计赛(天池杯)于8月21日启动,吸引了200多所高校近千支队伍参赛。经过激烈角逐,60支队伍晋级决赛第一阶段,36支队伍脱颖而出进入现场答辩,将于12月29日在武汉大学争夺最终奖项。决赛要求选手基于PolarDB-PG开源代码部署集群并优化TPCH查询性能。完赛率超90%,成绩表现出明显梯度,前20名均在500秒内完成。评委来自学术界和工业界,确保评选公正。预祝选手们取得优异成绩!
|
11天前
|
SQL 关系型数据库 MySQL
数据库灾难应对:MySQL误删除数据的救赎之道,技巧get起来!之binlog
《数据库灾难应对:MySQL误删除数据的救赎之道,技巧get起来!之binlog》介绍了如何利用MySQL的二进制日志(Binlog)恢复误删除的数据。主要内容包括: 1. **启用二进制日志**:在`my.cnf`中配置`log-bin`并重启MySQL服务。 2. **查看二进制日志文件**:使用`SHOW VARIABLES LIKE 'log_%';`和`SHOW MASTER STATUS;`命令获取当前日志文件及位置。 3. **创建数据备份**:确保在恢复前已有备份,以防意外。 4. **导出二进制日志为SQL语句**:使用`mysqlbinlog`
54 2
|
25天前
|
关系型数据库 MySQL 数据库
Python处理数据库:MySQL与SQLite详解 | python小知识
本文详细介绍了如何使用Python操作MySQL和SQLite数据库,包括安装必要的库、连接数据库、执行增删改查等基本操作,适合初学者快速上手。
174 15
|
18天前
|
SQL 关系型数据库 MySQL
数据库数据恢复—Mysql数据库表记录丢失的数据恢复方案
Mysql数据库故障: Mysql数据库表记录丢失。 Mysql数据库故障表现: 1、Mysql数据库表中无任何数据或只有部分数据。 2、客户端无法查询到完整的信息。
|
7天前
|
NoSQL 关系型数据库 分布式数据库
PolarDB图数据库快速入门
图数据库(Graph Database)专门存储图数据,适合处理社交网络、知识图谱等复杂关系。它使用图查询语言(如Cypher、Gremlin)进行操作。PolarDB兼容OpenCypher语法,支持创建、查询、更新和删除图数据,包括模式匹配、过滤、MERGE避免重复、可视化工具等功能,简化了图数据的管理和应用。
|
5月前
|
运维 数据库 数据库管理
云数据库问题之阿里云在运营商领域数据库替换的整体解决方案要如何实现
云数据库问题之阿里云在运营商领域数据库替换的整体解决方案要如何实现
|
3月前
|
缓存 弹性计算 NoSQL
新一期陪跑班开课啦!阿里云专家手把手带你体验高并发下利用云数据库缓存实现极速响应
新一期陪跑班开课啦!阿里云专家手把手带你体验高并发下利用云数据库缓存实现极速响应