1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18 package org.apache.shardingsphere.sharding.cache;
19
20 import lombok.Getter;
21 import org.apache.shardingsphere.sharding.api.config.cache.ShardingCacheConfiguration;
22 import org.apache.shardingsphere.sharding.cache.checker.ShardingRouteCacheableChecker;
23 import org.apache.shardingsphere.sharding.cache.route.cache.ShardingRouteCache;
24 import org.apache.shardingsphere.sharding.rule.ShardingRule;
25 import org.apache.shardingsphere.timeservice.core.rule.TimestampServiceRule;
26 import org.apache.shardingsphere.timeservice.core.rule.builder.DefaultTimestampServiceConfigurationBuilder;
27
28
29
30
31 @Getter
32 public final class ShardingCache {
33
34 private final ShardingCacheConfiguration configuration;
35
36 private final ShardingRule shardingRule;
37
38 private final TimestampServiceRule timestampServiceRule;
39
40 private final ShardingRouteCacheableChecker routeCacheableChecker;
41
42 private final ShardingRouteCache routeCache;
43
44 public ShardingCache(final ShardingCacheConfiguration config, final ShardingRule shardingRule) {
45 configuration = config;
46 this.shardingRule = shardingRule;
47 timestampServiceRule = new TimestampServiceRule(new DefaultTimestampServiceConfigurationBuilder().build());
48 routeCacheableChecker = new ShardingRouteCacheableChecker(this);
49 routeCache = new ShardingRouteCache(config.getRouteCache());
50 }
51 }