溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

SpringBoot 整合Redis 數(shù)據(jù)庫(kù)的方法

發(fā)布時(shí)間:2020-08-25 20:24:30 來(lái)源:腳本之家 閱讀:132 作者:https://blog.csdn.ne 欄目:編程語(yǔ)言

Redis簡(jiǎn)介

Redis(官網(wǎng): https://redis.io )是一個(gè)基于內(nèi)存的日志型可持久化的緩存數(shù)據(jù)庫(kù),保存形式為key-value格式,Redis完全免費(fèi)開(kāi)源,它使用ANSI C語(yǔ)言編寫。與其他的key - value緩存產(chǎn)品一樣,Redis具有以下三個(gè)特點(diǎn)。

• Redis支持?jǐn)?shù)據(jù)的持久化,可以將內(nèi)存中的數(shù)據(jù)保存在磁盤中,重啟的時(shí)候可以再次加載進(jìn)行使用;

• Redis不僅支持簡(jiǎn)單的key-value類型數(shù)據(jù),同時(shí)還提供字符串、鏈表、集合、有序集合和哈希等數(shù)據(jù)結(jié)構(gòu)的存儲(chǔ);

• Redis支持?jǐn)?shù)據(jù)備份,即master-slave模式的數(shù)據(jù)備份。

SpringBoot 整合Redis 數(shù)據(jù)庫(kù)的方法 

在Mac系統(tǒng)上,無(wú)需下載Redis即可使用它,以下是從Redis的托管服務(wù)器下載Redis壓縮包并解壓的相關(guān)命令。

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提供的服務(wù)之前,需要先啟動(dòng)Redis相關(guān)的服務(wù),在mac系統(tǒng)上啟動(dòng)Redis的命令如下。

src/redis-server

SpringBoot 整合Redis 數(shù)據(jù)庫(kù)的方法 

然后,重新打開(kāi)一個(gè)Redis客戶端,使用以下的命令來(lái)連接Redis server。

src/redis-cli
redis> set foo bar
OK
redis> get foo
"bar"

SpringBoot 整合Redis 數(shù)據(jù)庫(kù)的方法 

整合Redis 數(shù)據(jù)庫(kù)

使用Redis之前需要引入相關(guān)依賴,Maven方式依賴的腳本如下:

<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>

之后我們把Redis的相關(guān)配置寫入yml,這里建議根據(jù)之前不同的環(huán)境寫入不同的配置,Redis默認(rèn)使用的端口是6379,通常Redis默認(rèn)使用0號(hào)數(shù)據(jù)庫(kù),默認(rèn)共有16個(gè)數(shù)據(jù)庫(kù):

#redis配置
 redis:
# 數(shù)據(jù)庫(kù)索引
  database: 0
#  服務(wù)器地址
  host: 127.0.0.1
#  服務(wù)器連接端口
  port: 6379
#  鏈接密碼
  password:
#  鏈接池
  pool:
#  最大連接數(shù)(負(fù)值表示沒(méi)有限制)
   max-active: 8
#   最大阻塞等待時(shí)間(負(fù)值表示沒(méi)有限制)
   max-wait: 1
#   最大空閑鏈接
   max-idle: 8
#   最小空閑鏈接
   min-idle: 0
#  鏈接超時(shí)時(shí)間(毫秒)
  timeout: 0

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

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文件用來(lái)存放配置文件。

@Configuration 
@EnableCaching//開(kāi)啟注解 
public class RedisConfig extends CachingConfigurerSupport {
  @Bean
  public CacheManager cacheManager(RedisTemplate<?,?> redisTemplate) {
    CacheManager cacheManager = new RedisCacheManager(redisTemplate);
    return cacheManager;
  }
  @Bean
  public RedisTemplate<String, String> redisTemplate(RedisConnectionFactory factory) {
    RedisTemplate<String, String> redisTemplate = new RedisTemplate<String, String>();
    redisTemplate.setConnectionFactory(factory);
    return redisTemplate;
  }
}

在service包中建立一個(gè)RedisService.java類。

public interface RedisService {
  public void set(String key, Object value); 
  public Object get(String key); 
}

新建一個(gè)service實(shí)現(xiàn)類RedisServiceImpl.java。

@Service
public class RedisServiceImpl implements RedisService {
  @Resource
  private RedisTemplate<String,Object> redisTemplate;
  public void set(String key, Object value) {
    ValueOperations<String,Object> vo = redisTemplate.opsForValue();
     vo.set(key, value);
  }
  public Object get(String key) {
    ValueOperations<String,Object> 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獲取某個(gè)用戶
  @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<User> 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";
  }
}

本文設(shè)計(jì)的實(shí)體類User.java的代碼如下,需要把對(duì)象存放在redis需要將對(duì)象序列化。

@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<Photo> setPhoto;
  //省略getter和setter
  @Override
  public String toString() {
    return "User [id=" + id + ", username=" + username + ", password="
        + password + ", dictum=" + dictum + ", setPhoto=" + setPhoto
        + "]";
  }
}

總結(jié)

以上所述是小編給大家介紹的SpringBoot 整合Redis 數(shù)據(jù)庫(kù)的方法,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)億速云網(wǎng)站的支持!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI