- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章springboot与redis的简单整合实例由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
前言 。
redis是一个缓存、消息代理和功能丰富的键值存储。stringboot提供了基本的自动配置。本文记录一下springboot与redis的简单整合实例 。
官方文档:https://docs.spring.io/spring-boot/docs/2.1.0.release/reference/htmlsingle/ 。
前期准备 。
首先我们要有一个redis服务,由于我没有linux环境,为了方便搭建项目,直接在windows下安装,参考这篇博客:windows下安装redis服务 。
安装步骤:一直点下一步(偷懒,步骤9、10设置密码我没有设置) 。
下载、安装、启动好redis服务后我们设置一个key并获取一下 。
代码编写 。
maven引包 。
1
2
3
4
5
|
<!-- redis -->
<dependency>
<groupid>org.springframework.boot</groupid>
<artifactid>spring-boot-starter-data-redis</artifactid>
</dependency>
|
配置文件 。
我们先看一下都有哪些redis相关配置,发现好多都有默认值,而且刚好符合我们现在的测试环境,于是乎我的配置文件是这样滴.... 。
1
2
|
server.port=
1113
spring.application.name=redis-server
|
接口测试代码 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
@restcontroller
public
class
controller{
@autowired
private
stringredistemplate template;
@requestmapping
(
"/redis/get/{key}"
)
private
string get(
@pathvariable
(
"key"
) string key){
return
template.opsforvalue().get(key);
}
@requestmapping
(
"/redis/set/{key}/{value}"
)
private
boolean
set(
@pathvariable
(
"key"
) string key,
@pathvariable
(
"value"
) string value){
boolean
flag =
true
;
try
{
template.opsforvalue().set(key,value);
}
catch
(exception e) {
e.printstacktrace();
flag =
false
;
}
return
flag;
}
}
|
测试效果 。
我们直接启动springboot的main函数,浏览器访问测试接口 。
扩展工具类 。
关于stringredistemplate类的操作自行查阅资料,我在网上找了一个工具类,我没有测试过,但可以参考自行测试! 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
|
@suppresswarnings
(
"all"
)
@component
public
class
redisutil {
private
static
stringredistemplate template;
/**
* 静态注入
*/
public
redisutil(stringredistemplate template) {
redisutil.template = template;
}
/**
* 指定缓存失效时间
*
* @param key 键
* @param time 时间(秒)
*/
private
void
expire(string key,
long
time) {
try
{
if
(time >
0
) {
template.expire(key, time, timeunit.seconds);
}
}
catch
(exception e) {
e.printstacktrace();
}
}
/**
* 根据key 获取过期时间
*
* @param key 键 不能为null
* @return 时间(秒) 返回0代表为永久有效
*/
public
long
getexpire(string key) {
return
template.getexpire(key, timeunit.seconds);
}
/**
* 判断key是否存在
*
* @param key 键
* @return true 存在 false不存在
*/
public
boolean
haskey(string key) {
try
{
return
template.haskey(key);
}
catch
(exception e) {
e.printstacktrace();
return
false
;
}
}
/**
* 删除缓存
*
* @param key 可以传一个值 或多个
*/
public
void
del(string... key) {
if
(key !=
null
&& key.length >
0
) {
if
(key.length ==
1
) {
template.delete(key[
0
]);
}
else
{
template.delete(collectionutils.arraytolist(key));
}
}
}
//============================string=============================
/**
* 普通缓存获取
*
* @param key 键
* @return 值
*/
public
object get(string key) {
return
key ==
null
?
null
: template.opsforvalue().get(key);
}
/**
* 普通缓存放入
*
* @param key 键
* @param value 值
* @return true成功 false失败
*/
public
boolean
set(string key, object value) {
try
{
template.opsforvalue().set(key, string.valueof(value));
return
true
;
}
catch
(exception e) {
e.printstacktrace();
return
false
;
}
}
/**
* 普通缓存放入并设置时间
*
* @param key 键
* @param value 值
* @param time 时间(秒) time要大于0 如果time小于等于0 将设置无限期
* @return true成功 false 失败
*/
public
boolean
set(string key, object value,
long
time) {
try
{
if
(time >
0
) {
template.opsforvalue().set(key, string.valueof(value), time, timeunit.seconds);
}
else
{
set(key, value);
}
return
true
;
}
catch
(exception e) {
e.printstacktrace();
return
false
;
}
}
/**
* 递增
*
* @param key 键
* @return
*/
public
long
incr(string key,
long
delta) {
if
(delta <
0
) {
throw
new
runtimeexception(
"递增因子必须大于0"
);
}
return
template.opsforvalue().increment(key, delta);
}
/**
* 递减
*
* @param key 键
* @return
*/
public
long
decr(string key,
long
delta) {
if
(delta <
0
) {
throw
new
runtimeexception(
"递减因子必须大于0"
);
}
return
template.opsforvalue().increment(key, -delta);
}
//================================map=================================
/**
* hashget
*
* @param key 键 不能为null
* @param item 项 不能为null
* @return 值
*/
public
object hget(string key, string item) {
return
template.opsforhash().get(key, item);
}
/**
* 获取hashkey对应的所有键值
*
* @param key 键
* @return 对应的多个键值
*/
public
map<object, object> hmget(string key) {
return
template.opsforhash().entries(key);
}
/**
* hashset
*
* @param key 键
* @param map 对应多个键值
* @return true 成功 false 失败
*/
public
boolean
hmset(string key, map<string, object> map) {
try
{
template.opsforhash().putall(key, map);
return
true
;
}
catch
(exception e) {
e.printstacktrace();
return
false
;
}
}
/**
* hashset 并设置时间
*
* @param key 键
* @param map 对应多个键值
* @param time 时间(秒)
* @return true成功 false失败
*/
public
boolean
hmset(string key, map<string, object> map,
long
time) {
try
{
template.opsforhash().putall(key, map);
if
(time >
0
) {
expire(key, time);
}
return
true
;
}
catch
(exception e) {
e.printstacktrace();
return
false
;
}
}
/**
* 向一张hash表中放入数据,如果不存在将创建
*
* @param key 键
* @param item 项
* @param value 值
* @return true 成功 false失败
*/
public
boolean
hset(string key, string item, object value) {
try
{
template.opsforhash().put(key, item, value);
return
true
;
}
catch
(exception e) {
e.printstacktrace();
return
false
;
}
}
/**
* 向一张hash表中放入数据,如果不存在将创建
*
* @param key 键
* @param item 项
* @param value 值
* @param time 时间(秒) 注意:如果已存在的hash表有时间,这里将会替换原有的时间
* @return true 成功 false失败
*/
public
boolean
hset(string key, string item, object value,
long
time) {
try
{
template.opsforhash().put(key, item, value);
if
(time >
0
) {
expire(key, time);
}
return
true
;
}
catch
(exception e) {
e.printstacktrace();
return
false
;
}
}
/**
* 删除hash表中的值
*
* @param key 键 不能为null
* @param item 项 可以使多个 不能为null
*/
public
void
hdel(string key, object... item) {
template.opsforhash().delete(key, item);
}
/**
* 判断hash表中是否有该项的值
*
* @param key 键 不能为null
* @param item 项 不能为null
* @return true 存在 false不存在
*/
public
boolean
hhaskey(string key, string item) {
return
template.opsforhash().haskey(key, item);
}
/**
* hash递增 如果不存在,就会创建一个 并把新增后的值返回
*
* @param key 键
* @param item 项
* @param by 要增加几(大于0)
* @return
*/
public
double
hincr(string key, string item,
double
by) {
return
template.opsforhash().increment(key, item, by);
}
/**
* hash递减
*
* @param key 键
* @param item 项
* @param by 要减少记(小于0)
* @return
*/
public
double
hdecr(string key, string item,
double
by) {
return
template.opsforhash().increment(key, item, -by);
}
//============================set=============================
/**
* 根据key获取set中的所有值
*
* @param key 键
* @return
*/
public
set<object> sget(string key) {
try
{
return
collections.singleton(template.opsforset().members(key));
}
catch
(exception e) {
e.printstacktrace();
return
null
;
}
}
/**
* 根据value从一个set中查询,是否存在
*
* @param key 键
* @param value 值
* @return true 存在 false不存在
*/
public
boolean
shaskey(string key, object value) {
try
{
return
template.opsforset().ismember(key, value);
}
catch
(exception e) {
e.printstacktrace();
return
false
;
}
}
/**
* 将数据放入set缓存
*
* @param key 键
* @param values 值 可以是多个
* @return 成功个数
*/
public
long
sset(string key, object... values) {
try
{
return
template.opsforset().add(key, string.valueof(values));
}
catch
(exception e) {
e.printstacktrace();
return
0
;
}
}
/**
* 将set数据放入缓存
*
* @param key 键
* @param time 时间(秒)
* @param values 值 可以是多个
* @return 成功个数
*/
public
long
ssetandtime(string key,
long
time, string... values) {
try
{
long
count = template.opsforset().add(key, values);
if
(time >
0
) {
expire(key, time);
}
return
count;
}
catch
(exception e) {
e.printstacktrace();
return
0
;
}
}
/**
* 获取set缓存的长度
*
* @param key 键
* @return
*/
public
long
sgetsetsize(string key) {
try
{
return
template.opsforset().size(key);
}
catch
(exception e) {
e.printstacktrace();
return
0
;
}
}
/**
* 移除值为value的
*
* @param key 键
* @param values 值 可以是多个
* @return 移除的个数
*/
public
long
setremove(string key, object... values) {
try
{
long
count = template.opsforset().remove(key, values);
return
count;
}
catch
(exception e) {
e.printstacktrace();
return
0
;
}
}
//===============================list=================================
/**
* 获取list缓存的内容
*
* @param key 键
* @param start 开始
* @param end 结束 0 到 -1代表所有值
* @return
*/
public
list<string> lget(string key,
long
start,
long
end) {
try
{
return
template.opsforlist().range(key, start, end);
}
catch
(exception e) {
e.printstacktrace();
return
null
;
}
}
/**
* 获取list缓存的长度
*
* @param key 键
* @return
*/
public
long
lgetlistsize(string key) {
try
{
return
template.opsforlist().size(key);
}
catch
(exception e) {
e.printstacktrace();
return
0
;
}
}
/**
* 通过索引 获取list中的值
*
* @param key 键
* @param index 索引 index>=0时, 0 表头,1 第二个元素,依次类推;index<0时,-1,表尾,-2倒数第二个元素,依次类推
* @return
*/
public
object lgetindex(string key,
long
index) {
try
{
return
template.opsforlist().index(key, index);
}
catch
(exception e) {
e.printstacktrace();
return
null
;
}
}
/**
* 将list放入缓存
*
* @param key 键
* @param value 值
* @return
*/
public
boolean
lset(string key, object value) {
try
{
template.opsforlist().rightpush(key, (string) value);
return
true
;
}
catch
(exception e) {
e.printstacktrace();
return
false
;
}
}
/**
* 将list放入缓存
*
* @param key 键
* @param value 值
* @param time 时间(秒)
* @return
*/
public
boolean
lset(string key, object value,
long
time) {
try
{
template.opsforlist().rightpush(key, (string) value);
if
(time >
0
) {
expire(key, time);
}
return
true
;
}
catch
(exception e) {
e.printstacktrace();
return
false
;
}
}
/**
* 将list放入缓存
*
* @param key 键
* @param value 值
* @return
*/
public
boolean
lset(string key, list<object> value) {
try
{
template.opsforlist().rightpushall(key, string.valueof(value));
return
true
;
}
catch
(exception e) {
e.printstacktrace();
return
false
;
}
}
/**
* 将list放入缓存
*
* @param key 键
* @param value 值
* @param time 时间(秒)
* @return
*/
public
boolean
lset(string key, list<object> value,
long
time) {
try
{
template.opsforlist().rightpushall(key, string.valueof(value));
if
(time >
0
) {
expire(key, time);
}
return
true
;
}
catch
(exception e) {
e.printstacktrace();
return
false
;
}
}
/**
* 根据索引修改list中的某条数据
*
* @param key 键
* @param index 索引
* @param value 值
* @return
*/
public
boolean
lupdateindex(string key,
long
index, object value) {
try
{
template.opsforlist().set(key, index, (string) value);
return
true
;
}
catch
(exception e) {
e.printstacktrace();
return
false
;
}
}
/**
* 移除n个值为value
*
* @param key 键
* @param count 移除多少个
* @param value 值
* @return 移除的个数
*/
public
long
lremove(string key,
long
count, object value) {
try
{
long
remove = template.opsforlist().remove(key, count, value);
return
remove;
}
catch
(exception e) {
e.printstacktrace();
return
0
;
}
}
}
|
后记 。
这只是一个单机版的redis服务,而且还是windows上面的,后续有空再搭建redis集群 。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我.
原文链接:https://www.cnblogs.com/huanzi-qch/p/10239888.html 。
最后此篇关于springboot与redis的简单整合实例的文章就讲到这里了,如果你想了解更多关于springboot与redis的简单整合实例的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
SpringBoot-Admin 服务监控 简单介绍 Spring Boot Actuator 是 Spring Boot 自带的一个功能模块, 提供了一组已经开箱即用的生产环境下常用
我想查找通过关键字匹配字段 nameEnglish 或 nameChinese 的模型列表。我花了一个多小时谷歌搜索但我做不到。请帮忙。 Springboot Mongo 入门示例 https://s
(请注意:在调查 this issue 时,我更好地发现了我在此处介绍的问题根源) 我对 Hibernate 和 SpringBoot 非常陌生。我的项目涉及一个搜索引擎,其中索引(javafx 客户
我最近有一个 Web 应用程序从 springboot 升级到 springboot 2。当我将其部署到 Tomcat 8 时,它似乎启动了,但没有完全启动。 在 localhost.2019-09-
我是 Spring boot 的新手...我在运行 Controller 时遇到问题, Description: Field todoService in com.springboot.todoCon
我有一个SpringBoot应用程序,它使用以下配置与PostgreSQL通信,通过AWS Beanstrik部署:。在我将AWS Aurora证书更新为rds-ca-ecc384-g1之前,一切都很
一、介绍 在实际的软件系统开发过程中,由于业务的需求,在代码层面实现数据的脱敏还是远远不够的,往往还需要在数据库层面针对某些关键性的敏感信息,例如:身份证号、银行卡号、手机号、工资等信息进行加密存储
Selenium Selenium是一个用于Web应用程序自动化测试的开源工具套件。它主要用于以下目的: 浏览器自动化:Selenium能够模拟真实用户在不同浏览器(如Chrome、Fire
一、简介 在实际的项目开发过程中,经常需要用到邮件通知功能。例如,通过邮箱注册,邮箱找回密码,邮箱推送报表等等,实际的应用场景非常的多。 早期的时候,为了能实现邮件的自动发送功能,通常会使用 Ja
SpringBoot:基于redis自定义注解实现后端接口防重复提交校验 一、添加依赖 org.springframework.boot spring
SpringBoot:使用Jackson完成全局序列化配置 一、测试准备 com.fasterxml.jackson.core jackson-cor
springboot:整合rocketmq 一、简易消息操作 生产者整合mq 导入依赖 org.springframework.boot
springboot:常用注解 一、spring常用注解 包扫描+组件标注注解 @Component:泛指各种组件 @Controller、@Service、@Repository都可以称为@Comp
我们经常需要在两个系统之间进行一些数据的交互,这时候我们就需要开发数据交互接口。 一般来说,遇到比较多的接口有HTTP接口、WebService接口、FTP文件传输。今天我要来学习一下在SpringB
背景 近期项目上线,甲方要求通过安全检测才能进行验收,故针对扫描结果对系统进行了一系列的安全加固,本文对一些常见的安全问题及防护策略进行介绍,提供对应的解决方案 跨站脚本攻击 XSS常发生于论坛评论等
1.排除 Spring-boot-starter 默认的日志配置 将原本的 spring-boot-starter 改为 org.springframework.boot
springboot:解决跨域问题 一、跨域简介 URL的组成: // 协议 + 域名(子域名 + 主域名) + 端口号 + 资源地址 http://www.baidu.com:8080/ 只要协
一、自定义Starter 的思路: 创建一个Maven工程,创建三个模块 一个模块为demo-app,一个模块为demo-module,一个模块为demo-module-springboot-star
1.pom.xml 4.0.0 org.springframework.boot spring-boot-starter-parent
1.pom.xml 4.0.0 org.springframework.boot spring-boot-starter-parent
我是一名优秀的程序员,十分优秀!