`

Redis缓存介绍和使用

 
阅读更多
Redis缓存介绍和使用
参考:http://snowolf.iteye.com/blog/1630697


一、Redis介绍:
redis是一个key-value存储系统。和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)和zset(有序集合)。这些数据类型都支持push/pop、add/remove及取交集并集和差集及更丰富的操作,而且这些操作都是原子性的。在此基础上,redis支持各种不同方式的排序。与memcached一样,为了保证效率,数据都是缓存在内存中。区别的是redis会周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,并且在此基础上实现了master-slave(主从)同步。

Redis 是一个高性能的key-value数据库。 redis的出现,很大程度补偿了memcached这类key/value存储的不足,在部 分场合可以对关系数据库起到很好的补充作用。它提供了Python,Ruby,Erlang,PHP客户端,使用很方便。

二、安装Redis:
Redis的代码遵循ANSI-C编写,可以在所有POSIX系统(如Linux, *BSD, Mac OS X, Solaris等)上安装运行。而且Redis并不依赖任何非标准库,也没有编译参数必需添加。redis的安装出奇的简单,这可能也是他风靡的一个原因,让人很容易上手,不像某些东西,编译阶段就能让人完全绝望。
http://redis.googlecode.com/files/redis-2.4.6.tar.gz
1.安装:
Makefile文件,直接运行make命令即可。
make
make install

2.安装目录文件介绍:
Redis 由四个可执行文件:redis-benchmark、redis-cli、redis-server、redis-stat 这四个文件,加上一个redis.conf就构成了整个redis的最终可用包。它们的作用如下:
 •redis-server:Redis服务器的daemon启动程序
 •redis-cli:Redis命令行操作工具。当然,你也可以用telnet根据其纯文本协议来操作
 •redis-benchmark:Redis性能测试工具,测试Redis在你的系统及你的配置下的读写性能
 •redis-stat:Redis状态检测工具,可以检测Redis当前状态参数及延迟状况

3.启动redis:
启动redis了,redis只有一个启动参数,就是他的配置文件路径。
 
redis-server /etc/redis.conf
 
注意,默认复制过去的redis.conf文件的daemonize参数为no,所以redis不会在后台运行,这时要测试,我们需要重新开一个终端。修改为yes则为后台运行redis。另外配置文件中规定了pid文件,log文件和数据文件的地址,如果有需要先修改,默认log信息定向到stdout.
 
下面是redis.conf的主要配置参数的意义:
 •daemonize:是否以后台daemon方式运行
 •pidfile:pid文件位置
 •port:监听的端口号
 •timeout:请求超时时间
 •loglevel:log信息级别
 •logfile:log文件位置
 •databases:开启数据库的数量
 •save * *:保存快照的频率,第一个*表示多长时间,第三个*表示执行多少次写操作。在一定时间内执行一定数量的写操作时,自动保存快照。可设置多个条件。
 •rdbcompression:是否使用压缩
 •dbfilename:数据快照文件名(只是文件名,不包括目录)
 •dir:数据快照的保存目录(这个是目录)
 •appendonly:是否开启appendonlylog,开启的话每次写操作会记一条log,这会提高数据抗风险能力,但影响效率。
 •appendfsync:appendonlylog如何同步到磁盘(三个选项,分别是每次写都强制调用fsync、每秒启用一次fsync、不调用fsync等待系统自己同步)
 

redis.conf配置选项如下 
Daemonize是否以后台进程运行,默认为no 
pidfile如以后台进程运行,则需指定一个pid,默认为/var/run/redis.pid 
Bind绑定主机IP,默认值为127.0.0.1(注释) 
port监听端口,默认为6379 
Timeout超时时间,默认为300(秒) 
loglevel日志记录等级,有4个可选值,debug,verbose(默认值),notice,warning 
Logfile日志记录方式,默认值为stdout 
Databases可用数据库数,默认值为16,默认数据库为0 
save <seconds> <changes>指出在多长时间内,有多少次更新操作,就将数据同步到数据文件。这个可以多个条件配合,比如默认配置文件中的设置,就设置了三个条件。 
save 900 1 900秒(15分钟)内至少有1个key被改变 
save 300 10 300秒(5分钟)内至少有300个key被改变 
save 60 10000 60秒内至少有10000个key被改变 
Rdbcompression存储至本地数据库时是否压缩数据,默认为yes 
Dbfilename本地数据库文件名,默认值为dump.rdb 
Dir本地数据库存放路径,默认值为./ 
slaveof <masterip> <masterport>当本机为从服务时,设置主服务的IP及端口(注释) 
masterauth <master-password>当本机为从服务时,设置主服务的连接密码(注释) 
requirepass连接密码(注释) 
maxclients最大客户端连接数,默认不限制(注释) 
maxmemory <bytes>设置最大内存,达到最大内存设置后,Redis会先尝试清除已到期或即将到期的Key,当此方法处理后,任到达最大内存设置,将无法再进行写入操作。(注释) 
appendonl是否在每次更新操作后进行日志记录,如果不开启,可能会在断电时导致一段时间内的数据丢失。因为redis本身同步数据文件是按上面save条件来同步的,所以有的数据会在一段时间内只存在于内存中。默认值为no 
appendfilenam更新日志文件名,默认值为appendonly.aof(注释) 
appendfsyn更新日志条件,共有3个可选值。no表示等操作系统进行数据缓存同步到磁盘,always表示每次更新操作后手动调用fsync()将数据写到磁盘,everysec表示每秒同步一次(默认值)。 
vm-enabled是否使用虚拟内存,默认值为no 
vm-swap-file虚拟内存文件路径,默认值为/tmp/redis.swap,不可多个Redis实例共享 
vm-max-memory将所有大于vm-max-memory的数据存入虚拟内存,无论vm-max-memory设置多小,所有索引数据都是内存存储的(Redis的索引数据就是keys),也就是说,当vm-max-memory设置为0的时候,其实是所有value都存在于磁盘。默认值为0。 



这时你可以打开一个终端进行测试了,配置文件中默认的监听端口是6379
 我们可以开启一个Redis客户端进行测试
 [root@SNDA-192-168-1-114 ~]# redis-cli 
Could not connect to Redis at 127.0.0.1:6379: Connection refused 
not connected> exit 
[root@SNDA-192-168-1-114 ~]# redis-server /etc/redis.conf 
[root@SNDA-192-168-1-114 ~]# redis-cli 
redis 127.0.0.1:6379> quit


三、redis数据结构
redis 的作者antirez曾称其为一个数据结构服务器(data structures server),这是一个非常准确的表述,redis的所有功能就是将数据以其固有的几种结构保存,并提供给用户操作这几种结构的接口。我们可以想象我们在各种语言中的那些固有数据类型及其操作。

redis目前提供四种数据类型:string,list,set及zset(sorted set)和Hash。
 •string是最简单的类型,你可以理解成与Memcached一模一个的类型,一个key对应一个value,其上支持的操作与Memcached的操作类似。但它的功能更丰富。
 •list是一个链表结构,主要功能是push、pop、获取一个范围的所有值等等。操作中key理解为链表的名字。
 •set是集合,和我们数学中的集合概念相似,对集合的操作有添加删除元素,有对多个集合求交并差等操作。操作中key理解为集合的名字。
 •zset是set的一个升级版本,他在set的基础上增加了一个顺序属性,这一属性在添加修改元素的时候可以指定,每次指定后,zset会自动重新按新的值调整顺序。可以理解了有两列的mysql表,一列存value,一列存顺序。操作中key理解为zset的名字。
 •Hash数据类型允许用户用Redis存储对象类型,Hash数据类型的一个重要优点是,当你存储的数据对象只有很少几个key值时,数据存储的内存消耗会很小.更多关于Hash数


四、redis数据存储
redis的存储分为内存存储、磁盘存储和log文件三部分,配置文件中有三个参数对其进行配置。
save seconds updates,save配置,指出在多长时间内,有多少次更新操作,就将数据同步到数据文件。这个可以多个条件配合,比如默认配置文件中的设置,就设置了三个条件。
appendonly yes/no ,appendonly配置,指出是否在每次更新操作后进行日志记录,如果不开启,可能会在断电时导致一段时间内的数据丢失。因为redis本身同步数据文件是按上面的save条件来同步的,所以有的数据会在一段时间内只存在于内存中。
appendfsync no/always/everysec ,appendfsync配置,no表示等操作系统进行数据缓存同步到磁盘,always表示每次更新操作后手动调用fsync()将数据写到磁盘,everysec表示每秒同步一次。

五、redis主从配置
redis支持master-slave的主从配置,配置方法是在从机的配置文件中指定slaveof参数为主机的ip和port即可

六、redis起步(链接整理)
项目首页,下方是各种语言支持列表:
http://code.google.com/p/redis/

作者在wiki中给出了一个非常好的例子,以使我们可以快速上手,地址:
http://code.google.com/p/redis/wiki/TwitterAlikeExample

同时作者推荐的另一个教程,地址:
http://labs.alcacoop.it/doku.php?id=articles:redis_land

一个redis爱好者创建的相关问题讨论网站:
http://www.rediscookbook.org/

为什么使用 Redis及其产品定位
http://www.infoq.com/cn/articles/tq-why-choose-redis

Redis内存使用优化与存储
http://www.infoq.com/cn/articles/tq-redis-memory-usage-optimization-storage

redis底层代码图:





扩展:http://zhaohaolin.iteye.com/blog/1017561
转自:http://www.cnblogs.com/shanyou/archive/2012/01/28/2330451.html














分享到:
评论

相关推荐

    SpringBoot项目 MybatisPlus使用 Redis缓存.zip

    本项目中,我们看到“SpringBoot项目 MybatisPlus使用 Redis缓存.zip”主要涉及了SpringBoot、MybatisPlus和Redis三个核心组件,它们在实际开发中扮演着重要角色。 首先,SpringBoot是Spring框架的一种简化版,它...

    redis本地缓存与redis缓存

    文件名称“RedisCache-master”可能是一个包含Redis缓存相关项目的源代码仓库,里面可能包括了如何配置、使用Redis作为缓存的示例代码,以及如何与本地缓存结合的实践。 总结来说,本地缓存和Redis缓存各有优势,...

    MemCache和Redis缓存介绍

    **MemCache和Redis缓存介绍** 在IT行业中,缓存技术是提高系统性能和响应速度的关键因素之一。MemCache和Redis是两种广泛使用的分布式内存缓存系统,它们能够有效地存储和检索数据,减轻数据库的负担,提升应用的...

    redis缓存分享,包含redis和redis测试的项目test

    在"redis缓存知识分享.pptx"中,可能详细介绍了如何利用Redis的缓存机制提升系统的响应速度和性能。通常,Redis缓存用于减轻数据库的压力,通过将频繁访问的数据暂存到内存中,从而减少磁盘I/O操作。使用Redis缓存时...

    c#使用Redis缓存

    本文将深入探讨如何在C#应用中使用Redis缓存,以提高系统性能和响应速度。 首先,要使用Redis与C#进行交互,我们需要一个客户端库。StackExchange.Redis是.NET社区广泛推荐的Redis客户端,它提供了丰富的API用于...

    mybatis+redis缓存配置

    ### MyBatis与Redis缓存配置详解 #### 一、MyBatis缓存机制概述 在MyBatis中,缓存是一项重要的性能优化措施。它能够显著减少数据库的访问次数,提高应用程序的响应速度。MyBatis提供了两种级别的缓存支持:一级...

    redis页面缓存html使用redis实现页面缓存.docx

    本文档主要介绍了使用 Redis 实现页面缓存的方法,包括缓存 key 的设计、缓存实现的思路和代码实现。 页面缓存的目的:页面缓存的主要目的是为了提高网站的访问速度和用户体验。通过将页面缓存到 Redis 中,可以...

    清空redis缓存脚本指令

    清理redis缓存bat脚本,清理redis缓存bat脚本,清理redis缓存bat脚本,清理redis缓存bat脚本,清理redis缓存bat脚本,清理redis缓存bat脚本,清理redis缓存bat脚本,清理redis缓存bat脚本,清理redis缓存bat脚本,...

    什么是redis缓存穿透 雪崩 ,如何应对解决 redis缓存穿透 雪崩 的解决办法

    缓存穿透是指用户请求的数据既不在Redis缓存中,也不在数据库中,导致每次请求都需要去数据库查询。这可能由于恶意用户反复请求不存在的数据,或者系统设计缺陷引起。解决缓存穿透的方法有以下几点: 1. **布隆过滤...

    REDIS缓存数据库在JAVA中的使用

    零基础学会REDIS缓存数据库在JAVA中的使用。从REDIS的安装和使用开始,到Java程序与REDIS数据库进行连接互动,简单明了。

    redis缓存 redis缓存

    redis缓存 redis缓存

    redis缓存安装包和教案

    本资源包含Redis缓存的安装包以及相关学习教程,特别是关于Redis持久化方式的教案,对于想要深入理解和应用Redis的开发者来说,是一份宝贵的学习资料。 首先,让我们深入了解一下Redis的安装过程。在Windows环境下...

    Linux下使用C++编写的并发服务器,redis缓存和MySQL数据库,GoogleTest单元测试和webbench压力测试

    spark一个Linux下使用C++学习编写的并发服务器,使用redis作为缓存和MySQL作为数据库,并利用GoogleTest编写单元测试和webbench进行压力测试。.zipspark一个Linux下使用C++学习编写的并发服务器,使用redis作为缓存...

    redis缓存的示例代码

    在IT行业中,Redis被广泛用作高性能的内存数据存储,常用于实现缓存、消息队列、计数器等...正确配置和使用Redis缓存,是提升应用性能的关键步骤。通过`cache_redis-demo`这个示例,开发者可以快速上手并掌握这一技术。

    redis缓存服务器

    Redis 是一个高性能的键值对数据存储系统,常被用作数据库、缓存和消息中间件。它支持多种数据结构,如字符串、哈希、列表、集合、有序集合,这使得 Redis 在各种场景下有着广泛的应用。Redis 以其内存高速读写性能...

    使用.Net 技术操作Redis缓存技术,对Redis缓存进行存储增删改查等相关操作

    Redis是一种高性能的键值数据库,常用于数据缓存、消息队列、主从复制等多种场景。在.NET开发环境中,我们通常使用StackExchange.Redis库来与Redis进行交互。本篇文章将详细探讨如何使用.NET技术,尤其是C#语言,来...

    Springboot加Redis缓存实现

    总的来说,"Springboot加Redis缓存实现"项目展示了如何在Spring Boot应用中集成并使用Redis作为缓存系统,提高了数据读取效率,同时也提供了数据库操作和API测试的全套方案。理解并掌握这个项目中的知识点,对于开发...

    springboot-redis缓存+分布锁

    总的来说,"springboot-redis缓存+分布锁"项目是学习如何在SpringBoot应用中使用Redis进行缓存管理和实现分布式锁的绝佳实践。通过这个项目,你可以深入了解SpringBoot的集成特性,以及Redis在高并发场景下的重要...

    redis缓存技术

    首先,Redis缓存技术的关键在于它能够快速地存储和检索数据。Redis采用内存存储,这意味着数据读取速度非常快,比传统的磁盘存储数据库快几个数量级。当需要频繁访问的数据存储在Redis中,可以极大地提高应用程序的...

    Redis 缓存穿透、缓存击穿工具类资源

    Redis 缓存穿透的处理(缓存空值) Redis缓存击穿处理(互斥锁与逻辑删除方案) 封装为工具类,并适用于所有需要进行缓存穿透、击穿的方案,采用了泛型以及Lambda 函数式编程来完成编码

Global site tag (gtag.js) - Google Analytics