tp5mysql分表_基于ThinkPHP5.1扩展的分布式分表数据库存储架构,开贴记录下相关重要代码...

基于ThinkPHP5.1扩展的分布式分表数据库存储架构,开贴记录下相关重要代码

6cd5e4fd49658da7be73f2e8e3760c00.png

1年前

阅读 6695

评论 0

喜欢 4

### 核心技术

1、PHP分表存储

2、分布式服务器(数据库),主从复制

3、合表查询分页

### 分表存储代码

```php

namespace org;

class SubTable

{

// 缓存表名称地址

protected static $table_path = '';

// 缓存表名称列表

protected static $table_list = [];

// 表前缀

private static $prefix = 'tp_';

// 表中缀:TP的分表链接只能是下划线中缀

private static $in_prefix = '_';

// 表名称

private static $table = '';

// 单例实例

private static $instance;

// 私有化构造函数,可以保证在类外该类不能被实例化

private function __construct(){}

// 禁止克隆单例类,防止二次new

private function __clone()

{

die('此对象不允许被克隆');

}

/**

* 用于初始化单例类

* @todo 无

* @author 小黄牛

* @version v1.0.1 + 2019.05.23

* @deprecated 暂不弃用

* @global 无

* @param string $table

* @return void

*/

public static function init($table)

{

self::$table = $table;

if (!self::$instance instanceof self) {

// 生成缓存地址

self::$table_path = ROOT_PATH . DIRECTORY_SEPARATOR .'public'. DIRECTORY_SEPARATOR .'data'. DIRECTORY_SEPARATOR .'table_cache' . DIRECTORY_SEPARATOR . $table . '_cache.php';

// 获得单例

self::$instance = new self();

// 返回单例

return self::$instance;

}

return self::$instance;

}

/**

* 简单hash算法,生成表名

* @todo 无

* @autho

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我可以为您解答关于SpringBoot和ShardingSphere实现读写分离的问题。 首先,您需要在pom.xml文件中添加ShardingSphere相关依赖: ```xml <dependency> <groupId>org.apache.shardingsphere</groupId> <artifactId>sharding-jdbc-core</artifactId> <version>${sharding-sphere.version}</version> </dependency> <dependency> <groupId>org.apache.shardingsphere</groupId> <artifactId>sharding-jdbc-spring-boot-starter</artifactId> <version>${sharding-sphere.version}</version> </dependency> ``` 其中${sharding-sphere.version}为ShardingSphere的版本号。 接下来,您需要在application.yml或application.properties中配置ShardingSphere的数据源和规则,例如: ```yaml spring: shardingsphere: datasource: names: ds_master, ds_slave_0, ds_slave_1 ds_master: url: jdbc:mysql://localhost:3306/mydb_master?useSSL=false&serverTimezone=Asia/Shanghai&useUnicode=true&characterEncoding=utf-8 username: root password: root ds_slave_0: url: jdbc:mysql://localhost:3306/mydb_slave_0?useSSL=false&serverTimezone=Asia/Shanghai&useUnicode=true&characterEncoding=utf-8 username: root password: root ds_slave_1: url: jdbc:mysql://localhost:3306/mydb_slave_1?useSSL=false&serverTimezone=Asia/Shanghai&useUnicode=true&characterEncoding=utf-8 username: root password: root sharding: default-data-source-name: ds_master master-slave-rules: ds_0: master-data-source-name: ds_master slave-data-source-names: ds_slave_0, ds_slave_1 load-balance-algorithm-type: round_robin ``` 以上配置中,我们配置了3个数据源:ds_master, ds_slave_0和ds_slave_1,其中ds_master为主库,ds_slave_0和ds_slave_1为从库。然后我们使用了ShardingSphere提供的master-slave规则将ds_master和ds_slave_0、ds_slave_1进行了关联,并使用了轮询算法进行负载均衡,从而实现了读写分离。 最后,您需要在SpringBoot主类上添加@EnableSharding注解,以启用ShardingSphere的功能。 这就是使用SpringBoot和ShardingSphere实现读写分离的基本步骤。希望对您有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值