SpringBoot --- 使用 docker 安装使用 Redis 缓存 存储数据

Redis 数据都是缓存在计算机内存中,会周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,实现数据的持久化。

docker 方式安装 Redis

1. 启动docker:

systemctl start docker

2. 安装 redis (安装并启动一套完成)

docker run -id --name myredis(自定义名称) -p 6379:6379 redis

如果你的 docker 上没有安装过 redis , 则 docker 会自动帮你在仓库上拉取 redis 镜像 , 此过程需要等待下载完成

注意 ! ! !

会出现下载镜像速度太慢 , 拉半天拉不下来 , 可以配置成阿里云镜像仓库 , 直接百度阿里云官网 , 登录上去 , 找到镜像加速器地址 :

1. 修改 daemon配置文件来使用加速器 :

vi /etc/docker/daemon.json

2. 在配置文件中加入加速器地址 :

{"registry-mirrors": ["https://kwe1le51.mirror.aliyuncs.com"]}

3. 保存后,输入

systemctl daemon-reload

4. 重新启动 docker

systemctl restart docker

以上就是切换了 docker 的下载镜像地址 ( 使用阿里镜像 ) 之后 pull 的速度就会很快了

使用 docker ps 命令查看 redis(容器)是否启动

如果显示没有启动或者历史已经存在过该容器 , 且没有删除 , 我们直接重新启动一下该容器就可以了

命令 : docker restart 容器ID 或者 容器名

也可以使用 Redis Desktop Manager (Redis可视化工具) 查看 redis 的连接状态

 docker 成功安装了 redis之后的操作

1. 后端服务pom中添加 redis 依赖

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

<!-- spring2.X集成redis所需common-pool2-->
<dependency>
     <groupId>org.apache.commons</groupId>
     <artifactId>commons-pool2</artifactId>
     <version>2.6.0</version>
</dependency>

2. 添加 redis 配置类

@Configuration
@EnableCaching
public class RedisConfig {

    /**
     * 设置RedisTemplate规则
     * @param redisConnectionFactory
     * @return
     */
    @Bean
    public RedisTemplate<Object, Object> redisTemplate(RedisConnectionFactory redisConnectionFactory) {
        RedisTemplate<Object, Object> redisTemplate = new RedisTemplate<>();
        redisTemplate.setConnectionFactory(redisConnectionFactory);
        Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);

//解决查询缓存转换异常的问题
        ObjectMapper om = new ObjectMapper();
// 指定要序列化的域,field,get和set,以及修饰符范围,ANY是都有包括private和public
        om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
// 指定序列化输入的类型,类必须是非final修饰的,final修饰的类,比如String,Integer等会跑出异常
        om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
        jackson2JsonRedisSerializer.setObjectMapper(om);

//序列号key value
        redisTemplate.setKeySerializer(new StringRedisSerializer());
        redisTemplate.setValueSerializer(jackson2JsonRedisSerializer);
        redisTemplate.setHashKeySerializer(new StringRedisSerializer());
        redisTemplate.setHashValueSerializer(jackson2JsonRedisSerializer);

        redisTemplate.afterPropertiesSet();
        return redisTemplate;
    }

    /**
     * 设置CacheManager缓存规则
     * @param factory
     * @return
     */
    @Bean
    public CacheManager cacheManager(RedisConnectionFactory factory) {
        RedisSerializer<String> redisSerializer = new StringRedisSerializer();
        Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);

//解决查询缓存转换异常的问题
        ObjectMapper om = new ObjectMapper();
        om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
        om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
        jackson2JsonRedisSerializer.setObjectMapper(om);

// 配置序列化(解决乱码的问题),过期时间600秒
        RedisCacheConfiguration config = RedisCacheConfiguration.defaultCacheConfig()
                .entryTtl(Duration.ofSeconds(600))
                .serializeKeysWith(RedisSerializationContext.SerializationPair.fromSerializer(redisSerializer))
                .serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(jackson2JsonRedisSerializer))
                .disableCachingNullValues();

        RedisCacheManager cacheManager = RedisCacheManager.builder(factory)
                .cacheDefaults(config)
                .build();
        return cacheManager;
    }
}

3. 你要使用的某后端服务中添加 redis 配置 ( application.properties 或者 yml 文件 )

spring.redis.host=192.168.xxx.xxx  # 你自己的redis宿主机ip
spring.redis.port=6379   # redis端口号
spring.redis.database= 0
spring.redis.timeout=1800000

4. 运行测试类

@SpringBootTest
public class test111 {
    @Autowired
    RedisTemplate redisTemplate;

    @Test
    public void test1(){
        redisTemplate.opsForValue().set("username", "卡卡罗特");
    }
}

最后 , 成功将数据存入Redis 缓存中 

可以通过可视化工具查看

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
回答: Docker是一个开源的容器化平台,可以帮助开发者将应用程序及其依赖项打包成一个独立的容器,以便在不同的环境中进行部署和运行。Spring Boot是一个用于创建独立的、生产级别的Spring应用程序的框架。Redis是一个开源的内存数据存储系统,常用于缓存、消息队列和数据存储等场景。 在使用Docker搭建Spring BootRedis集群的过程中,可以按照以下步骤进行操作: 1. 使用Docker创建一个基于默认网段172.17.0.0/16的Redis集群,包括6个Redis节点和一个集群调度节点。可以使用以下指令创建节点: - docker run -d -p 7001:6379 --name r1 redis-cluster - docker run -d -p 7002:6379 --name r2 redis-cluster - docker run -d -p 7003:6379 --name r3 redis-cluster - docker run -d -p 7004:6379 --name r4 redis-cluster - docker run -d -p 7005:6379 --name r5 redis-cluster - docker run -d -p 7006:6379 --name r6 redis-cluster - docker run --name ruby2 -i -d ruby-redis 2. 进入ruby2容器的shell界面中,执行以下指令安装Redis的Ruby插件: - docker exec -it ruby2 /bin/bash - gem install redis --version 3.0.7 3. 为了让Spring Boot能够有效连接到Redis集群,需要给Redis集群设置密码。可以使用以下指令进入6个节点,并设置密码: - docker exec -it r1 /bin/bash - docker exec -it r2 /bin/bash - docker exec -it r3 /bin/bash - docker exec -it r4 /bin/bash - docker exec -it r5 /bin/bash - docker exec -it r6 /bin/bash 请注意,本节的目的是为了快速搭建一个Redis数据库,以方便学习使用和后续内容的学习。如果您想深入学习Docker,建议您参考其他相关课程。\[3\] #### 引用[.reference_title] - *1* *2* [springboot连接基于docker搭建的redis集群](https://blog.csdn.net/xielinrui123/article/details/85178874)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [[springboot]使用docker安装redis实验环境](https://blog.csdn.net/hanxiaotongtong/article/details/122893288)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值