SpringBoot 整合Redis 数据库的方法

网友投稿 262 2023-02-11


SpringBoot 整合Redis 数据库的方法

Redis简介

Redis(官网: https://redis.io )是一个基于内存的日志型可持久化的缓存数据库,保存形式为key-value格式,Redis完全免费开源,它使用ANSI C语言编写。与其他的key - value缓存产品一样,Redis具有以下三个特点。

• Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用;

• Redis不仅支持简单的key-value类型数据,同时还提供字符串、链表、集合、有序集合和哈希等数据结构的存储;

• Redis支持数据备份,即master-slave模式的数据备份。

在Mac系统上,无需下载Redis即可使用它,以下是从Redis的托管服务器下载Redis压缩包并解压的相关命令。

wget http://download.redis.io/releases/redis-4.0.8.tar.gz

tar xzf redis-4.0.8.tar.gz

cd redis-4.0.8

make

使用Redis提供的服务之前,需要先启动Redis相关的服务,在mac系统上启动Redis的命令如下。

src/redis-server

然后,重新打开一个Redis客户端,使用以下的命令来连接Redis server。

src/redis-cli

redis> set foo bar

OK

redis> get foo

"bar"

整合Redis 数据库

使用Redis之前需要引入相关依赖,Maven方式依赖的脚本如下:

org.springframework.boot

spring-boot-starter-data-redis

之后我们把Redis的相关配置写入yml,这里建议根据之前不同的环境写入不同的配置,Redis默认使用的端口是6379,通常Redis默认使用0号数据库,默认共有16个数据库:

#redis配置

redis:

# 数据库索引

database: 0

# 服务器地址

host: 127.0.0.1

# 服务器连接端口

port: 6379

# 链接密码

password:

# 链接池

pool:

# 最大连接数(负值表示没有限制)

max-active: 8

# 最大阻塞等待时间(负值表示没有限制)

max-wait: 1

# 最大空闲链接

max-idle: 8

# 最小空闲链接

min-idle: 0

# 链接超时时间(毫秒)

timeout: 0

如果是application.propertNZFLVies方式,部分配置如下:

spring.redis.hostName=127.0.0.1

spring.redis.port=6379

spring.redis.pool.maxActive=8

spring.redis.pool.maxWait=-1

spring.redis.pool.maxIdle=8

spring.redis.pool.minIdle=0

spring.redis.timeout=0

新建RedisConfig.java文件用来存放配置文件。

@Configuration

@EnableCaching//开启注解

public class RedisConfig extends CachingConfigurerSupport {

@Bean

public CacheManager cacheManager(RedisTemplate,?> redisTemplate) {

CacheManager cacheManager = new RedisCacheManager(redisTemplate);

return cacheManager;

}

@Bean

public RedisTemplate redisTemplate(RedisConnectionFactory factory) {

RedisTemplate redisTemplate = new RedisTemplate();

redisTemplate.setConnectionFactory(factory);

return redisTemplate;

}

}

在service包中建立一个RedisService.java类。

public interface RedisService {

public void set(String key, Object value);

public Object get(String key);

}

新建一个service实现类RedisServiceImpl.java。

@Service

public class RedisServiceImpl implements RedisService {

@Resource

private RedisTemplate redisTemplate;

public void set(String key, Object value) {

ValueOperations

vo.set(key, value);

}

public Object get(String key) {

ValueOperations vo = redisTemplate.opsForValue();

return vo.get(key);

}

}

新建Controller层代码UserController.java

@Controller

@RequestMapping(path="/user")

public class UserController {

@Autowired

private UserService userService;

@Autowired

private RedisService redisService;

//从redis获取某个用户

@RequestMapping(value = "/getuserfromredis", method = RequestMethod.GET)

public @ResponseBody User getRedis(@RequestParam String key) {

return (User)redisService.get(key);

}

//获取所有用户

@RequestMapping(value = "/getusers", method = RequestMethod.GET)

public @ResponseBody Page list(Model model, Pageable pageable){

return userService.findAll(pageable);

}

//添加用户

@GetMapping(value="/adduser")

public @ResponseBody String addUser(@RequestParam String dictum,

@RequestParam String password, @RequestParam String username) {

User user = new User();

user.setDictum(dictum);

user.setPassword(password);

user.setUsername(username);

System.out.println(user);

userService.saveUser(user);

redisService.set(user.getId()+"", user);

return "Saved";

}

}

本文设计的实体类User.java的代码如下,需要把对象存放在redis需要将对象序列化。

@Entity

@Table(name="s_user")

public class User implements Serializable {

private static final long serialVersionUID = 1L;

@Id

@GeneratedValue(strategy=GenerationType.AUTO)

private Integer id;

private String username;

private String password;

private String dictum;

@OneToMany(mappedBy = "user", fetch = FetchType. LAZY, cascade = {CascadeType. ALL})

private Set setPhoto;

//省略getter和setter

@Override

public String toString() {

return "User [id=" + id + ", username=" + username + ", password="

+ password + ", dictum=" + dictum + ", setPhoto=" + setPhoto

+ "]";

}

}

总结

以上所述是给大家介绍的SpringBoot 整合Redis 数据库的方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,会及时回复大家的。在此也非常感谢大家对我们网站的支持!

vo.set(key, value);

}

public Object get(String key) {

ValueOperations vo = redisTemplate.opsForValue();

return vo.get(key);

}

}

新建Controller层代码UserController.java

@Controller

@RequestMapping(path="/user")

public class UserController {

@Autowired

private UserService userService;

@Autowired

private RedisService redisService;

//从redis获取某个用户

@RequestMapping(value = "/getuserfromredis", method = RequestMethod.GET)

public @ResponseBody User getRedis(@RequestParam String key) {

return (User)redisService.get(key);

}

//获取所有用户

@RequestMapping(value = "/getusers", method = RequestMethod.GET)

public @ResponseBody Page list(Model model, Pageable pageable){

return userService.findAll(pageable);

}

//添加用户

@GetMapping(value="/adduser")

public @ResponseBody String addUser(@RequestParam String dictum,

@RequestParam String password, @RequestParam String username) {

User user = new User();

user.setDictum(dictum);

user.setPassword(password);

user.setUsername(username);

System.out.println(user);

userService.saveUser(user);

redisService.set(user.getId()+"", user);

return "Saved";

}

}

本文设计的实体类User.java的代码如下,需要把对象存放在redis需要将对象序列化。

@Entity

@Table(name="s_user")

public class User implements Serializable {

private static final long serialVersionUID = 1L;

@Id

@GeneratedValue(strategy=GenerationType.AUTO)

private Integer id;

private String username;

private String password;

private String dictum;

@OneToMany(mappedBy = "user", fetch = FetchType. LAZY, cascade = {CascadeType. ALL})

private Set setPhoto;

//省略getter和setter

@Override

public String toString() {

return "User [id=" + id + ", username=" + username + ", password="

+ password + ", dictum=" + dictum + ", setPhoto=" + setPhoto

+ "]";

}

}

总结

以上所述是给大家介绍的SpringBoot 整合Redis 数据库的方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,会及时回复大家的。在此也非常感谢大家对我们网站的支持!


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:IntelliJ IDEA中ajax开发实现分页查询示例
下一篇:Java实现两人五子棋游戏(六) 行棋方变换
相关文章

 发表评论

暂时没有评论,来抢沙发吧~