分佈式數據存儲 之 Redis(二) —— spring中的緩存抽象

分佈式數據存儲 之 Redis(二) —— spring中的緩存抽象

1、spring boot 中的 StringRedisTemplate

1.StringRedisTemplate Demo

第一步:引入redis依賴

最重要的依賴java

compile('org.springframework.boot:spring-boot-starter-data-redis')web

此依賴爲springCloud 父項目 依賴(但已添加 redis 依賴)redis

buildscript {
    ext {
        springBootVersion = '2.1.2.RELEASE'
    }
    repositories {
        mavenLocal() //maven本地倉庫
        maven {
            url = "http://maven.aliyun.com/nexus/content/groups/public"
        }
        mavenCentral()//maven中心倉庫
    }
    dependencies {
        classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}")
    }
}

subprojects {
    apply plugin: 'java'
    apply plugin: 'eclipse'
    apply plugin: 'org.springframework.boot'
    apply plugin: 'io.spring.dependency-management'

    group = 'com.lichuang.kukri'
    version = '1.0.0'
    sourceCompatibility = 1.8

    repositories {
        mavenLocal() //maven本地倉庫
        maven {
            url = "http://maven.aliyun.com/nexus/content/groups/public"
        }
        mavenCentral()//maven中心倉庫
    }


    ext {
        springCloudVersion = 'Greenwich.RELEASE'
    }

    dependencies {
        compile('org.springframework.boot:spring-boot-starter-actuator')
        compile('org.springframework.boot:spring-boot-starter-web')
        compile('org.springframework.cloud:spring-cloud-starter')
        testCompile('org.springframework.boot:spring-boot-starter-test')
        
        //redis 依賴
        compile('org.springframework.boot:spring-boot-starter-data-redis')
    }

    dependencyManagement {
        imports {
            mavenBom "org.springframework.cloud:spring-cloud-dependencies:${springCloudVersion}"
        }
    }

}

第二步:建立 StringRedisTemplate 的 Bean

StringRedisTemplate 的構造函數可知須要 RedisConnectionFactory 的 Bean,又由 RedisConnectionFactory 可知須要 RedisStandaloneConfiguration 的 Bean, RedisStandaloneConfiguration 的構造函數中須要有 hostname 以及 portspring

@Configuration
@ComponentScan
public class AppConfig {

    //xxxTemplate -> 設計模式之一 模板方法設計模式

    @Bean
    public RedisStandaloneConfiguration redisStandaloneConfiguration(){
        RedisStandaloneConfiguration redisStandaloneConfiguration = new RedisStandaloneConfiguration("hostname",6379);
        return redisStandaloneConfiguration;
    }


    @Bean
    public RedisConnectionFactory redisConnectionFactory(){
        LettuceConnectionFactory connectionFactory = new LettuceConnectionFactory(redisStandaloneConfiguration());

        return connectionFactory;
    }

    @Bean
    public StringRedisTemplate stringRedisTemplate(){
        StringRedisTemplate redisTemplate = new StringRedisTemplate(redisConnectionFactory());

        return redisTemplate;
    }

}

第三步:獲取 StringRedisTemplate 進行運用

  1. 添加數據至Redis: redisTemplate.opsForValue().set("name","test");
  2. 從Redis 獲取數據: redisTemplate.opsForValue().get("name")
public class RedisServer {
    public static void main(String[] args) {
        AnnotationConfigApplicationContext applicationContext = new AnnotationConfigApplicationContext(AppConfig.class);

        StringRedisTemplate redisTemplate = applicationContext.getBean(StringRedisTemplate.class);


        redisTemplate.opsForValue().set("name","test");

        //System.out.println(redisTemplate.opsForValue().get("name"));

       /* redisTemplate.watch("name");
        redisTemplate.multi();
        redisTemplate.exec();*/
    }
}

2、 Cache Abstraction

1.核心接口

CachManager

Spring's central cache manager SPI.shell

方法

​ Cache getCache(String name);json

​ Collection getCacheNames(); 設計模式

Cache

Interface that defines common cache operations緩存

常見實現類
  1. ConcurrentMapCache
  2. RedisCache
  3. EhCacheCache

KeyGenerator

​ SimpleKeyGenerator(默認實現類)app

2. 常見註解

@Cacheable

若是緩存中有值,則使用緩存中的值;若是沒有則執行業務方法並存入緩存中less

屬性
  1. condition

    判斷

  2. unless

@CachePut

每次都會執行業務方法,並設置緩存

@CacheEvict

每次都會執行業務方法,並刪除緩存

3. Cache Abstraction Demo

第一步:引入依賴

dependencies {
    compile('org.springframework.boot:spring-boot-starter-data-redis')
    compile group: 'org.projectlombok', name: 'lombok', version: '1.18.6'
    compile group: 'com.alibaba', name: 'fastjson', version: '1.2.56'
}

第二步:建立 CacheManager 的 Bean

注:

​ 1. GenericFastJsonRedisSerializer 類 使 Value 的 儲存方式 爲 Josn

@Configuration
@ComponentScan
@MapperScan("com.lichuang.kukri.springcloudproject.config.dao")
@EnableCaching
public class AppConfig {

    //xxxTemplate -> 設計模式之一 模板方法設計模式

    @Bean
    public RedisStandaloneConfiguration redisStandaloneConfiguration(){
        RedisStandaloneConfiguration redisStandaloneConfiguration = new RedisStandaloneConfiguration("hostname",6379);
        return redisStandaloneConfiguration;
    }

    @Bean
    public CacheManager cacheManager(){
        RedisCacheWriter redisCacheWriter = RedisCacheWriter.nonLockingRedisCacheWriter(redisConnectionFactory());

        RedisCacheConfiguration redisCacheConfiguration = RedisCacheConfiguration.defaultCacheConfig()
                .serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(new GenericFastJsonRedisSerializer()));

        RedisCacheManager redisCacheManager = new RedisCacheManager(redisCacheWriter,redisCacheConfiguration);

        return redisCacheManager;
    }

}

第三步:建立 Service

@Service
public class CacheService {

    @CachePut(cacheNames = "person")
    public Person update(int age){
        Person person = new Person();
        person.setPersonName("admin");
        person.setAge(age);
        return person;
    }


    @Cacheable(cacheNames = "person")
    public Person selectP(int age){
        Person person = new Person();
        person.setPersonName("test");
        person.setAge(age);
        return person;
    }

    @Cacheable(cacheNames = "cache")
    public String selectC(int i){
        System.out.println("select");
        return "admin";
    }
}

​ Person.java(實體類)

public class Person {

    private String personName;

    private int age;

    public String getPersonName() {
        return personName;
    }

    public void setPersonName(String personName) {
        this.personName = personName;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }
}

第四步:運行

public class RedisServer {
    public static void main(String[] args) {
        AnnotationConfigApplicationContext applicationContext = new AnnotationConfigApplicationContext(AppConfig.class);

        PersonDao personDao = applicationContext.getBean(PersonDao.class);
        List<Person> people = personDao.select();
        for (int i = 0; i < people.size(); i++) {
            System.out.println(people.get(i).getPersonName() + "-" + people.get(i).getAge());
        }

        /*CacheService cacheService = applicationContext.getBean(CacheService.class);
        for (int i = 0; i < 2; i++) {
            //System.out.println(cacheService.selectC(i));

            cacheService.update(i);
        }*/
    }
}

第五步:在 Redis 中獲取

127.0.0.1:6379> get cache::0
"\"admin\""
127.0.0.1:6379> get person::0
"{\"@type\":\"com.bean.Person\",\"age\":1,\"name\":\"test\"}"
相關文章
相關標籤/搜索