🚀 feat(新增): 未解决配合MyBatisPlus使用
This commit is contained in:
parent
ef909c895a
commit
f16550ddee
|
@ -29,22 +29,17 @@
|
||||||
<artifactId>httpclient</artifactId>
|
<artifactId>httpclient</artifactId>
|
||||||
<version>4.5.14</version>
|
<version>4.5.14</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
<!-- redis -->
|
|
||||||
<dependency>
|
|
||||||
<groupId>org.springframework.boot</groupId>
|
|
||||||
<artifactId>spring-boot-starter-data-redis</artifactId>
|
|
||||||
</dependency>
|
|
||||||
<!-- redisson 分布式锁-->
|
|
||||||
<dependency>
|
|
||||||
<groupId>org.redisson</groupId>
|
|
||||||
<artifactId>redisson</artifactId>
|
|
||||||
<version>3.26.1</version>
|
|
||||||
</dependency>
|
|
||||||
<!-- 查询ip地址 -->
|
<!-- 查询ip地址 -->
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.lionsoul</groupId>
|
<groupId>org.lionsoul</groupId>
|
||||||
<artifactId>ip2region</artifactId>
|
<artifactId>ip2region</artifactId>
|
||||||
<version>2.6.5</version>
|
<version>2.6.5</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
<!-- ShardingSphere -->
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.apache.shardingsphere</groupId>
|
||||||
|
<artifactId>shardingsphere-jdbc-core-spring-boot-starter</artifactId>
|
||||||
|
<version>5.2.0</version>
|
||||||
|
</dependency>
|
||||||
</dependencies>
|
</dependencies>
|
||||||
</project>
|
</project>
|
||||||
|
|
|
@ -6,8 +6,14 @@ import com.baomidou.mybatisplus.extension.plugins.inner.BlockAttackInnerIntercep
|
||||||
import com.baomidou.mybatisplus.extension.plugins.inner.OptimisticLockerInnerInterceptor;
|
import com.baomidou.mybatisplus.extension.plugins.inner.OptimisticLockerInnerInterceptor;
|
||||||
import com.baomidou.mybatisplus.extension.plugins.inner.PaginationInnerInterceptor;
|
import com.baomidou.mybatisplus.extension.plugins.inner.PaginationInnerInterceptor;
|
||||||
import lombok.extern.slf4j.Slf4j;
|
import lombok.extern.slf4j.Slf4j;
|
||||||
|
import org.apache.ibatis.session.SqlSessionFactory;
|
||||||
|
import org.apache.shardingsphere.driver.jdbc.core.datasource.ShardingSphereDataSource;
|
||||||
|
import org.mybatis.spring.SqlSessionFactoryBean;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.context.annotation.Bean;
|
import org.springframework.context.annotation.Bean;
|
||||||
import org.springframework.context.annotation.Configuration;
|
import org.springframework.context.annotation.Configuration;
|
||||||
|
import org.springframework.jdbc.datasource.DataSourceTransactionManager;
|
||||||
|
import org.springframework.transaction.PlatformTransactionManager;
|
||||||
import org.springframework.transaction.annotation.EnableTransactionManagement;
|
import org.springframework.transaction.annotation.EnableTransactionManagement;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -17,6 +23,9 @@ import org.springframework.transaction.annotation.EnableTransactionManagement;
|
||||||
@Configuration
|
@Configuration
|
||||||
@Slf4j
|
@Slf4j
|
||||||
public class MybatisPlusConfig {
|
public class MybatisPlusConfig {
|
||||||
|
@Autowired
|
||||||
|
private ShardingSphereDataSource dataSource;
|
||||||
|
|
||||||
@Bean
|
@Bean
|
||||||
public MybatisPlusInterceptor mybatisPlusInterceptor() {
|
public MybatisPlusInterceptor mybatisPlusInterceptor() {
|
||||||
log.info("MybatisPlusInterceptor===>注入Mybatis-Plus配置...");
|
log.info("MybatisPlusInterceptor===>注入Mybatis-Plus配置...");
|
||||||
|
@ -33,5 +42,17 @@ public class MybatisPlusConfig {
|
||||||
|
|
||||||
return interceptor;
|
return interceptor;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Bean
|
||||||
|
public SqlSessionFactory sqlSessionFactory() throws Exception {
|
||||||
|
SqlSessionFactoryBean sqlSessionFactoryBean = new SqlSessionFactoryBean();
|
||||||
|
sqlSessionFactoryBean.setDataSource(dataSource);
|
||||||
|
// 可以设置MyBatis-Plus的配置,比如mapper.xml的位置等
|
||||||
|
return sqlSessionFactoryBean.getObject();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Bean
|
||||||
|
public PlatformTransactionManager transactionManager() {
|
||||||
|
return new DataSourceTransactionManager(dataSource);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,98 +0,0 @@
|
||||||
package cn.bunny.common.service.config;
|
|
||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonAutoDetect;
|
|
||||||
import com.fasterxml.jackson.annotation.PropertyAccessor;
|
|
||||||
import com.fasterxml.jackson.databind.ObjectMapper;
|
|
||||||
import com.fasterxml.jackson.databind.SerializationFeature;
|
|
||||||
import com.fasterxml.jackson.databind.jsontype.impl.LaissezFaireSubTypeValidator;
|
|
||||||
import com.fasterxml.jackson.datatype.jsr310.JavaTimeModule;
|
|
||||||
import com.fasterxml.jackson.datatype.jsr310.deser.LocalDateDeserializer;
|
|
||||||
import com.fasterxml.jackson.datatype.jsr310.deser.LocalDateTimeDeserializer;
|
|
||||||
import com.fasterxml.jackson.datatype.jsr310.ser.LocalDateSerializer;
|
|
||||||
import com.fasterxml.jackson.datatype.jsr310.ser.LocalDateTimeSerializer;
|
|
||||||
import lombok.extern.slf4j.Slf4j;
|
|
||||||
import org.springframework.cache.CacheManager;
|
|
||||||
import org.springframework.context.annotation.Bean;
|
|
||||||
import org.springframework.data.redis.cache.RedisCacheConfiguration;
|
|
||||||
import org.springframework.data.redis.cache.RedisCacheManager;
|
|
||||||
import org.springframework.data.redis.connection.RedisConnectionFactory;
|
|
||||||
import org.springframework.data.redis.connection.lettuce.LettuceConnectionFactory;
|
|
||||||
import org.springframework.data.redis.core.RedisTemplate;
|
|
||||||
import org.springframework.data.redis.serializer.GenericJackson2JsonRedisSerializer;
|
|
||||||
import org.springframework.data.redis.serializer.Jackson2JsonRedisSerializer;
|
|
||||||
import org.springframework.data.redis.serializer.RedisSerializationContext;
|
|
||||||
import org.springframework.data.redis.serializer.StringRedisSerializer;
|
|
||||||
import org.springframework.stereotype.Component;
|
|
||||||
|
|
||||||
import java.time.Duration;
|
|
||||||
import java.time.LocalDate;
|
|
||||||
import java.time.LocalDateTime;
|
|
||||||
import java.time.format.DateTimeFormatter;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 设置Redis序列化
|
|
||||||
*/
|
|
||||||
@Component
|
|
||||||
@Slf4j
|
|
||||||
public class RedisConfiguration {
|
|
||||||
/**
|
|
||||||
* 使用StringRedisSerializer序列化为字符串
|
|
||||||
*/
|
|
||||||
@Bean
|
|
||||||
public RedisTemplate<String, Object> redisTemplate(LettuceConnectionFactory connectionFactory) {
|
|
||||||
log.info("RedisConfiguration===>使用StringRedisSerializer序列化为字符串");
|
|
||||||
|
|
||||||
RedisTemplate<String, Object> redisTemplate = new RedisTemplate<>();
|
|
||||||
redisTemplate.setConnectionFactory(connectionFactory);
|
|
||||||
// 设置key序列化为string
|
|
||||||
redisTemplate.setKeySerializer(new StringRedisSerializer());
|
|
||||||
// 设置value序列化为JSON,使用GenericJackson2JsonRedisSerializer替换默认序列化
|
|
||||||
redisTemplate.setValueSerializer(new GenericJackson2JsonRedisSerializer());
|
|
||||||
redisTemplate.setHashKeySerializer(new StringRedisSerializer());
|
|
||||||
redisTemplate.setHashValueSerializer(new GenericJackson2JsonRedisSerializer());
|
|
||||||
|
|
||||||
return redisTemplate;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 解决cache(@Cacheable)把数据缓存到redis中的value是乱码问题
|
|
||||||
*/
|
|
||||||
@Bean
|
|
||||||
@SuppressWarnings("all")
|
|
||||||
public CacheManager cacheManager(RedisConnectionFactory factory) {
|
|
||||||
log.info("RedisConfiguration===>解决cache(@Cacheable)把数据缓存到redis中的value是乱码问题");
|
|
||||||
|
|
||||||
// 配置序列化
|
|
||||||
RedisCacheConfiguration config = RedisCacheConfiguration.defaultCacheConfig()
|
|
||||||
.serializeKeysWith(RedisSerializationContext.SerializationPair.fromSerializer(new StringRedisSerializer()))
|
|
||||||
.serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(jsonRedisSerializer()))
|
|
||||||
.entryTtl(Duration.ofDays(30));
|
|
||||||
|
|
||||||
return RedisCacheManager.builder(factory).cacheDefaults(config).build();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 指定的日期模式
|
|
||||||
*/
|
|
||||||
public Jackson2JsonRedisSerializer<Object> jsonRedisSerializer() {
|
|
||||||
log.info("RedisConfiguration===>指定的日期模式");
|
|
||||||
|
|
||||||
ObjectMapper mapper = new ObjectMapper();
|
|
||||||
// 设置ObjectMapper访问权限
|
|
||||||
mapper.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
|
|
||||||
// 记录序列化之后的数据类型,方便反序列化
|
|
||||||
mapper.activateDefaultTyping(LaissezFaireSubTypeValidator.instance, ObjectMapper.DefaultTyping.NON_FINAL);
|
|
||||||
// LocalDatetime序列化,默认不兼容jdk8日期序列化
|
|
||||||
JavaTimeModule timeModule = new JavaTimeModule();
|
|
||||||
timeModule.addDeserializer(LocalDate.class, new LocalDateDeserializer(DateTimeFormatter.ofPattern("yyyy-MM-dd")));
|
|
||||||
timeModule.addSerializer(LocalDate.class, new LocalDateSerializer(DateTimeFormatter.ofPattern("yyyy-MM-dd")));
|
|
||||||
|
|
||||||
timeModule.addDeserializer(LocalDateTime.class, new LocalDateTimeDeserializer(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss")));
|
|
||||||
timeModule.addSerializer(LocalDateTime.class, new LocalDateTimeSerializer(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss")));
|
|
||||||
// 关闭默认的日期格式化方式,默认UTC日期格式 yyyy-MM-dd’T’HH:mm:ss.SSS
|
|
||||||
mapper.disable(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS);
|
|
||||||
mapper.registerModule(timeModule);
|
|
||||||
|
|
||||||
return new Jackson2JsonRedisSerializer<>(mapper, Object.class);
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -55,18 +55,6 @@
|
||||||
<groupId>org.aspectj</groupId>
|
<groupId>org.aspectj</groupId>
|
||||||
<artifactId>aspectjweaver</artifactId>
|
<artifactId>aspectjweaver</artifactId>
|
||||||
</dependency>
|
</dependency>
|
||||||
<!-- shardingsphere -->
|
|
||||||
<dependency>
|
|
||||||
<groupId>org.apache.shardingsphere</groupId>
|
|
||||||
<artifactId>shardingsphere-jdbc-core</artifactId>
|
|
||||||
<version>5.4.1</version>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>org.apache.shardingsphere</groupId>
|
|
||||||
<artifactId>shardingsphere-jdbc</artifactId>
|
|
||||||
<version>5.4.1</version>
|
|
||||||
<type>pom</type>
|
|
||||||
</dependency>
|
|
||||||
|
|
||||||
</dependencies>
|
</dependencies>
|
||||||
|
|
||||||
|
|
|
@ -17,9 +17,3 @@ bunny:
|
||||||
sqlData: db_user
|
sqlData: db_user
|
||||||
username: root
|
username: root
|
||||||
password: "02120212"
|
password: "02120212"
|
||||||
|
|
||||||
redis:
|
|
||||||
host: 1192.168.3.98
|
|
||||||
port: 6379
|
|
||||||
database: 3
|
|
||||||
password: "123456"
|
|
||||||
|
|
|
@ -18,8 +18,3 @@ bunny:
|
||||||
username: root
|
username: root
|
||||||
password: "02120212"
|
password: "02120212"
|
||||||
|
|
||||||
redis:
|
|
||||||
host: 1192.168.3.98
|
|
||||||
port: 6379
|
|
||||||
database: 3
|
|
||||||
password: "123456"
|
|
||||||
|
|
|
@ -1,37 +1,63 @@
|
||||||
server:
|
server:
|
||||||
port: 8800
|
port: 8800
|
||||||
|
|
||||||
spring:
|
spring:
|
||||||
|
main:
|
||||||
|
allow-bean-definition-overriding: true
|
||||||
profiles:
|
profiles:
|
||||||
active: @profiles.active@
|
active: @profiles.active@
|
||||||
application:
|
application:
|
||||||
name: bunny-service
|
name: bunny-service
|
||||||
datasource:
|
# datasource:
|
||||||
driver-class-name: org.apache.shardingsphere.driver.ShardingSphereDriver
|
# # driver-class-name: org.apache.shardingsphere.driver.ShardingSphereDriver
|
||||||
url: jdbc:shardingsphere:classpath:static/shardingsphere.yaml
|
# # url: jdbc:shardingsphere:classpath:static/shardingsphere.yaml
|
||||||
# type: com.zaxxer.hikari.HikariDataSource
|
# # type: com.zaxxer.hikari.HikariDataSource
|
||||||
# driver-class-name: com.mysql.cj.jdbc.Driver
|
# driver-class-name: com.mysql.cj.jdbc.Driver
|
||||||
# url: jdbc:mysql://${bunny.master.host}:${bunny.master.port}/${bunny.master.sqlData}?serverTimezone=GMT%2B8&useSSL=false&characterEncoding=utf-8&allowPublicKeyRetrieval=true
|
# url: jdbc:mysql://${bunny.master.host}:${bunny.master.port}/${bunny.master.sqlData}?serverTimezone=GMT%2B8&useSSL=false&characterEncoding=utf-8&allowPublicKeyRetrieval=true
|
||||||
# username: ${bunny.master.username}
|
# username: ${bunny.master.username}
|
||||||
# password: ${bunny.master.password}
|
# password: ${bunny.master.password}
|
||||||
|
|
||||||
|
shardingsphere:
|
||||||
data:
|
datasource:
|
||||||
redis:
|
names: master, slave1, slave2
|
||||||
host: ${bunny.redis.host}
|
master:
|
||||||
port: ${bunny.redis.port}
|
type: com.zaxxer.hikari.HikariDataSource
|
||||||
database: ${bunny.redis.database}
|
driver-class-name: com.mysql.cj.jdbc.Driver
|
||||||
password: ${bunny.redis.password}
|
jdbc-url: jdbc:mysql://${bunny.master.host}:${bunny.master.port}/${bunny.master.sqlData}?serverTimezone=GMT%2B8&useSSL=false&characterEncoding=utf-8&allowPublicKeyRetrieval=true
|
||||||
lettuce:
|
username: ${bunny.master.username}
|
||||||
pool:
|
password: ${bunny.master.password}
|
||||||
max-active: 20 #最大连接数
|
slave1:
|
||||||
max-wait: -1 #最大阻塞等待时间(负数表示没限制)
|
type: com.zaxxer.hikari.HikariDataSource
|
||||||
max-idle: 5 #最大空闲
|
driver-class-name: com.mysql.cj.jdbc.Driver
|
||||||
min-idle: 0 #最小空闲
|
jdbc-url: jdbc:mysql://${bunny.slave1.host}:${bunny.slave1.port}/${bunny.slave1.sqlData}?serverTimezone=GMT%2B8&useSSL=false&characterEncoding=utf-8&allowPublicKeyRetrieval=true
|
||||||
|
username: ${bunny.slave1.username}
|
||||||
|
password: ${bunny.slave1.password}
|
||||||
|
slave2:
|
||||||
|
type: com.zaxxer.hikari.HikariDataSource
|
||||||
|
driver-class-name: com.mysql.cj.jdbc.Driver
|
||||||
|
jdbc-url: jdbc:mysql://${bunny.slave2.host}:${bunny.slave2.port}/${bunny.slave2.sqlData}?serverTimezone=GMT%2B8&useSSL=false&characterEncoding=utf-8&allowPublicKeyRetrieval=true
|
||||||
|
username: ${bunny.slave2.username}
|
||||||
|
password: ${bunny.slave2.password}
|
||||||
|
rules:
|
||||||
|
readwrite-splitting:
|
||||||
|
data-sources:
|
||||||
|
readwrite_ds:
|
||||||
|
static-strategy:
|
||||||
|
write-data-source-name: master
|
||||||
|
read-data-source-names: slave1, slave2
|
||||||
|
load-balancer-name: round_robin
|
||||||
|
load-balancers:
|
||||||
|
round_robin:
|
||||||
|
type: ROUND_ROBIN
|
||||||
|
sharding:
|
||||||
|
default-database-strategy:
|
||||||
|
hint:
|
||||||
|
sharding-algorithm-name: master
|
||||||
|
|
||||||
jackson:
|
jackson:
|
||||||
date-format: yyyy-MM-dd HH:mm:ss
|
date-format: yyyy-MM-dd HH:mm:ss
|
||||||
time-zone: GMT+8
|
time-zone: GMT+8
|
||||||
|
|
||||||
|
|
||||||
mybatis-plus:
|
mybatis-plus:
|
||||||
mapper-locations: classpath:mapper/*.xml
|
mapper-locations: classpath:mapper/*.xml
|
||||||
configuration:
|
configuration:
|
||||||
|
|
Loading…
Reference in New Issue