java redis分库分表整合_SpringBoot整合分库分表利器ShardingSphere

# 服务端口

server:

port:8888# 服务名

spring:

application:

name: test-user

# 配置sharding jdbc分片规则

shardingsphere:

datasource:

# 连接名称(下面要用这个名称来区分库)

names: ds0,ds1

ds0:

type: com.alibaba.druid.pool.DruidDataSource

driver-class-name: com.mysql.jdbc.Driver

url: jdbc:mysql://192.168.1.19:3306/user0?useUnicode=true&characterEncoding=utf8&allowMultiQueries=true&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8

username: root

password:123initialSize:5#初始化大小

maxActive:200#最大值

maxWait:2000#最大等待时间,配置获取连接等待超时,时间单位都是毫秒ms

timeBetweenEvictionRunsMillis:60000#配置间隔多久才进行一次检测,检测需要关闭的空闲连接

ds1:

type: com.alibaba.druid.pool.DruidDataSource

driver-class-name: com.mysql.jdbc.Driver

url: jdbc:mysql://192.168.1.19:3306/user1?useUnicode=true&characterEncoding=utf8&allowMultiQueries=true&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8

username: root

password:123initialSize:5#初始化大小

maxActive:200#最大值

maxWait:2000#最大等待时间,配置获取连接等待超时,时间单位都是毫秒ms

timeBetweenEvictionRunsMillis:60000#配置间隔多久才进行一次检测,检测需要关闭的空闲连接

# 配置分片规则

sharding:

# 按表来区分

tables:

us_admin:

# 配置数据节点

actualDataNodes: ds${0..1}.us_admin${0..1}

# 分库策略

databaseStrategy:

inline:

# 分库的规则 用user_id这个字段来分库 总共有两个库 及ds0(user0)与ds1(user1)

shardingColumn: user_id

algorithmExpression: ds${user_id% 2}

# 分表策略

tableStrategy:

inline:

shardingColumn: addr_id

algorithmExpression: us_admin${addr_id% 2}

keyGenerator:

column: id

type: SNOWFLAKE

bindingTables:

us_admin

broadcastTables:

t_config

defaultDataSourceName: ds0

props:

sql.show:true# 配置xml 的扫描路径

mybatis:

mapper-locations: classpath:mapper/*.xml

check-config-location: true

type-aliases-package: com.sharding.sphere.model

configuration:

cacheEnabled: true

mapUnderscoreToCamelCase: true

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java中使用Redis存储Map集合可以使用Redis的Hash数据类型。Hash可以看做是一个键值对的集合,其中键和值都是字符串类型。 在SpringBoot中,我们可以使用RedisTemplate或者StringRedisTemplate来进行Redis的操作。这里介绍一下常见的操作: 1. Redis的String类型操作 ```java // 保存字符串 redisTemplate.opsForValue().set("key", "value"); // 获取字符串 String value = redisTemplate.opsForValue().get("key"); // 删除字符串 redisTemplate.delete("key"); ``` 2. Redis的Hash类型操作 ```java // 添加一个键值对 redisTemplate.opsForHash().put("hashKey", "hashField", "hashValue"); // 获取一个键值对 String value = (String) redisTemplate.opsForHash().get("hashKey", "hashField"); // 获取所有键值对 Map<Object, Object> hash = redisTemplate.opsForHash().entries("hashKey"); // 删除一个键值对 redisTemplate.opsForHash().delete("hashKey", "hashField"); ``` 3. Redis的List类型操作 ```java // 在列表左侧添加一个元素 redisTemplate.opsForList().leftPush("listKey", "value1"); // 在列表右侧添加一个元素 redisTemplate.opsForList().rightPush("listKey", "value2"); // 获取列表指定范围内的元素 List<String> values = redisTemplate.opsForList().range("listKey", 0, -1); // 删除列表中的元素 redisTemplate.opsForList().remove("listKey", 1, "value1"); ``` 4. Redis的Set类型操作 ```java // 添加一个元素 redisTemplate.opsForSet().add("setKey", "value1"); // 获取集合中所有元素 Set<String> values = redisTemplate.opsForSet().members("setKey"); // 删除一个元素 redisTemplate.opsForSet().remove("setKey", "value1"); ``` 5. Redis的实体类操作 ```java // 将实体类对象序列化后保存到Redis redisTemplate.opsForValue().set("user", user); // 从Redis中获取实体类对象 User user = (User) redisTemplate.opsForValue().get("user"); // 删除实体类对象 redisTemplate.delete("user"); ``` 以上就是RedisSpringBoot中的基本操作介绍,可以根据实际需求进行相应的操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值