Redis и Spring Data с самого начала. Часть 3 | OTUS
⚡ Подписка на курсы OTUS!
Интенсивная прокачка навыков для IT-специалистов!
Подробнее

Курсы

Программирование
iOS Developer. Professional
-8%
Базы данных
-12%
Python Developer. Basic
-10%
Java Developer. Professional
-7%
JavaScript Developer. Professional
-3%
Web-разработчик на Python
-10%
Highload Architect
-6%
JavaScript Developer. Basic
-8%
Backend-разработчик на PHP
-9%
Архитектура и шаблоны проектирования C# Developer. Professional
-9%
Team Lead
-6%
Kotlin Backend Developer
-9%
Разработчик на Spring Framework Framework Laravel Cloud Solution Architecture Reverse-Engineering. Professional Vue.js разработчик C# ASP.NET Core разработчик VOIP инженер NoSQL Flutter Mobile Developer Супер - интенсив по Kubernetes iOS Developer. Basic Супер-интенсив «СУБД в высоконагруженных системах» Супер-интенсив "Tarantool"
Инфраструктура
Базы данных
-12%
Network engineer. Basic
-10%
Network engineer
-4%
Инфраструктурная платформа на основе Kubernetes
-6%
Экспресс-курс по управлению миграциями (DBVC)
-10%
Экспресс-курс «Введение в непрерывную поставку на базе Docker»
-10%
Экспресс-курс «CI/CD или Непрерывная поставка с Docker и Kubernetes»
-30%
Дизайн сетей ЦОД
-13%
PostgreSQL
-8%
DevOps практики и инструменты Cloud Solution Architecture Разработчик голосовых ассистентов и чат-ботов VOIP инженер Супер-практикум по работе с протоколом BGP NoSQL Супер-практикум по использованию и настройке GIT Супер-интенсив «СУБД в высоконагруженных системах» Экспресс-курс «IaC Ansible»
Специализации Курсы в разработке Подготовительные курсы
+7 499 938-92-02

Redis и Spring Data с самого начала. Часть 3

Spring_Deep_20.5_site-5020-e0d2d3.png

В первой части мы рассмотрели NoSQL базы данных, в частности Key-Value NoSQL БД, и обсудили одну из самых популярных NoSQL БД — Redis. Во второй части мы узнали, что такое Spring Data и Spring Data Redis Repositories. В этой части посмотрим на альтернативный вариант подключения к Redis с помощью различных *Operations-классов (ну, точнее, интерфейсов, реализации будут – *Templates).

Spring Data Redis Operations

Корневым интерфейсом является RedisOperations и из него можно получить все остальные, которые предоставляются на большинство типов данных Redis. С помощью таких классов можно более специфично реализовывать mapping сущностей, а также более эффективно утилизировать место в Redis.

Итак, напишем свой собственный репозиторий на их основе. Сама сущность:

public class SimplePerson {
    private String id;
    private String name;

    public SimplePerson(String name) {
        this.id = UUID.randomUUID().toString();
        this.name = name;
    }

    public SimplePerson(String id, String name) {
        this.id = id;
        this.name = name;
    }

    // геттеры и сеттеры
}

Допустим, мы хотим хранить эту сущность не в виде хэша, а компактно в виде строк (name) по ключу. Соответственно наш репозиторий:

@Repository
@Transactional
public class SimplePersonRepository {

    private final RedisOperations<String, String> ops;

    public SimplePersonRepository(RedisOperations<String, String> ops) {
        this.ops = ops;
    }

    public SimplePerson findById(String id) {
        String name = ops.opsForValue().get(id);
        return new SimplePerson(id, name);
    }

    public String save(SimplePerson person) {
        ops.opsForValue().set(person.getId(), person.getName());
        return person.getId();
    }
}

Обратите внимание, что мы из корневого класса RedisOperations получаем операции для работы со значениями .opsForValue(). В действительности, таких возможностей – почти под каждый тип данных.

Ну и наконец, код программы с бином RedisTemplate:

@SpringBootApplication
public class Main {

    @Bean
    public RedisOperations redisOperations(LettuceConnectionFactory connectionFactory) {
        RedisTemplate<String, String> redisTemplate = new RedisTemplate<>();
        redisTemplate.setConnectionFactory(connectionFactory);
        redisTemplate.setEnableTransactionSupport(true);
        return redisTemplate;
    }

    public static void main(String[] args) {
        ApplicationContext context = SpringApplication.run(Main.class, args);
        SimplePersonRepository repository = context.getBean(SimplePersonRepository.class);
        String id = repository.save(new SimplePerson("Cidre"));
        SimplePerson person = repository.findById(id);
        System.out.println(person.getName());
    }
}

Оставлю вам удовольствие самостоятельно разобраться, например, нужна или нет аннотация @Transactional на этом репозитории. Несложно догадаться, что после работы в базе останутся следующие данные:

127.0.0.1:6379> keys *
1) "87c5a482-11e9-4ef4-8bb4-c77f5873aaa9"
127.0.0.1:6379> type 87c5a482-11e9-4ef4-8bb4-c77f5873aaa9
string
127.0.0.1:6379> get 87c5a482-11e9-4ef4-8bb4-c77f5873aaa9
"Cidre"

На этом всё. Успешного использования Redis!

Не пропустите новые полезные статьи!

Спасибо за подписку!

Мы отправили вам письмо для подтверждения вашего email.
С уважением, OTUS!

Автор
0 комментариев
Для комментирования необходимо авторизоваться