前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >docker 安装redis 以及 spingboot redis的配置和使用

docker 安装redis 以及 spingboot redis的配置和使用

作者头像
周杰伦本人
发布2022-10-25 15:31:58
3790
发布2022-10-25 15:31:58
举报
文章被收录于专栏:同步文章

一 docker的redis安装

docker 安装很简单 一行命令:

代码语言:javascript
复制
docker run -p 6379:6379 --name redis -v /mydata/redis/data:/data -d redis:3.2 redis-server --appendonly yes

设置自启动

代码语言:javascript
复制
docker container update --restart=always redis

缓存的使用场景: 一些固定的数据,不太变化的数据,高频访问的数据(基本不变),变化频率低的都可以入缓存,加速系统的访问。 缓存的目的:提高系统查询效率,提供性能

二 springboot整合redis

1)、将菜单缓存起来,以后查询直接去缓存中拿即可;

设计模式:模板模式: 操作xxx都有对应的xxxTemplate; JdbcTemplate、RestTemplate、RedisTemplate、MongoTemplate

RedisTemplate<Object, Object>; k-v; v有五种类型、String、V StringRedisTemplate: k-v都是String的。

引入一个场景,猜这个场景的xxxAutoConfiguration, 帮我们注入能操作这个技术的组件,这个场景的配置信息都在xxxProperties中说明了(prefix = “spring.redis”)使用哪种前缀配置

2)、整合Redis两大步

1)、导入starter-data-redis

代码语言:javascript
复制
	<dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-data-redis</artifactId>
     </dependency>

2)、application.properties配置与 spring.redis相关的

代码语言:javascript
复制
spring.redis.database=0
spring.redis.host=192.168.217.130
spring.redis.port=6379

把对象转换为字节序列的过程称为对象的序列化。 把字节序列恢复为对象的过程称为对象的反序列化。 对象的序列化主要有两种用途: 1) 把对象的字节序列永久地保存到硬盘上,通常存放在一个文件中; 2) 在网络上传送对象的字节序列。

在很多应用中,需要对某些对象进行序列化,让它们离开内存空间,入住物理硬盘,以便长期保存。比如最常见的是Web服务器中的Session对象,当有 10万用户并发访问,就有可能出现10万个Session对象,内存可能吃不消,于是Web容器就会把一些seesion先序列化到硬盘中,等要用了,再把保存在硬盘中的对象还原到内存中。

当两个进程在进行远程通信时,彼此可以发送各种类型的数据。无论是何种类型的数据,都会以二进制序列的形式在网络上传送。发送方需要把这个Java对象转换为字节序列,才能在网络上传送;接收方则需要把字节序列再恢复为Java对象。

在这里插入图片描述
在这里插入图片描述

注意: RedisTemplate;存数据默认使用jdk的方式序列化存过去。 我们推荐都应该存成json; 做法: 将默认的序列化器改为json的

redis序列化:

在这里插入图片描述
在这里插入图片描述

redis自动配置源码:

在这里插入图片描述
在这里插入图片描述

重写这个:

代码语言:javascript
复制
import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean;
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.GenericJackson2JsonRedisSerializer;
import org.springframework.data.redis.serializer.RedisSerializer;

import java.net.UnknownHostException;

/**
 * 只需要自己创建出自己满意的序列化器放入容器中即可
 */
@Configuration
public class PmsRedisConfig {


    /**
     * jedis
     * @param redisConnectionFactory
     * @return
     * @throws UnknownHostException
     */
    @Bean("redisTemplate")
    public RedisTemplate<Object, Object> redisTemplate(
            RedisConnectionFactory redisConnectionFactory) throws UnknownHostException {
        RedisTemplate<Object, Object> template = new RedisTemplate<>();
        template.setConnectionFactory(redisConnectionFactory);
        //修改默认的序列化方式
        template.setDefaultSerializer(new GenericJackson2JsonRedisSerializer());
        return template;
    }
}

业务逻辑:

代码语言:javascript
复制
	@Autowired
    RedisTemplate<Object,Object> redisTemplate;

    @Override
    public List<PmsProductCategoryWithChildrenItem> listCategoryWithChildren(Integer i) {
        Object cacheMenu = redisTemplate.opsForValue().get(SysCacheConstant.CATEGORY_MENU_CACHE_KEY);
        List<PmsProductCategoryWithChildrenItem> items;
        if (cacheMenu!=null) {
            //缓存中有 直接从缓存中取
            log.info("菜单数据命中缓存。。");
            items = (List<PmsProductCategoryWithChildrenItem>) cacheMenu;
        }else {
            items = productCategoryMapper.listCategoryWithChildren(i);
            redisTemplate.opsForValue().set(SysCacheConstant.CATEGORY_MENU_CACHE_KEY,items);
        }
        return items;
    }

存储结果:

在这里插入图片描述
在这里插入图片描述

参考博客: https://www.cnblogs.com/xdp-gacl/p/3777987.html

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2019-12-24,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一 docker的redis安装
  • 二 springboot整合redis
    • 1)、将菜单缓存起来,以后查询直接去缓存中拿即可;
      • 2)、整合Redis两大步
      相关产品与服务
      云数据库 Redis
      腾讯云数据库 Redis(TencentDB for Redis)是腾讯云打造的兼容 Redis 协议的缓存和存储服务。丰富的数据结构能帮助您完成不同类型的业务场景开发。支持主从热备,提供自动容灾切换、数据备份、故障迁移、实例监控、在线扩容、数据回档等全套的数据库服务。
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档