Remote Dictionary Server(Redis)是一个由Salvatore Sanfilippo写的key-value存储系统。Redis是一个开源的使用ANSI C语言编写、遵守BSD协议、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。

它通常被称为数据结构服务器,因为值(value)可以是字符串(String),哈希(Map),列表(list),集合(sets)和有序集合(sorted sets)等类型。

Redis简介

Redis是完全开源免费的,遵守BSD协议,是一个高性能的key-value数据库。

Redis与其他key-value缓存产品有以下三个特点:

  • Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用;
  • Redis不仅仅支持简单的key-value类型的数据,同时还提供list、set、zset、hash等数据结构的存储;
  • Redis支持数据的备份,即master-slave模式的数据备份;

Redis优势

  • 性能极高-Redis能读的速度是110000次/s,写的速度是81000次/s;
  • 丰富的数据类型-Redis支持二进制案例的string、lists、hashes、sets、及ordered sets数据类型操作;

    -原子-Redis的所有操作都是原子性的,意思就是要么成功执行要么失败完全不执行,单个操作是原子性的。多个操作也支持事物,即原子性,通过MULTI和EXEC指令包起来;
  • 丰富的特性-Redis还支持publish/subscribe,通知key过期等等特性;

Redis与其他key-value存储的区别:

  • Redis有着更为复杂的数据结构并且提供对他们的原子性操作,这是一个不同于其他数据库的进化路径。Redis的数据类型都是基于基本数据结构的,同时对程序员透明,无需进行额外的抽象。
  • Redis运行在内存中但是可以持久化到磁盘,所以在对不同数据集进行高速读写时需要权衡内存,因为数据量不能大于硬件内存。在内存数据库方面的另一个优点是,相比在磁盘上相同的复杂的数据结构中,在内存中操作起来非常简单,这样Redis可以做很多内部复杂性很强的事情。同时,在磁盘格式方面他们是紧凑的以追加的方式产生的,因为他们并不需要进行随机访问。

Redis安装

Windows下安装

下载地址:https://github.com/MicrosoftArchive/redis/releases

Redis支持32位和64位,这个根据自己的系统平台的实际情况选择,这里我们下载Redis-x64-xxx.zip压缩包到C盘,解压后将文件重新命名为redis。

打开cmd窗口,使用cd命令切换到目录C:\redis运行redis-server.exe redis.windows.conf。如果可以,最好是把redis的路径添加到系统的环境变量里面,这样就省得再输路径了,后面的那个redis.windows.conf可以省略,如果省略,会启动默认的。输入之后,会显示下面的界面:

这时候另启一个cmd窗口,原来的不要关闭,不然就无法访问服务端了。

切换到redis目录下运行redis-cli.exe -h 127.0.0.1 -p 6379

设置键值对set mykey abc

取出键值对get mykey

Linux下安装

下载地址:http://redis.io/download,下载最新文档版本,本教程使用的最新文档版本为2.8.17,下载并安装:

shell
$ wget http://download.redis.io/releases/redis-2.8.17.tar.gz
$ tar xzf redis-2.8.17.tar.gz
$ cd redis-2.8.17
$ make

make完成之后,redis-2.8.17目录下面会出现编译后的redis服务程序redis-server,还有用于测试的客户端程序redis-cli,两个程序位于安装目录src目录下:

下面启动redis服务:

shell
$ cd src
$ ./redis-server

注意这种方式启动redis使用的是默认配置,也可以通过启动参数告诉redis使用指定配置文件使用下面命令启动:

shell
$ cd src
$ ./redis-server redis.conf

redis.conf是一个默认的配置文件,我们可以根据需要使用自己的配置文件。启动redis服务进程后,就可以使用测试客户端程序redis-cli和redis服务器交互了。比如:

shell
$ cd src
$ ./redis-cli
redis> set foo bar
OK
redis> get foo
"bar"

ubuntu下安装

再ubuntu系统安装Redis可以使用以下命令:

shell
$ sudo apt-get update
$ sudo apt-get install redis-server

启动Redis

shell
$ redis-server

查看redis是否启动成功

shell
$ redis-cli

以上命令将打开以下终端:

shell
redis 127.0.0.1:6379>

127.0.0.1是本机IP,6379是redis服务端口。现在我么输入ping命令

shell
redis 127.0.0.1:6379> ping
PONG

以上说明我们已经成功安装了redis。

最新文章

  1. js中属性和方法的类型和区别
  2. vue2 上传图片
  3. Eclipse自动调整格式
  4. 建立ODBC数据源(基于windows)
  5. 嵌入式开发软件环境:uboot、kernel、rootfs、data布局分析
  6. 11gR2 RAC启用iptables导致节点宕机问题处理
  7. OnClick事件的Sender参数的前世今生——TWinControl.WinProc优先捕捉到鼠标消息,然后使用IsControlMouseMsg函数进行消息转发给图形子控件(意外发现OnClick是由WM_LBUTTONUP触发的)
  8. POJ 2187: Beauty Contest(旋转卡)
  9. LeetCode 259. 3Sum Smaller (三数之和较小值) $
  10. django 的时区设置
  11. Msi中文件替换
  12. sql server中的charindex函数用法解析(在一段字符中搜索字符或者字符串-----返回expression1在expression2出现的位置;反之,返回0)
  13. DSP builder安装指南(以9.1为例) 转自http://www.cnblogs.com/sleepy/archive/2011/06/28/2092362.html
  14. 2emq服务器压力测试(无用)
  15. replace 将逗号替换~
  16. FE面试题库
  17. 3DPDF是个什么东西?
  18. oracle知识点小结1
  19. 【WIP】markdown
  20. Kafka生产者----向kafka写入数据

热门文章

  1. C# 程序关闭托盘图标不会自动消失
  2. 北京Uber优步司机奖励政策(1月24日)
  3. 使用union 外加count
  4. 【springboot-01】整合quartz
  5. Windows运行机理——消息与消息队列
  6. Linux命令应用大词典-第29章 SELinux管理
  7. TW实习日记:第17天
  8. python3爬虫-快速入门-爬取图片和标题
  9. ThinkPHP - 1 - 本地部署
  10. 4.安装hive