redis初识

redis典型应用场景

1. 缓存系统

image.png

2. 计数器

image.png

3. 消息队列系统

image.png

4.排行榜

image.png

5.社交网络

image.png

6.实时系统

image.png

Redis Api的使用和理解

通用命令

  1. keys * 列出所有键值,keys后面跟的是通配符
  2. dbsize 键的个数
  3. exists key 检查key是否存在
  4. del key 删除key
  5. expire key seconds // key在seconds秒后过期
  6. ttl key // 查询key的过期时间
  7. persist key // 去掉key的过期时间
  8. type key // 返回key的类型

单线程

redis在一个瞬间只能执行一条命令。
单线程为什么这么快?

  1. 纯内存
  2. 非阻塞IO
  3. 避免线程切换和竞态消耗

字符串类型

使用场景:缓存、计数器、分布式锁...
相关涉及命令:get key,set key value,del key
由于redis内部会把整型自动转换为字符串类型,即整型也被看做字符串类型,下面是整型的相关api:
incr key // key自增1,若key不存在,自增后get(key)=1
decr key // key自减1
incrby key k // key自增k
decrby key k // key自减k

set,setnx,setxx三种的区别:
set key value // 不管key是否存在都设置
setnx key value // key不存在才进行设置
set key value xx // key存在才进行设置

mget,mset的区别:
mget key1 key2 key3 //批量获取key,原子操作,实现图如下:


image.png

从图中可以得知一次mget请求获取多个参数的时候是比较高效的。

getset,append,strlen三个命令的区别:
getset key newvalue // set key newvalue并返回旧的value
append key value // 将value追加到旧的value
strlen key // 返回字符串的长度,UTF-8中一个中文占两个字节

incrbyfloat,getrange,setrange三个命令的区别:
incrbyfloat key 3.5 //增加key对应的值为3.5
getrange key start end //获取字符串指定下标所有的值
setrange key index value // 设置指定下标所有对应的值

字符串总结


image.png

哈希类型

哈希键值结构如下:


image.png

hget,hset,hdel:
hget key field // 获取hash key对应的field的value
hset key field // 设置hash key对应的field的value
hdel key field // 删除hash key对应的field的value

hexists,hlen:
hexists key field // 判断hash key是否有field
hlen key // 获取hash key field的数量

hmget,hmset:
hmget key field1 field2 ... fieldN // 批量获取hash key的一批field对应的值
hmset key field1 value1 field2 value2... fileldN valueN //批量设置hasn key的一批field value

hgetall,hvals,hkeys:
hgetall key // 返回hash key对应所有的field和value
hvals key // 返回hash key对应所有的field的value
hkeys key // 返回hash key对应所有field
hsetnx key field value // 设置hash key对应field的value,如果field已经存在,则失败
hincrby key field intCounter // hash key对应的field的value自增intCounter
hincrbyfloat key field floatCounter // hincrby浮点数版

list类型

rpush key value1 value2 ... valueN //从列表右端插入值(1-N)
lpush key value1 value2 ... valueN //从列表左端插入值(1-N)
insert key before|after value newValue // 在list指定的值前后插入newValue
lpop key // 从列表左侧弹出一个item
rpop key // 从列表右侧弹出一个item
lrem key count value // 根据count的值,从列表中删除所有value相等的项。如果count大于0,从左到右,删除最多count个value相等的项;如果count小于0,从右到左,删除最多math.abs(count)个value相等的项;如果count=0,删除所有value相等的项。
ltrim key start end // 按照索引范围修剪列表
lrange key start end //包含end,获取列表指定索引范围内所有item
index key index // 获取列表指定索引的item
llen key // 获取列表长度
lset key index newValue // 设置列表指定索引值为newValue

慢查询

redis客户端访问的流程如下图所示,慢查询发生在第三步。


屏幕快照 2018-05-30 下午9.06.38.png

由上图可知,客户端查询超时并不一定是慢查询导致的。上述1到4步每一步都有可能导致客户端查询超时。

pipeline(流水线)

对于批量对redis执行get,set操作,为提高效率可以使用mget,mset命令。但是如果想批量执行hset,hget等操作哈希类型的命令,则没有对应的批量操作的方法(hmset命令是针对同一个key进行的批量操作,实际要求是对不同的key和value进行批量操作,此时只能使用pipeline来做),为此提出了流水线命令。批量将请求打包后发送,并将执行结果打包一次返回。


屏幕快照 2018-05-28 下午1.32.40.png

通过jedis来使用pipeline示例代码如下:


屏幕快照 2018-05-28 下午1.44.43.png

redis安装

image.png

redis可执行文件说明

image.png

image.png

下面是一个具体的例子,通过第三方应用的api来获取天气数据:
首先我们在项目的pom.xml文件中添加必要的依赖:

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

首先编写配置类RestConfiguration.java

package com.yun.hello.config;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.web.client.RestTemplateBuilder;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.client.RestTemplate;

@Configuration
public class RestConfiguration {

    @Autowired
    private RestTemplateBuilder restTemplateBuilder;

    @Bean
    public RestTemplate restTemplate(){
        return restTemplateBuilder.build();
    }
}

接下来我们实现请求天气数据api并且将返回值保存到redis中,在下面的例子中我们使用注入的restTemplate对象来发起restful 请求,使用StringRedisTemplate对象把获取的天气数据保存到redis缓存中。

package com.yun.hello.service.weather;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.StringRedisTemplate;
import org.springframework.data.redis.core.ValueOperations;
import org.springframework.http.ResponseEntity;
import org.springframework.stereotype.Service;
import org.springframework.web.client.RestTemplate;

import java.util.concurrent.TimeUnit;

@Service
public class WeatherDataCollectionServiceImpl implements WeatherDataCollectionService {

    private static String WEATHER_URI="http://wthrcdn.etouch.cn/weather_mini?";
    private static final Long TIME_OUT = 1800L;//30 minutes

    @Autowired
    private RestTemplate restTemplate;

    @Autowired
    private StringRedisTemplate stringRedisTemplate;

    @Override
    public void syncDataByCityId(String cityId) {
        String uri = WEATHER_URI +"citykey="+ cityId;

        this.saveWeatherData(uri);
    }

    private void saveWeatherData(String uri) {
        String key = uri;
        String resBody= null;

        ResponseEntity<String> responseEntity = restTemplate.getForEntity(uri,String.class);
        if(responseEntity.getStatusCodeValue() == 200){
            resBody = responseEntity.getBody();
        }

        ValueOperations<String, String> ops = stringRedisTemplate.opsForValue();
        // 数据写入缓存
        ops.set(key,resBody,TIME_OUT, TimeUnit.SECONDS);
    }

}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,186评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,858评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,620评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,888评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,009评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,149评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,204评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,956评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,385评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,698评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,863评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,544评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,185评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,899评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,141评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,684评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,750评论 2 351

推荐阅读更多精彩内容