您好,登錄后才能下訂單哦!
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ù)備份。
在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
然后,重新打開(kāi)一個(gè)Redis客戶端,使用以下的命令來(lái)連接Redis server。
src/redis-cli redis> set foo bar OK redis> get foo "bar"
整合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)站的支持!
免責(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)容。