目录

Redis缓存

使用缓存Redis解决首页并发问题

1、缓存使用的简单设计

2、Redis的整合步骤

A 将Redis整合到项目中(Redis+Spring)

B 设计一个数据存储策越

3、Redis的整合过程

1、引入pom依赖信息(将本工程所有的Redis统一放入service-util里)

2、写一个Redis的工具类(用来将Redis的池初始化到spring容器)

3、写一个spring整合Redis的配置类

4、每隔引用工程引入service-util后,单独配置只能的redis的配置文件

代码

查询结果

查看Redis数据库的数据


Redis缓存

重点要讲的是另外一个层面:尽量避免直接查询数据库。

解决办法就是:缓存

缓存可以理解是数据库的一道保护伞,任何请求只要能在缓存中命中,都不会直接访问数据库。而缓存的处理性能是数据库10-100倍。

使用缓存Redis解决首页并发问题

  1. 用户第一次请求到redis
  2. 如果redis没有数据,redis会请求mysql
  3. mysql会把数据返回给用户,同时会传到redis上
  4. 第二次用户访问时,redis有数据,就不需要访问mysql。节省时间,降低消耗

1、缓存使用的简单设计

  1. 连接缓存
  2. 查询缓存
  3. 如果缓存没有,查询mysql
  4. mysql查询结果存入redis

2、Redis的整合步骤

A 将Redis整合到项目中(Redis+Spring)

B 设计一个数据存储策越

企业中的存储策越(核心是:如何设计k)

数据对象名:数据对象id:对象属性

User:123:password 用户ID为123的密码

User:123:userename 用户ID为123的名字

3、Redis的整合过程

1、引入pom依赖信息(将本工程所有的Redis统一放入service-util里)

<dependency>
<groupId>redis.clients</groupId>
<artifactId>jedis</artifactId>
</dependency>

创建两个类RedisConfig和RedisUtil

RedisConfig负责在spring容器启动时自动注入,而RedisUtil就是被注入的工具类以供其他模块调用。

2、写一个Redis的工具类(用来将Redis的池初始化到spring容器)

RedisUtil

public class RedisUtil {

    private  JedisPool jedisPool;

    public void initPool(String host,int port ,int database){
JedisPoolConfig poolConfig = new JedisPoolConfig();
poolConfig.setMaxTotal(200);
poolConfig.setMaxIdle(30);
poolConfig.setBlockWhenExhausted(true);
poolConfig.setMaxWaitMillis(10*1000);
poolConfig.setTestOnBorrow(true);
jedisPool=new JedisPool(poolConfig,host,port,20*1000);
} public Jedis getJedis(){
Jedis jedis = jedisPool.getResource();
return jedis;
} }

3、写一个spring整合Redis的配置类

将Redis的链接池创建到spring的容器中

RedisConfig

@Configuration
public class RedisConfig { //读取配置文件中的redis的ip地址
@Value("${spring.redis.host:disabled}")
private String host; @Value("${spring.redis.port:0}")
private int port; @Value("${spring.redis.database:0}")
private int database; @Bean
public RedisUtil getRedisUtil(){
if(host.equals("disabled")){
return null;
}
RedisUtil redisUtil=new RedisUtil();
redisUtil.initPool(host,port,database);
return redisUtil;
} }

4、每隔引用工程引入service-util后,单独配置只能的redis的配置文件

Service-util的配置文件没有作用

同时,任何模块想要调用redis都必须在application.properties配置,否则不会进行注入

#Redis配置
//读取配置文件中的redis的ip地址
spring.redis.host=192.168.1.111
#Redis端口号
spring.redis.port=6379
#数据库
spring.redis.database=0

代码

这是从数据库调用mysql,查询数据

 /**
* 从数据库调用
*
* @param skuId
* @return
*/
public PmsSkuInfo getSkuByIdFromDb(String skuId) {
//sku的商品对象
PmsSkuInfo pmsSkuInfo = new PmsSkuInfo();
pmsSkuInfo.setId(skuId);
PmsSkuInfo skuInfo = pmsSkuInfoMapper.selectOne(pmsSkuInfo); try {
//sku的图片集合
PmsSkuImage pmsSkuImage = new PmsSkuImage();
List<PmsSkuImage> pmsSkuImages = pmsSkuImageMapper.select(pmsSkuImage);
skuInfo.setSkuImageList(pmsSkuImages);
} catch (Exception e) {
e.printStackTrace();
}
return skuInfo; }

这个是Redis的代码,判断redis中是否有数据,

如果没有,就调用上面的代码,查询mysql数据库。返回结果,在写入redis数据库中。

如果有,直接调用redis数据库中的数据。

/**
* 商品详细图
* 主要是item前端的东西,调用此处的服务,方便
* 使用Redis缓存,解决高并发
*
* @param skuId
* @return
*/
@Override
public PmsSkuInfo getSkuById(String skuId) { PmsSkuInfo pmsSkuInfo = new PmsSkuInfo(); //链接缓存
Jedis jedis = redisUtil.getJedis(); //查询缓存
String skuKey = "sky:" + skuId + ":info";
String skuJson = jedis.get("skuKey");
//可以吧json的字符串转换成jav的对象类
if (StringUtils.isNotBlank(skuJson)) {// if (skuJson!=null&&!skuJson.equals(""))
pmsSkuInfo = JSON.parseObject(skuJson, PmsSkuInfo.class);
} else {
//如果缓存没有,查询mysql
pmsSkuInfo = getSkuByIdFromDb(skuId); if (pmsSkuInfo != null) {
//mysql查询结果存入redis
jedis.set("sku" + skuId + ":info", JSON.toJSONString(pmsSkuInfo));
}
} jedis.close(); return pmsSkuInfo;
}

查询结果

查看Redis数据库的数据

Redis缓存实战教程的更多相关文章

  1. go语言实战教程:Redis实战项目应用

    项目Redis配置 在实战项目中使用Redis功能,首先需要进行Redis配置.本实战项目中,关与Redis的配置项包含:连接类型.地址.端口.公共前缀.以上配置项被定义包含在Iris框架的redis ...

  2. SpringBoot微服务电商项目开发实战 --- Redis缓存雪崩、缓存穿透、缓存击穿防范

    最近已经推出了好几篇SpringBoot+Dubbo+Redis+Kafka实现电商的文章,今天再次回到分布式微服务项目中来,在开始写今天的系列五文章之前,我先回顾下前面的内容. 系列(一):主要说了 ...

  3. .net使用CSRedis操作Redis缓存的简单笔记(新手教程)

    0.介绍 .NET Core or .NET Framework 4.0+ client for Redis and Redis Sentinel (2.8) and Cluster. Include ...

  4. Canal 实战 | 第一篇:SpringBoot 整合 Canal + RabbitMQ 实现监听 MySQL 数据库同步更新 Redis 缓存

    一. Canal 简介 canal [kə'næl],译意为水道/管道/沟渠,主要用途是基于 MySQL 数据库增量日志解析,提供增量数据订阅和消费 早期阿里巴巴因为杭州和美国双机房部署,存在跨机房同 ...

  5. Redis 缓存应用实战

    为了提高系统吞吐量,我们经常在业务架构中引入缓存层. 缓存通常使用 Redis / Memcached 等高性能内存缓存来实现, 本文以 Redis 为例讨论缓存应用中面临的一些问题. 缓存更新一致性 ...

  6. ASP.NET Core教程:ASP.NET Core中使用Redis缓存

    参考网址:https://www.cnblogs.com/dotnet261010/p/12033624.html 一.前言 我们这里以StackExchange.Redis为例,讲解如何在ASP.N ...

  7. spring boot 实战教程

    二八法则 - get more with less Java.spring经过多年的发展,各种技术纷繁芜杂,初学者往往不知道该从何下手.其实开发技术的世界也符合二八法则,80%的场景中只有20%的技术 ...

  8. Windows下Redis缓存服务器的使用 .NET StackExchange.Redis Redis Desktop Manager

    Redis缓存服务器是一款key/value数据库,读110000次/s,写81000次/s,因为是内存操作所以速度飞快,常见用法是存用户token.短信验证码等 官网显示Redis本身并没有Wind ...

  9. [个人翻译]Redis 集群教程(中)

    上一篇:http://www.cnblogs.com/li-peng/p/6143709.html 官方原文地址:https://redis.io/topics/cluster-tutorial  水 ...

随机推荐

  1. vue操作select获取option值

    如何实时的获取你选中的值 只用@change件事 @change="changeProduct($event)" 动态传递参数 vue操作select获取option的ID值 如果 ...

  2. SpringCloud学习笔记(九、SpringCloud Stream)

    目录: 什么是SpringCloud Stream 如何使用SpringCloud Stream 消息分流 什么是SpringCloud Stream: SpringCloud Stream是一个用于 ...

  3. Pwnable-bof

    Download : http://pwnable.kr/bin/bof Download : http://pwnable.kr/bin/bof.c 下载之后,先看看c源码 #include < ...

  4. Hive 读书札记

    把数据从一个关系型数据库直接导入 Hive,使用 Sqoop.

  5. centos7虚拟机端口命令

    cat /etc/redhat-release  #  查看centos 版本 Centos7端口常见命令 虚拟机新开了5005端口,系统内部是显示开了的,但是外部不能访问端口. 一些需要用到的命令: ...

  6. hdu6514 一维化 + 二维前缀和

    http://acm.hdu.edu.cn/showproblem.php?pid=6514 题意 给出一个大矩形(\(nm\leq10^7\)),有p个矩形覆盖,然后有q次询问,询问指定矩形内是否覆 ...

  7. 【2019.8.9 慈溪模拟赛 T1】数论(a)(打表找规律)

    莫比乌斯反演 血亏! 比赛时看到这题先写了个莫比乌斯反演,然后手造了几组数据和暴力对拍的时候发现,居然答案就是\(nm\)... 吐槽数据范围太小... 下面给上出题人对此题的解释: 原式的物理意义, ...

  8. webrtc笔记(5): 基于kurento media server的多人视频聊天示例

    这是kurento tutorial中的一个例子(groupCall),用于多人音视频通话,效果如下: 登录界面: 聊天界面: 运行方法: 1.本地用docker把kurento server跑起来 ...

  9. linux系统中启动daytime服务

    环境:vmware下面的cetos6 1. 进入/etc/xinetd.d/目录下,查看是否存在daytime服务,若不存在,则须安装: 执行命令:yum install xinetd 该命令执行后会 ...

  10. WEB测试应该注意哪些地方,怎样才能做好WEB测试

    基于Web的系统测试与传统的软件测试既有相同之处,也有不同的地方,对软件测试提出了新的挑战.基于Web的系统测试不但需要检查和验证是否按照设计的要求运行,而且还要评价系统在不同用户的浏览器端的显示是否 ...