• Stars
    star
    1,645
  • Rank 25,817 (Top 0.6 %)
  • Language
    Java
  • License
    Apache License 2.0
  • Created over 12 years ago
  • Updated 13 days ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

Provides support to increase developer productivity in Java when using Redis, a key-value store. Uses familiar Spring concepts such as a template classes for core API usage and lightweight repository style data access.

Spring Data Redis Spring Data Redis

Spring Data Redis icon?job=spring data redis%2Fmain&subject=Build Gitter Revved up by Gradle Enterprise

The primary goal of the Spring Data project is to make it easier to build Spring-powered applications that use new data access technologies such as non-relational databases, map-reduce frameworks, and cloud based data services.

This modules provides integration with the Redis store.

Features

  • Connection package as low-level abstraction across multiple Redis drivers (Lettuce and Jedis).

  • Exception translation to Spring’s portable Data Access exception hierarchy for Redis driver exceptions

  • RedisTemplate that provides a high level abstraction for performing various Redis operations, exception translation and serialization support.

  • Pubsub support (such as a MessageListenerContainer for message-driven POJOs).

  • Redis Sentinel and Redis Cluster support.

  • Reactive API using the Lettuce driver.

  • JDK, String, JSON and Spring Object/XML mapping serializers.

  • JDK Collection implementations on top of Redis.

  • Atomic counter support classes.

  • Sorting and Pipelining functionality.

  • Dedicated support for SORT, SORT/GET pattern and returned bulk values.

  • Redis implementation for Spring 3.1 cache abstraction.

  • Automatic implementation of Repository interfaces including support for custom finder methods using @EnableRedisRepositories.

  • CDI support for repositories.

Code of Conduct

This project is governed by the Spring Code of Conduct. By participating, you are expected to uphold this code of conduct. Please report unacceptable behavior to [email protected].

Getting Started

Here is a quick teaser of an application using Spring Data Redis in Java:

public class Example {

    // inject the actual template
    @Autowired
    private RedisTemplate<String, String> template;

    // inject the template as ListOperations
    // can also inject as Value, Set, ZSet, and HashOperations
    @Resource(name="redisTemplate")
    private ListOperations<String, String> listOps;

    public void addLink(String userId, URL url) {
        listOps.leftPush(userId, url.toExternalForm());
        // or use template directly
        redisTemplate.boundListOps(userId).leftPush(url.toExternalForm());
    }
}

@Configuration
class ApplicationConfig {

  @Bean
  public RedisConnectionFactory redisConnectionFactory() {
    return new LettuceConnectionFactory();
  }
}

Maven configuration

Add the Maven dependency:

<dependency>
  <groupId>org.springframework.data</groupId>
  <artifactId>spring-data-redis</artifactId>
  <version>${version}</version>
</dependency>

If you’d rather like the latest snapshots of the upcoming major version, use our Maven snapshot repository and declare the appropriate dependency version.

<dependency>
  <groupId>org.springframework.data</groupId>
  <artifactId>spring-data-redis</artifactId>
  <version>${version}-SNAPSHOT</version>
</dependency>

<repository>
  <id>spring-snapshot</id>
  <name>Spring Snapshot Repository</name>
  <url>https://repo.spring.io/snapshot</url>
</repository>

Getting Help

Having trouble with Spring Data? We’d love to help!

Reporting Issues

Spring Data uses Github as issue tracking system to record bugs and feature requests. If you want to raise an issue, please follow the recommendations below:

  • Before you log a bug, please search the issue tracker to see if someone has already reported the problem.

  • If the issue does not already exist, create a new issue.

  • Please provide as much information as possible with the issue report, we like to know the version of Spring Data that you are using, the JVM version, Stacktrace, etc.

  • If you need to paste code, or include a stack trace use Markdown code fences ```.

  • If possible try to create a test-case or project that replicates the issue. Attach a link to your code or a compressed file containing your code.

Building from Source

You don’t need to build from source to use Spring Data (binaries in repo.spring.io), but if you want to try out the latest and greatest, Spring Data can be easily built with the maven wrapper. You also need JDK 17 or above and make. The local build environment is managed within a Makefile to download, build and spin up Redis in various configurations (Standalone, Sentinel, Cluster, etc.)

 $ make test

The preceding command runs a full build. You can use make start, make stop, and make clean commands to control the environment yourself. This is useful if you want to avoid constant server restarts. Once all Redis instances have been started, you can either run tests in your IDE or the full Maven build:

 $ ./mvnw clean install

If you want to build with the regular mvn command, you will need Maven v3.8.0 or above.

Also see CONTRIBUTING.adoc if you wish to submit pull requests, and in particular please sign the Contributor’s Agreement before your first non-trivial change.

Building reference documentation

Building the documentation builds also the project without running tests.

 $ ./mvnw clean install -Pantora

The generated documentation is available from target/antora/site/index.html.

Guides

The spring.io site contains several guides that show how to use Spring Data step-by-step:

Examples

License

Spring Data Redis is Open Source software released under the Apache 2.0 license.

More Repositories

1

spring-boot

Spring Boot
Java
70,285
star
2

spring-framework

Spring Framework
Java
53,687
star
3

spring-security

Spring Security
Java
8,088
star
4

spring-petclinic

A sample Spring-based application
CSS
6,917
star
5

spring-data-examples

Spring Data Example Projects
Java
4,944
star
6

spring-authorization-server

Spring Authorization Server
Java
4,573
star
7

spring-data-elasticsearch

Provide support to increase developer productivity in Java when using Elasticsearch. Uses familiar Spring concepts such as a template classes for core API usage and lightweight repository style data access.
Java
2,833
star
8

spring-data-jpa

Simplifies the development of creating a JPA-based data access layer.
Java
2,796
star
9

spring-loaded

Java agent that enables class reloading in a running JVM
Java
2,705
star
10

spring-batch

Spring Batch is a framework for writing batch applications using Java and Spring
Java
2,496
star
11

spring-integration-samples

You are looking for examples, code snippets, sample applications for Spring Integration? This is the place.
Java
2,245
star
12

spring-retry

Java
2,037
star
13

spring-kafka

Provides Familiar Spring Abstractions for Apache Kafka
Java
1,978
star
14

spring-session

Spring Session
Java
1,810
star
15

spring-data-mongodb

Provides support to increase developer productivity in Java when using MongoDB. Uses familiar Spring concepts such as a template classes for core API usage and lightweight repository style data access.
Java
1,549
star
16

spring-integration

Spring Integration provides an extension of the Spring programming model to support the well-known Enterprise Integration Patterns (EIP)
Java
1,459
star
17

spring-statemachine

Spring Statemachine is a framework for application developers to use state machine concepts with Spring.
Java
1,448
star
18

spring-graphql

Spring Integration for GraphQL
Java
1,441
star
19

spring-restdocs

Test-driven documentation for RESTful services
Java
1,122
star
20

spring-hateoas

Spring HATEOAS - Library to support implementing representations for hyper-text driven REST web services.
Java
1,016
star
21

spring-security-samples

Java
1,014
star
22

spring-data-rest

Simplifies building hypermedia-driven REST web services on top of Spring Data repositories
Java
878
star
23

spring-cloud

Umbrella project for Spring Cloud
821
star
24

spring-net

Spring Framework for .NET
C#
819
star
25

sts4

The next generation of tooling for Spring Boot, including support for Cloud Foundry manifest files, Concourse CI pipeline definitions, BOSH deployment manifests, and more... - Available for Eclipse, Visual Studio Code, and Theia
Java
812
star
26

spring-data-neo4j

Provide support to increase developer productivity in Java when using Neo4j. Uses familiar Spring concepts such as a template classes for core API usage and lightweight repository style data access.
Java
796
star
27

spring-amqp

Spring AMQP - support for Spring programming model with AMQP, especially but not limited to RabbitMQ
Java
782
star
28

spring-data-commons

Spring Data Commons. Interfaces and code shared between the various datastore specific implementations.
Java
726
star
29

spring-data-r2dbc

Provide support to increase developer productivity in Java when using Reactive Relational Database Connectivity. Uses familiar Spring concepts such as a DatabaseClient for core API usage and lightweight repository style data access.
710
star
30

spring-data-relational

Spring Data Relational. Home of Spring Data JDBC and Spring Data R2DBC.
Java
705
star
31

spring-shell

Spring based shell
Java
685
star
32

spring-amqp-samples

Samples for Spring AMQP
Java
578
star
33

spring-modulith

Modular applications with Spring Boot
Java
548
star
34

spring-plugin

Java
424
star
35

spring-webflow-samples

CSS
399
star
36

spring-ai

An Application Framework for AI Engineering
Java
396
star
37

spring-data-cassandra

Provides support to increase developer productivity in Java when using Apache Cassandra. Uses familiar Spring concepts such as a template classes for core API usage and lightweight repository style data access.
Java
367
star
38

spring-hateoas-examples

Collection of examples on how (and why) to build hypermedia-driven apps with Spring HATEOAS
Java
358
star
39

spring-ldap

Spring LDAP
Java
333
star
40

spring-webflow

Spring Web Flow
Java
315
star
41

spring-ws

Spring Web Services
Java
301
star
42

spring-flo

JavaScript angular based embeddable graphical component for pipeline/graph building and editing
TypeScript
289
star
43

spring-integration-extensions

The Spring Integration Extensions project provides extension components for Spring Integration
Java
272
star
44

spring-vault

Provides familiar Spring abstractions for HashiCorp Vault
Java
272
star
45

spring-data-couchbase

Provides support to increase developer productivity in Java when using Couchbase. Uses familiar Spring concepts such as a template classes for core API usage and lightweight repository style data access.
Java
271
star
46

spring-data-envers

Envers extension of the Spring Data JPA module
260
star
47

spring-batch-extensions

Spring Batch Extensions
Java
217
star
48

spring-integration-aws

Java
192
star
49

spring-security-kerberos

Spring Security Kerberos
Java
167
star
50

spring-guice

Tools for using Spring in Guice and Guice in Spring
Java
165
star
51

gradle-plugins

Gradle plugins for use in building and publishing open-source Spring projects, e.g. Spring Framework, Spring Integration
Groovy
139
star
52

spring-pulsar

Spring Friendly Abstractions for Apache Pulsar
Java
136
star
53

spring-ws-samples

Java
134
star
54

spring-data-keyvalue

Project to provide infrastructure to implement Spring Data repositories on top of key-value-based, in-memory data stores.
Java
122
star
55

spring-data-gemfire

Spring Data integration for Pivotal GemFire
Java
98
star
56

spring-data-build

Modules to centralize common resources and configuration for Spring Data Maven builds.
Shell
91
star
57

spring-data

Spring Data
82
star
58

spring-data-ldap

Repository abstraction for Spring LDAP
Java
63
star
59

spring-data-geode

Spring Data support for Apache Geode
Java
49
star
60

spring-boot-data-geode

Spring Boot support for Apache Geode and VMware GemFire
Java
45
star
61

spring-session-data-mongodb

Spring Session for MongoDB
Java
45
star
62

spring-aot-smoke-tests

Java
42
star
63

spring-cli

A CLI focused on developer productivity
Java
42
star
64

spring-data-dev-tools

A collection of tools to support Spring Data development.
Java
40
star
65

spring-session-bom

Spring Session Bill of Materials
Java
31
star
66

spring-restdocs-samples

JavaScript
26
star
67

spring-credhub

Spring abstractions for Cloud Foundry CredHub
Java
25
star
68

spring-session-data-geode

Spring Session support for Apache Geode and VMware Tanzu GemFire
Java
21
star
69

spring-integration-splunk

Java
21
star
70

spring-test-data-geode

A Spring-based Test Framework supporting Unit and Integration testing for Spring Boot applications using Spring Data with either Apache Geode or VMware Tanzu GemFire
Java
21
star
71

spring-session-data-mongodb-examples

Java
16
star
72

spring-data-bom

Spring Data Bill of Materials
16
star
73

eclipse-integration-tcserver

Eclipse Integration for vFabric tc Server
Java
13
star
74

spring-integration-flow

Java
10
star
75

spring-checkpoint-restore-smoke-tests

Java
10
star
76

gh-pages

Shared gh-pages content for Spring projects
JavaScript
8
star
77

security-advisories

8
star
78

.github

7
star
79

spring-data-release

Command-line application to ship Spring Data releases
Java
5
star
80

spring-graphql-examples

3
star