目录

  1. Redis 特性
  2. 使用场景
  3. 初次使用
    安装(Linux)
    配置
    启动 redis 的 3 种方法
    使用 redis 客户端
    关闭 redis 服务
  4. Redis 版本说明
  5. 引用

1 Redis 特性

  1. 速度快(基于内存,C 语言,单线程)
  2. 基于 key value 键值对的数据结构服务器。全称 Remote Dictionary Server。包含 String,Hash, List, Set, SotrSet. 同时在字符串的基础上演变出位图(BitMaps) 和 HyperLogLog 两种数据数据结构。3.2 版本中加入 GEO(地理信息位置)。
  3. 丰富的功能。例如:键过期(缓存),发布订阅(消息队列), Lua 脚本(自己实现 Redis 命令),事务,流水线(Pipeline 减少网络开销)。
  4. 简单稳定。
  5. 客户端语言多。
  6. 持久化(RDB,AOF)。
  7. 主从复制(分布式的基础)。
  8. 高可用(Sentinel)和分布式(Cluster)。

2 使用场景

  1. 缓存

    合理的使用缓存能够明显加快访问的速度,同时降低数据源的压力。这也是 Redis 最常用的功能。Redis 提供了键值过期时间(EXPIRE key seconds)设置,并且也提供了灵活控制最大内存和内存溢出后的淘汰策略。

  2. 排行榜

    每个网站都有自己的排行榜,例如按照热度排名的排行榜,发布时间的排行榜,答题排行榜等等。Redis 提供了列表(List)和有序集合(sorted set)数据结构,合理的使用这些数据结构可以很方便的构建各种排行榜系统。

  3. 计数器

    计数器在网站应用中非常重要,例如,点赞数加一,浏览数加一,还有常用的限流操作,限制每个用户每秒访问系统的次数等等,Redis 支持计数功能(INCR key)而且计数的性能也非常好,计数的同时也可以设置超时时间,这样就可以实现限流。

  4. 社交网络

    赞/踩,粉丝,共同好友/喜好,推送,下拉刷新等是社交网站必备的功能,由于社交网站访问量通常比较大,而且传统的数据库不太适合保存这类数据,Redis 提供的数据结构可以相对比较容易实现这些功能。链接:Redis实战:如何构建类微博的亿级社交平台

  5. 消息队列

    Redis 提供的发布订阅(PUB/SUB) 和阻塞队列(blpop key1...keyN timeout )的功能,虽然和专业的消息队列比,还不够强大,但对于一般的消息队列功能基本满足。

3 初次使用

  1. 安装(Linux)
    Centos yum install redis
  2. 配置
    安装完成之后,会在 /usr/local/bin 目录目录下,多出几个可执行文件,称之为 redis shell。如下:
可执行文件 作用
redis-server 启动 redis 服务
redis-cli redis 命令行客户端
redis-benchmark redis 基准测试工具
redis-check-aof redis AOF 持久化文件检测和修复工具
redis-check-dump redis RDB 持久化文件检测和修复工具
redis-sentinel 启动 redis sentinel
  1. 启动 redis 的 3 种方法
    3.1 配置文件启动
    将配置写到配置文件中,例如写到 /opt/redis/redis.conf 中,执行 redis-server /opt/redis/redis.conf 即可启动 redis。redis 有 60 多个配置,常用的是:port(端口),logfile(日志文件),dir(redis 工作目录,存放持久化文件和日志文件),daemonize(是否以守护进程的方式启动 redis)。
    3.2 运行启动
    在 redis-server 后面加入参数,格式为:redis-server --configkey1 configvaue1 --configkey2 configvalue2. 例如:redis-server --port 6380 ,即,将端口自定义为 6380.
    3.3 默认启动
    直接 redis-server,默认端口 6379.

如果是生产环境的话,通常建议使用配置文件的方式启动。

  1. 使用 redis 客户端
    redis 客户端可以通过设置 ip 端口,连接 redis 服务器并执行命令。而使用redis-cli 的方式有 2 种。
    4.1 交互式方式
    通过 redis cli -h [host] -p [port] 的方式连接到 reids 服务。
    4.2 命令式方式
    通过 redis-cli -h [host] -p [port] [command] 就可以,是一次性的。

注意:如果不指定 host,port ,默认连接 127.0.0.1:6379.

  1. 关闭 redis 服务
    redis 提供了 shutDown 命令来停止 redis 服务,例如停掉127.0.0.1:6379 服务,使用:redis-cli shutdown 即可。

注意点:

  1. redis 关闭的过程:断开和客户端的连接,持久化文件生成。相对而言比较优雅。
  2. 不用使用 kill -9,过于粗暴,不但不会做持久化操作,还会造成缓冲区等资源不会优雅关闭。极端情况下造成 AOF 和复制丢失数据的情况。
  3. shutdown 还有一个参数,代表是否在关闭 redis 前,生成持久化文件:
    redis-cli shutdown nosave|save

4 Redis 版本说明

redis 借鉴了 Linux 对于版本号的命名规则,版本号第二位如果是奇数,则为非稳定版本,如果是偶数,则为稳定版本。当前奇数版本就是下一个稳定版本的开发版本。

重大版本:2.8 提升了 sentinel 的可用性,使其可在生产环境使用;3.0 版本最大的功能:添加了分布式 Redis Cluster,填补了官方没有分布式实现的空白(之前都是用户自己实现的 sharding)。

5 引用

《Redis 开发与运维》

Redis 初次见面的更多相关文章

  1. 使用redis构建可靠分布式锁

    关于分布式锁的概念,具体实现方式,直接参阅下面两个帖子,这里就不多介绍了. 分布式锁的多种实现方式 分布式锁总结 对于分布式锁的几种实现方式的优劣,这里再列举下 1. 数据库实现方式 优点:易理解 缺 ...

  2. Ignite性能测试以及对redis的对比

    测试方法 为了对Ignite做一个基本了解,做了一个性能测试,测试方法也比较简单主要是针对client模式,因为这种方法和使用redis的方式特别像.测试方法很简单主要是下面几点: 不作参数优化,默认 ...

  3. mac osx 安装redis扩展

    1 php -v查看php版本 2 brew search php|grep redis 搜索对应的redis   ps:如果没有brew 就根据http://brew.sh安装 3 brew ins ...

  4. Redis/HBase/Tair比较

    KV系统对比表 对比维度 Redis Redis Cluster Medis Hbase Tair 访问模式    支持Value大小 理论上不超过1GB(建议不超过1MB) 理论上可配置(默认配置1 ...

  5. Redis数据库

    Redis是k-v型数据库的典范,设计思想及数据结构实现都值得学习. 1.数据类型 value支持五种数据类型:1.字符串(strings)2.字符串列表(lists)3.字符串集合(sets)4.有 ...

  6. redis 学习笔记(2)

    redis-cluster 简介 redis-cluster是一个分布式.容错的redis实现,redis-cluster通过将各个单独的redis实例通过特定的协议连接到一起实现了分布式.集群化的目 ...

  7. redis 学习笔记(1)

    redis持久化 snapshot数据快照(rdb) 这是一种定时将redis内存中的数据写入磁盘文件的一种方案,这样保留这一时刻redis中的数据镜像,用于意外回滚.redis的snapshot的格 ...

  8. python+uwsgi导致redis无法长链接引起性能下降问题记录

    今天在部署python代码到预生产环境时,web站老是出现redis链接未初始化,无法连接到服务的提示,比对了一下开发环境与测试环境代码,完全一致,然后就是查看各种日志,排查了半天也没有查明是什么原因 ...

  9. nginx+iis+redis+Task.MainForm构建分布式架构 之 (redis存储分布式共享的session及共享session运作流程)

    本次要分享的是利用windows+nginx+iis+redis+Task.MainForm组建分布式架构,上一篇分享文章制作是在windows上使用的nginx,一般正式发布的时候是在linux来配 ...

随机推荐

  1. spring InitializingBean和DisposableBean init-method 和destroy-method @PostConstruct @PreDestroy

    对于初始化函数: @PostConstruct 注解的方法 InitializingBean接口定义的回调afterPropertiesSet() Bean配置中自定义的初始化函数 对于析构则与上相同 ...

  2. java基础0615

    1. 1)2)   1)输出:Base  2)编译成功,但没有输出. 2. 编译成功,但没有输出. 3. 只有12行的话,不会新建文件.需要create~~ 4. public static void ...

  3. 在使用可变数组过程中遇到*** Terminating app due to uncaught exception 'NSInternalInconsistencyException', reason: '-[__NSCFDictionary setObject:forKey:]: mutating method sent to immutable object'问题

    *** Terminating app due to uncaught exception 'NSInternalInconsistencyException', reason: '-[__NSCFD ...

  4. 包建强的培训课程(6):Android App瘦身优化

    v\:* {behavior:url(#default#VML);} o\:* {behavior:url(#default#VML);} w\:* {behavior:url(#default#VM ...

  5. 网络编程懒人入门(八):手把手教你写基于TCP的Socket长连接

    本文原作者:“水晶虾饺”,原文由“玉刚说”写作平台提供写作赞助,原文版权归“玉刚说”微信公众号所有,即时通讯网收录时有改动. 1.引言 好多小白初次接触即时通讯(比如:IM或者消息推送应用)时,总是不 ...

  6. 第70节:Java中xml和tomcat

    第70节:Java中xml和tomcat 前言: 哭着也要看完,字数: jdbc crud - statement dao java.sql.Driver The interface that eve ...

  7. Kali学习笔记32:Maltego、Exiftool

    有段时间没学Kali里面的工具了 以前做信息收集的时候呢,忘记了两个很强大的工具:Maltego.Exiftool 先来看看Maltego: 这个工具不仅可以方便地收集DNS信息等等,强大地地方还在于 ...

  8. idea src下源文件和class编译文件不一致

    今天遇到一个神奇BUG,一个和elasticsearch没有任何关系的项目,报错ES某个包找不到,刚开始以为是依赖了父项目的某个包,并且本项目主启动类ComponentScan扫描了相关的类进入Spr ...

  9. ubuntu下opencv的版本切换及遇到的问题解决

    默认使用opencv 3.2的时候,使用SVM的时候,系统报错如下: error: ‘class MySVM’ has no member named ‘decision_func’ 解决方法:要把系 ...

  10. 如何在 Linux 中查看可用的网络接口

    在我们安装完一个 Linux 系统后最为常见的任务便是网络配置了.当然,你可以在安装系统时进行网络接口的配置.但是,对于某些人来说,他们更偏爱在安装完系统后再进行网络的配置或者更改现存的设置.众所周知 ...