# tmerclub去除分库分表 `目前order`、`payment`服务使用sharding-jdbc进行分库分表,如果需要将其恢复改为单库单表,需要做如下操作: 1. 原分表的表结构改为单表结构 2. nacos中的`xxx.yml`(相关服务的配置文件) 中的多个数据库配置删除,复制一份单库的配置来替换即可 3. 更改canal配置 4. 移除shardingsphere中间件 5. 注释或者删掉对应服务下`tmerclub-common/tmerclub-common-sharding-proxy/src/main/java/com/mall4j/cloud/common/sharding/proxy`包中的sharding配置类 ## 1. 原分表的表结构改为单表结构 连接shardingsphere中的数据库,将对应的分表结构和数据复制到总库中 ![img_1.jpg](../img/常见问题/去除分库分表-01.jpg) ## 2. 将nacos中的`xxx.yml`(相关服务的配置文件) 中的数据库连接换成目前mysql的连接地址,如下图所示: ![img_2.jpg](../img/常见问题/去除分库分表-02.jpg) ## 3. 更改canal配置 修改服务器部署 `canal/conf/example` 目录下的[instance.properties](../开发环境搭建/中间件docker-compse一键安装/canal/conf/example/instance.properties) 将所有`tmerclub_xxx_[0-9]+.xxx_[0-9]+:*` 格式的多库多表数据库配置改为单库单表 `tmerclub_order.order:*` 例:将 `tmerclub_order_[0-9]+.order_[0-9]+:*` 改为 `tmerclub_order.order:*`, 其他数据库的同理 修改完成后,重启canal ![img_1.png](../img/常见问题/去除分库分表-05.png) ## 4. 移除shardingsphere中间件 将tmerclub-shardingsphere这个中间件删除,不部署 ## 5. 注释或者删掉对应服务下`tmerclub-common/tmerclub-common-sharding-proxy/src/main/java/com/mall4j/cloud/common/sharding/proxy`包中的sharding配置类 ![img_1.png](../img/常见问题/去除分库分表-04.jpg)