目录

  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. 底图与蒙版的过渡效果transition

    我用2种方法写了底图与蒙版的过渡效果 方法一:用js方法 <!DOCTYPE html> <html> <head> <meta http-equiv=&qu ...

  2. 乘法器的Verilog HDL实现(转载)

    原文地址:http://www.cnblogs.com/shengansong/archive/2011/05/23/2054401.html 1. 串行乘法器 两个N位二进制数x.y的乘积用简单的方 ...

  3. openvpn搭建和使用

    一.openvpn原理 openvpn通过使用公开密钥(非对称密钥,加密解密使用不同的key,一个称为Publice key,另外一个是Private key)对数据进行加密的.这种方式称为TLS加密 ...

  4. JS中创建多个相同的变量出现的问题

    在做轮播图的时候出现了一个问题:如果定义两个完全相同的变量会发生什么: 1.两个全局变量: var num = 10; var num =100; 这种情况下很明显输出num的话会是100,但是内存中 ...

  5. delphi压缩与解压_不需要特别的控件

    unit unzip; interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms ...

  6. wechat.php

    <?php/***Author @zhongbo * 步骤说明* 1,微信服务器返回一个会话ID* 2.通过会话ID获得二维码* 3.轮询手机端是否已经扫描二维码并确认在Web端登录* 4.访问 ...

  7. 最容易理解的对卷积(convolution)的解释

    啰嗦开场白 读本科期间,信号与系统里面经常讲到卷积(convolution),自动控制原理里面也会经常有提到卷积.硕士期间又学了线性系统理论与数字信号处理,里面也是各种大把大把卷积的概念.至于最近大火 ...

  8. MySQL优化技巧

    目录 MySQL的特点 数据类型优化 整型类型 小数类型 字符串类型 时间类型 主键类型的选择 特殊类型的数据 索引优化 一个使用Hash值创建索引的技巧 前缀索引 多列索引 聚簇索引 覆盖索引 重复 ...

  9. ElasticSearch写入数据的工作原理是什么?

    面试题 es 写入数据的工作原理是什么啊?es 查询数据的工作原理是什么啊?底层的 lucene 介绍一下呗?倒排索引了解吗? 面试官心理分析 问这个,其实面试官就是要看看你了解不了解 es 的一些基 ...

  10. 面试官问我,使用Dubbo有没有遇到一些坑?我笑了。

    前言 17年的时候,因为一时冲动没把持住(当然最近也有粉丝叫我再冲动一把再更新一波),结合面试题写了一个系列的Dubbo源码解析.目前公众号大部分粉丝都是之前的粉丝,这里不过多介绍. 根据我的面试经验 ...