Linux下在docker下配置Redis
1.安装redis
1.启动docker
systemctl docker start
2.在远端查找Redis资源
docker search redis
3.拉取redis资源
docker pull docker.io/redis
4.查询docker下载的镜像
docker image ls
5.运行并创建redis容器
docker run -itd --name redis -p 6379:6379 docker.io/redis
6.执行docker中的redis容器
docker exec -it redis /bin/bash
7.启动redis客户端
redis-cli
8.测试redis是否成功启动
ping
9.都说redis跑的快,不服跑个分,在容器外面直接运行
redis-benchmark -n 10000 -q
2.常用redis类型
1.string型
redis常用String型命令
2.hash类型
redis常用hash型命令
3.list类型
redis常用list型命令
4.set类型
redis常用set型命令
5.sorted set类型
redis常用sorted set型命令
3.SpringBoot整合redis
1.引入依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
<!-- 需要保持当前redis版本和SpringBoot start 版本一致 -->
2.编写配置类
package com.xuexuehai.carrecommand.config;
import com.fasterxml.jackson.databind.ser.std.StringSerializer;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.connection.RedisConnectionFactory;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.serializer.Jackson2JsonRedisSerializer;
import org.springframework.data.redis.serializer.RedisSerializer;
import org.springframework.data.redis.serializer.StringRedisSerializer;
/**
* @author xuexuehai
* @mailBox xuehai.xue@QQ.com
* @date 2021/8/20 2:34 下午
*/
@Configuration
public class RedisConfig {
@Autowired
private RedisConnectionFactory redisConnectionFactory;
/**
* 解决中文属性的问题
*/
@Bean
public RedisTemplate<String,Object> redisTemplate(){
RedisTemplate<String,Object> redisTemplate = new RedisTemplate<>();
redisTemplate.setConnectionFactory(redisConnectionFactory);
Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);
StringRedisSerializer stringRedisSerializer = new StringRedisSerializer();
redisTemplate.setKeySerializer(stringRedisSerializer);
redisTemplate.setValueSerializer(jackson2JsonRedisSerializer);
redisTemplate.setEnableDefaultSerializer(true);
redisTemplate.setDefaultSerializer(jackson2JsonRedisSerializer);
return redisTemplate;
}
}
3.redis在代码中的使用
1.使用配置类创建的RedisTemplate,注入到需要使用的地方,通过对象.opsValues()
下面的set()、get()等方法操作缓存中的key和value
@Autowired
private RedisTemplate<String, Object> redisTemplate;
@GetMapping("/login")
@ApiOperation("用户登录")
public HttpResp login(String username, String password) {
//使用UserService中的login方法登录用户并且获取用户权限
List<Privs> privs = ius.login(username, password);
//在缓存中添加用户的权限,使用用户的登录名称作为redis缓存的key,将权限保存在key的value中
redisTemplate.opsForValue().set(username, privs);
//给前端返回登录结果
return new HttpResp(SysStatusEnums.LOGIN_SUCCESS.getCode(),
SysStatusEnums.LOGIN_SUCCESS.getMsg(),
username, null);
}