springboot整合spring-data-redis使用redisTemplate操作

2024-05-29 08:32

本文主要是介绍springboot整合spring-data-redis使用redisTemplate操作,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一.spring data redis的安装

1.1 安装gcc

安装命令为:yum install gcc-c++

[root@bogon ~]# yum install gcc-c++
Loaded plugins: fastestmirror, langpacks, product-id, search-disabled-repos,: subscription-managerThis system is not registered with an entitlement server. You can use subscription-manager to register.Loading mirror speeds from cached hostfile* base: ftp.sjtu.edu.cn* extras: ftp.sjtu.edu.cn* updates: mirror.lzu.edu.cn
base                                                     | 3.6 kB     00:00     
extras                                                   | 2.9 kB     00:00     
updates                                                  | 2.9 kB     00:00     
(1/2): extras/7/x86_64/primary_db                          | 225 kB   00:00     
(2/2): updates/7/x86_64/primary_db                         | 5.7 MB   00:02    
Installed:gcc-c++.x86_64 0:4.8.5-44.el7                                                                                                                                                        Dependency Installed:cpp.x86_64 0:4.8.5-44.el7                            gcc.x86_64 0:4.8.5-44.el7           glibc-devel.x86_64 0:2.17-323.el7_9           glibc-headers.x86_64 0:2.17-323.el7_9        kernel-headers.x86_64 0:3.10.0-1160.15.2.el7         libmpc.x86_64 0:1.0.1-3.el7         libstdc++-devel.x86_64 0:4.8.5-44.el7        Dependency Updated:glibc.x86_64 0:2.17-323.el7_9     glibc-common.x86_64 0:2.17-323.el7_9     libgcc.x86_64 0:4.8.5-44.el7     libgomp.x86_64 0:4.8.5-44.el7     libstdc++.x86_64 0:4.8.5-44.el7    Complete!

#查看gcc的版本:gcc -v

[root@bogon ~]# gcc -v
Using built-in specs.
COLLECT_GCC=gcc
COLLECT_LTO_WRAPPER=/usr/libexec/gcc/x86_64-redhat-linux/4.8.5/lto-wrapper
Target: x86_64-redhat-linux
Configured with: ../configure --prefix=/usr --mandir=/usr/share/man --infodir=/usr/share/info --with-bugurl=http://bugzilla.redhat.com/bugzilla --enable-bootstrap --enable-shared --enable-threads=posix --enable-checking=release --with-system-zlib --enable-__cxa_atexit --disable-libunwind-exceptions --enable-gnu-unique-object --enable-linker-build-id --with-linker-hash-style=gnu --enable-languages=c,c++,objc,obj-c++,java,fortran,ada,go,lto --enable-plugin --enable-initfini-array --disable-libgcj --with-isl=/builddir/build/BUILD/gcc-4.8.5-20150702/obj-x86_64-redhat-linux/isl-install --with-cloog=/builddir/build/BUILD/gcc-4.8.5-20150702/obj-x86_64-redhat-linux/cloog-install --enable-gnu-indirect-function --with-tune=generic --with-arch_32=x86-64 --build=x86_64-redhat-linux
Thread model: posix
gcc version 4.8.5 20150623 (Red Hat 4.8.5-44) (GCC) 

1.2 解压redis的软件包

进入redis的存储目录:/bonc-kecheng-jingxiang ,进行解压

[root@bogon bonc-kecheng-jingxiang]# tar -zxvf redis-6.2.1.tar.gz 
redis-6.2.1/
redis-6.2.1/.github/
redis-6.2.1/.github/ISSUE_TEMPLATE/
redis-6.2.1/.github/ISSUE_TEMPLATE/bug_report.md
redis-6.2.1/.github/ISSUE_TEMPLATE/crash_report.md
redis-6.2.1/.github/ISSUE_TEMPLATE/feature_request.md
redis-6.2.1/.github/ISSUE_TEMPLATE/other_stuff.md
redis-6.2.1/.github/ISSUE_TEMPLATE/question.md
redis-6.2.1/.github/workflows/
redis-6.2.1/.github/workflows/ci.yml
redis-6.2.1/.github/workflows/daily.yml
redis-6.2.1/.gitignore
redis-6.2.1/00-RELEASENOTES
redis-6.2.1/BUGS
redis-6.2.1/CONDUCT
redis-6.2.1/CONTRIBUTING
redis-6.2.1/COPYING
redis-6.2.1/INSTALL
redis-6.2.1/MANIFESTO
redis-6.2.1/Makefile
redis-6.2.1/README.md

1.3 进入解压后的目录进行编译

进入redis的解压后的目录,然后执行:make PREFIX=/usr/local/redis install  进行编译

[root@bogon bonc-kecheng-jingxiang]# ls
1.txt  redis-6.2.1  redis-6.2.1.tar.gz  xfce-tools-base.tar
[root@bogon bonc-kecheng-jingxiang]# cd redis-6.2.1/
[root@bogon redis-6.2.1]# ls
00-RELEASENOTES  CONDUCT       COPYING  INSTALL   MANIFESTO  redis.conf  runtest-cluster    runtest-sentinel  src    TLS.md
BUGS             CONTRIBUTING  deps     Makefile  README.md  runtest     runtest-moduleapi  sentinel.conf     tests  utils
[root@bogon redis-6.2.1]# pwd
/bonc-kecheng-jingxiang/redis-6.2.1
[root@bogon redis-6.2.1]# make PREFIX=/usr/local/redis install
cd src && make install
make[1]: Entering directory `/bonc-kecheng-jingxiang/redis-6.2.1/src'CC Makefile.dep
make[1]: Leaving directory `/bonc-kecheng-jingxiang/redis-6.2.1/src'
make[1]: Entering directory `/bonc-kecheng-jingxiang/redis-6.2.1/src'
rm -rf redis-server redis-sentinel redis-cli redis-benchmark redis-check-rdb redis-check-aof *.o *.gcda *.gcno *.gcov redis.info lcov-html Makefile.dep dict-benchmark
rm -f adlist.d quicklist.d ae.d anet.d dict.d server.d sds.d zmalloc.d lzf_c.d lzf_d.d pqsort.d zipmap.d sha1.d ziplist.d release.d networking.d util.d object.d db.d replication.d rdb.d t_string.d t_list.d t_set.d t_zset.d t_hash.d config.d aof.d pubsub.d multi.d debug.d sort.d intset.d syncio.d cluster.d crc16.d endianconv.d slowlog.d scripting.d bio.d rio.d rand.d memtest.d crcspeed.d crc64.d bitops.d sentinel.d notify.d setproctitle.d blocked.d hyperloglog.d latency.d sparkline.d redis-check-rdb.d redis-check-aof.d geo.d lazyfree.d module.d evict.d expire.d geohash.d geohash_helper.d childinfo.d defrag.d siphash.d rax.d t_stream.d listpack.d localtime.d lolwut.d lolwut5.d lolwut6.d acl.d gopher.d tracking.d connection.d tls.d sha256.d timeout.d setcpuaffinity.d monotonic.d mt19937-64.d anet.d adlist.d dict.d redis-cli.d zmalloc.d release.d ae.d crcspeed.d crc64.d siphash.d crc16.d monotonic.d cli_common.d mt19937-64.d ae.d anet.d redis-bench

 

1.4  启动redis

1.修改一下配置redis.conf配置文件的内容:

先进入到 redis-6.2.1目录下

[root@localhost redis-6.2.1]# vi redis.conf
[root@localhost redis-6.2.1]# 

修改内容如下:

2.先进入到:/usr/local/redis/bin 这个目录下,然后执行启动脚本命令:

 ./redis-server  /bonc-kecheng-jingxiang/redis-6.2.1/redis.conf

root@bogon redis-6.2.1]# cd /usr/local
[root@bogon local]# ls
bin  etc  games  include  lib  lib64  libexec  redis  sbin  share  src
[root@bogon local]# cd redis
[root@bogon redis]# ls
bin
[root@bogon redis]# cd bin
[root@bogon bin]# ls
redis-benchmark  redis-check-aof  redis-check-rdb  redis-cli  redis-sentinel  redis-server
[root@bogon bin]# ./redis-server  /bonc-kecheng-jingxiang/redis-6.2.1/redis.conf
9723:C 14 Mar 2021 21:52:47.279 # oO0OoO0OoO0Oo Redis is starting oO0OoO0OoO0Oo
9723:C 14 Mar 2021 21:52:47.280 # Redis version=6.2.1, bits=64, commit=00000000, modified=0, pid=9723, just started
9723:C 14 Mar 2021 21:52:47.280 # Configuration loaded
9723:M 14 Mar 2021 21:52:47.280 * Increased maximum number of open files to 10032 (it was originally set to 1024).
9723:M 14 Mar 2021 21:52:47.280 * monotonic clock: POSIX clock_gettime_._                                                  _.-``__ ''-._                                             _.-``    `.  `_.  ''-._           Redis 6.2.1 (00000000/0) 64 bit.-`` .-```.  ```\/    _.,_ ''-._                                   (    '      ,       .-`  | `,    )     Running in standalone mode|`-._`-...-` __...-.``-._|'` _.-'|     Port: 6379|    `-._   `._    /     _.-'    |     PID: 9723`-._    `-._  `-./  _.-'    _.-'                                   |`-._`-._    `-.__.-'    _.-'_.-'|                                  |    `-._`-._        _.-'_.-'    |           http://redis.io        `-._    `-._`-.__.-'_.-'    _.-'                                   |`-._`-._    `-.__.-'    _.-'_.-'|                                  |    `-._`-._        _.-'_.-'    |                                  `-._    `-._`-.__.-'_.-'    _.-'                                   `-._    `-.__.-'    _.-'                                       `-._        _.-'                                           `-.__.-'                                               9723:M 14 Mar 2021 21:52:47.281 # WARNING: The TCP backlog setting of 511 cannot be enforced because /proc/sys/net/core/somaxconn is set to the lower value of 128.
9723:M 14 Mar 2021 21:52:47.281 # Server initialized
9723:M 14 Mar 2021 21:52:47.281 # WARNING overcommit_memory is set to 0! Background save may fail under low memory condition. To fix this issue add 'vm.overcommit_memory = 1' to /etc/sysctl.conf and then reboot or run the command 'sysctl vm.overcommit_memory=1' for this to take effect.
9723:M 14 Mar 2021 21:52:47.282 * Loading RDB produced by version 6.2.1
9723:M 14 Mar 2021 21:52:47.282 * RDB age 51 seconds
9723:M 14 Mar 2021 21:52:47.282 * RDB memory usage when created 0.77 Mb
9723:M 14 Mar 2021 21:52:47.282 * DB loaded from disk: 0.000 seconds
9723:M 14 Mar 2021 21:52:47.282 * Ready to accept connections

启动后的截图: 

1.5 启动客户端进行查看

同样在打开一个新窗口,先进到/usr/local/redis/bin目录下,然后给执行: ./redis-cli

[root@192 ~]# cd /usr/local/redis
[root@192 redis]# bin
bash: bin: command not found...
[root@192 redis]# ls
bin
[root@192 redis]# cd bin
[root@192 bin]# ls
dump.rdb         redis-check-aof  redis-cli       redis-server
redis-benchmark  redis-check-rdb  redis-sentinel
[root@192 bin]# ./redis-cli
127.0.0.1:6379> keys *
(empty array)
127.0.0.1:6379> 

二 springboot整合spring data redis

2.1  spring data redis的作用

spring data redis的作用是简化对redis的开发工作,属于spring data 下的一个模块。

工程结构:

 2.2 pom文件

<dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency><dependency><groupId>org.apache.commons</groupId><artifactId>commons-pool2</artifactId></dependency>

2.3 application配置文件

# Redis数据库索引(默认为0)
#spring.redis.database=0# Redis服务器地址
spring.redis.host=192.168.1.192# Redis服务器连接端口
spring.redis.port=6379# Redis服务器连接密码(默认为空)
#spring.redis.password=root# 连接池最大连接数(使用负值表示没有限制)
spring.redis.jedis.pool.max-active=8# 连接池最大阻塞等待时间(使用负值表示没有限制)
spring.redis.jedis.pool.max-wait=-1# 连接池中的最大空闲连接
spring.redis.jedis.pool.max-idle=8# 连接池中的最小空闲连接
spring.redis.jedis.pool.min-idle=0# 连接超时时间(毫秒)
spring.redis.timeout=1000000

2.4 redis连接池

package com.ljf.spring.boot.demo.config;import com.fasterxml.jackson.annotation.JsonAutoDetect;
import com.fasterxml.jackson.annotation.PropertyAccessor;
import com.fasterxml.jackson.databind.ObjectMapper;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.connection.RedisConnectionFactory;
import org.springframework.data.redis.connection.RedisStandaloneConfiguration;
import org.springframework.data.redis.connection.jedis.JedisClientConfiguration;
import org.springframework.data.redis.connection.jedis.JedisConnectionFactory;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.serializer.Jackson2JsonRedisSerializer;
import org.springframework.data.redis.serializer.StringRedisSerializer;/*** 完成对Redis的整合的一些配置***/
@Configuration
public class RedisConfig {@Beanpublic RedisTemplate<Object, Object> redisTemplate(RedisConnectionFactory redisConnectionFactory) {RedisTemplate<Object, Object> redisTemplate = new RedisTemplate<>();redisTemplate.setConnectionFactory(redisConnectionFactory);// 使用Jackson2JsonRedisSerialize 替换默认序列化Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);ObjectMapper objectMapper = new ObjectMapper();objectMapper.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);objectMapper.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);jackson2JsonRedisSerializer.setObjectMapper(objectMapper);// 设置value的序列化规则和 key的序列化规则redisTemplate.setValueSerializer(jackson2JsonRedisSerializer);redisTemplate.setKeySerializer(new StringRedisSerializer());redisTemplate.afterPropertiesSet();return redisTemplate;}
}

2.5 controller

package com.ljf.spring.boot.demo.controller;import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.core.StringRedisTemplate;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;/*** @ClassName: RedisController* @Description: TODO* @Author: liujianfu* @Date: 2021/03/14 20:59:26 * @Version: V1.0**/
@Controller
public class RedisController {@Autowiredprivate StringRedisTemplate stringRedisTemplate;@Autowiredprivate RedisTemplate redisTemplate;/*** 添加一个字符串*/@RequestMapping("/add")@ResponseBodypublic String testSet(){this.redisTemplate.opsForValue().set("key", "中国人民ruc");System.out.println("add=====");return "ok";}/*** 获取一个字符串*/@RequestMapping("/get")@ResponseBodypublic String testGet(){String value = (String)this.redisTemplate.opsForValue().get("key");System.out.println(value);return  value;}
}

2.6 启动访问

2. 新增

3.查询

这篇关于springboot整合spring-data-redis使用redisTemplate操作的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1013156

相关文章

使用Python实现矢量路径的压缩、解压与可视化

《使用Python实现矢量路径的压缩、解压与可视化》在图形设计和Web开发中,矢量路径数据的高效存储与传输至关重要,本文将通过一个Python示例,展示如何将复杂的矢量路径命令序列压缩为JSON格式,... 目录引言核心功能概述1. 路径命令解析2. 路径数据压缩3. 路径数据解压4. 可视化代码实现详解1

Pandas透视表(Pivot Table)的具体使用

《Pandas透视表(PivotTable)的具体使用》透视表用于在数据分析和处理过程中进行数据重塑和汇总,本文就来介绍一下Pandas透视表(PivotTable)的具体使用,感兴趣的可以了解一下... 目录前言什么是透视表?使用步骤1. 引入必要的库2. 读取数据3. 创建透视表4. 查看透视表总结前言

Python 交互式可视化的利器Bokeh的使用

《Python交互式可视化的利器Bokeh的使用》Bokeh是一个专注于Web端交互式数据可视化的Python库,本文主要介绍了Python交互式可视化的利器Bokeh的使用,具有一定的参考价值,感... 目录1. Bokeh 简介1.1 为什么选择 Bokeh1.2 安装与环境配置2. Bokeh 基础2

SpringBoot UserAgentUtils获取用户浏览器的用法

《SpringBootUserAgentUtils获取用户浏览器的用法》UserAgentUtils是于处理用户代理(User-Agent)字符串的工具类,一般用于解析和处理浏览器、操作系统以及设备... 目录介绍效果图依赖封装客户端工具封装IP工具实体类获取设备信息入库介绍UserAgentUtils

Android使用ImageView.ScaleType实现图片的缩放与裁剪功能

《Android使用ImageView.ScaleType实现图片的缩放与裁剪功能》ImageView是最常用的控件之一,它用于展示各种类型的图片,为了能够根据需求调整图片的显示效果,Android提... 目录什么是 ImageView.ScaleType?FIT_XYFIT_STARTFIT_CENTE

Spring 中的循环引用问题解决方法

《Spring中的循环引用问题解决方法》:本文主要介绍Spring中的循环引用问题解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录什么是循环引用?循环依赖三级缓存解决循环依赖二级缓存三级缓存本章来聊聊Spring 中的循环引用问题该如何解决。这里聊

Java学习手册之Filter和Listener使用方法

《Java学习手册之Filter和Listener使用方法》:本文主要介绍Java学习手册之Filter和Listener使用方法的相关资料,Filter是一种拦截器,可以在请求到达Servl... 目录一、Filter(过滤器)1. Filter 的工作原理2. Filter 的配置与使用二、Listen

Pandas使用AdaBoost进行分类的实现

《Pandas使用AdaBoost进行分类的实现》Pandas和AdaBoost分类算法,可以高效地进行数据预处理和分类任务,本文主要介绍了Pandas使用AdaBoost进行分类的实现,具有一定的参... 目录什么是 AdaBoost?使用 AdaBoost 的步骤安装必要的库步骤一:数据准备步骤二:模型

Spring Boot中JSON数值溢出问题从报错到优雅解决办法

《SpringBoot中JSON数值溢出问题从报错到优雅解决办法》:本文主要介绍SpringBoot中JSON数值溢出问题从报错到优雅的解决办法,通过修改字段类型为Long、添加全局异常处理和... 目录一、问题背景:为什么我的接口突然报错了?二、为什么会发生这个错误?1. Java 数据类型的“容量”限制

使用Pandas进行均值填充的实现

《使用Pandas进行均值填充的实现》缺失数据(NaN值)是一个常见的问题,我们可以通过多种方法来处理缺失数据,其中一种常用的方法是均值填充,本文主要介绍了使用Pandas进行均值填充的实现,感兴趣的... 目录什么是均值填充?为什么选择均值填充?均值填充的步骤实际代码示例总结在数据分析和处理过程中,缺失数