ShardingSphere-Proxy系列文章开篇

1.学习背景

最近在公司实习,公司主要的技术栈是Go,数据库方面使用的是MySQL。导师分配了一个数据分片的任务,希望能够通过ShardingSphere-Proxy将单节点数据存储改造成多节点数据分片存储。通过架构的优化,来提高数据的查询效率,为用户更好的服务。

和导师了解完任务的细节后,就开始进行ShrdinSphere的学习。

SphereSphere是Apache下的开源项目,在数据分片方面提供了两种方案,分别为:

  • ShardingSphere-JDBC,定位为轻量级 Java 框架,在 Java 的 JDBC 层提供的额外服务。
  • ShardingSphere-Proxy,定位为透明化的数据库代理端,通过实现数据库二进制协议,对异构语言提供支持。

由于公司的技术栈是GO,所以就选择使用ShardingSphere-Proxy中间件,作为数据分片的工具了。

2.ShardingSphere-Proxy介绍

ShardingSphere-Proxy相当是数据库上层的中间件服务,我们的业务代码可以像操作数据库一样操作ShardingSphere-Proxy,之后由ShardingSphere-Proxy根据匹配规则转换成对应的真实SQL,操作下层数据库节点。引入SharidngSphere-Proxy后,我们不需要关系数据具体被存储在数据库中的那一个节点上,屏蔽数据存储的底层细节,让我们更好地专注于业务开发。

 3.本系列文章主要涉及内容

  1. ShardingSphere-Proxy镜像的运行
  2. 根据业务场景制作自己的ShardingSphere-Proxy镜像
  3. ShardingSphere-Proxy集群模式的Etcd存储元数据的方案
ShardingSphere 是一个开源分布式数据库解决方案,提供了分库分表、读写分离、弹性伸缩等功能。ShardingSphere 包含了多个组件,其中 ShardingSphere-Proxy 是为数据库访问提供了标准的 SQL 接口,而 ShardingSphere-UI 提供了可视化的界面来管理和操作 ShardingSphere 配置。 要通过 Docker 安装 ShardingSphere-ProxyShardingSphere-UI,你需要按照以下步骤操作: 1. 首先,确保你的系统中已经安装了 Docker。 2. 创建一个 Docker 网络,以确保容器之间可以互相通信。可以在终端中执行以下命令: ``` docker network create --driver bridge shardingSphereNet ``` 3. 从 Docker Hub 拉取 ShardingSphere-ProxyShardingSphere-UI 的官方镜像。可以通过以下命令完成: ``` docker pull shardingsphere/sharding-proxy docker pull shardingsphere/sharding-ui ``` 4. 运行 ShardingSphere-Proxy 容器。你需要提供数据库的配置文件(如 `server.yaml` 和 `config-xxx.yaml`),并且将其映射到容器内部的相应路径。以下是一个示例命令: ``` docker run -d --name sharding-proxy \ --network shardingSphereNet \ -v /path/to/your/proxy/configs:/opt/shardingsphere-proxy/conf \ -p 3307:3307 \ shardingsphere/sharding-proxy ``` 注意:`/path/to/your/proxy/configs` 是宿主机上存放配置文件的目录,`3307` 是容器暴露的端口,`/opt/shardingsphere-proxy/conf` 是容器中配置文件的路径。 5. 运行 ShardingSphere-UI 容器,并将其映射到宿主机的端口以便可以访问 UI。命令如下: ``` docker run -d --name sharding-ui \ --network shardingSphereNet \ -p 5000:8080 \ shardingsphere/sharding-ui ``` 这里 `5000` 是宿主机上用于访问 ShardingSphere-UI 的端口,而 `8080` 是容器内部 ShardingSphere-UI 服务的端口。 6. 配置完成后,你可以在浏览器中访问 `http://localhost:5000` 来打开 ShardingSphere-UI 的 Web 界面。 7. 使用 ShardingSphere-UI 连接到 ShardingSphere-Proxy,进行配置和管理。 请注意,具体的配置文件和启动参数可能需要根据你的实际需求和环境进行相应的调整。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值