1. 什么是Redis?

Redis is a very fast non-relational database that stores a mapping of keys to five different types of values.

(Redis是一种速度非常快的非关系型数据库,NoSql的一种,它存储着以键值对为形式的数据,值的类型5种。)

Redis是Remote Dictionary Server(远程字典服务器)的缩写。

Redis supports in-memory persistent storage on disk, replication to scale read performance, and client-side sharding to scale write performance.

(Redis支持内存持久化到磁盘,以复制的形式来扩展读取的性能,以客户端碎片化(client-side sharding)的方式来扩展写的性能。)

Sharding is a method by which you partition your data into different pieces.

In this case, you partition your data based on IDs embedded in the keys, based on the hash of keys, or some combination of the two.

Through partitioning your data, you can store and fetch the data from multiple machines, which can allow a linear scaling in performance for certain problem domains.

(碎片化是一项技术,这项技术将你的数据分割成不同的部分。

这样一来,每个数据碎片将以ID作为它的键,根据哈希码的形式,这样就能把你的数据存储在不同的机器,然后以线性的方式对性能进行扩展。)

2. Redis支持的数据类型

字符串(String)

列表(List)

集合(Set)

散列(Hash)

有序集合(ZSet)

3. 存储形式

Redis数据库中所有数据都存储在内存中。

优势:由于内存的读写速度远快于硬盘,所以Redis在性能上比其他基于硬盘存储的数据库有明显优势。

eg:

在一台普通的PC上Redis可以每秒读写10万+个键值。

缺点:由于数据存储在内存中,程序退出后内存中的数据会丢失。

为了弥补这一缺点,Redis提供了持久化功能,用于将内存中的数据通过异步的方式写入到硬盘。

由于是异步的,因此不会影响其继续提供其他服务。

4. 应用场景

很多情况下,Redis被应用于缓存队列系统等。

当应用于缓存的场景,Redis为每个键值设置生存时间(TTL - Time to Live),生存时间到期后该键值

会自动被删除。

5. 安装Redis

Redis兼容大部分POSIX系统(Linux, OS X, BSD)

下载地址:

http://download.redis.io/

1) Linux下安装

首先下载安装包

tar xzf redis-stable.tar.gz

cd redis-stable

make (先编译源代码)

make test (测试源代码是否编译成功)

make install (安装程序)

安装程序实际过程是将可执行程序复制到/usr/local/bin目录,这样以后执行程序的时候不用输入完整的路径。

2) OS X下安装

OS X下通过软件包管理工具Homevrew进行。

a. 安装Homebrew

进入终端:

ruby -e"$(curl -fsSKL raw.github.com/mxcl/homebrew/go)"

b. 通过Homebrew安装Redis

brew install redis

c. 配置launchd让Redis岁系统自动运行

终端下输入以下命令:

ln -sfv /usr/local/opt/redis/*.plist ~/Library/LaunchAgents

launchctl load ~/Library/LaunchAgents/homebrew.mxcl.redis.plist

6. 启动Redis

1) 直接启动

$ redis-server

启动后Redis服务器默认使用6379端口

也可以自定义启动端口,如下:

$ redis-server --port 8918

2) 通过初始化脚本启动Redis

在生产环境中,我们推荐用该方法启动Redis(为了稳定)

a. 首先,进入Redis源码目录的utils目录

b. 找到叫redis_init_script的初始化脚本文件

c. 将初始化脚本复制到/etc/init.d目录并且重命名为redis_端口号

该端口号表示Redis将要监听的端口号

d. 修改脚本中REDISPORT变量的值为你设置的端口号

e. 建立需要的文件夹

/etc/redis           这里存放Redis的配置文件

/var/redis/端口号  这里存放Redis的持久化文件

f. 修改配置文件

网上下载文件模板,将它复制到/etc/redis目录

将该文件命名为端口号.conf

然后按照如下信息对配置文件中的部分参数进行配置

daemonize   yes                                       使Redis以守护进程的模式运行

pidfile         /var/run/redis_端口号.pid         这是Redis的PID文件位置

port           端口号                                    设置Redis监听的端口号

dir             /var/redis/端口号                      设置持久化文件存放位置

g. 使用如下命令启动Redis

/etc/init.d/redis_端口号 start

h. 使Redis随系统自动启动

$ sudo update-rc.d redis_端口号 defaults

7. 停止Redis

$ redis-cli shutdown

Redis开发 - 1. 认识redis的更多相关文章

  1. ASP.NET Redis 开发

    文件并发(日志处理)--队列--Redis+Log4Net Redis简介 Redis是一个开源的,使用C语言编写,面向“键/值”对类型数据的分布式NoSQL数据库系统,特点是高性能,持久存储,适应高 ...

  2. 企业项目开发--分布式缓存Redis

    第九章 企业项目开发--分布式缓存Redis(1) 注意:本章代码将会建立在上一章的代码基础上,上一章链接<第八章 企业项目开发--分布式缓存memcached> 1.为什么用Redis ...

  3. ASP.NET c# Redis 开发

    Redis简介 Redis是一个开源的,使用C语言编写,面向“键/值”对类型数据的分布式NoSQL数据库系统,特点是高性能,持久存储,适应高并发的应用场景.Redis纯粹为应用而产生,它是一个高性能的 ...

  4. 第九章 企业项目开发--分布式缓存Redis(1)

    注意:本章代码将会建立在上一章的代码基础上,上一章链接<第八章 企业项目开发--分布式缓存memcached> 1.为什么用Redis 1.1.为什么用分布式缓存(或者说本地缓存存在的问题 ...

  5. ASP.NET Redis 开发 [转]

    Redis简介 Redis是一个开源的,使用C语言编写,面向“键/值”对类型数据的分布式NoSQL数据库系统,特点是高性能,持久存储,适应高并发的应用场景.Redis纯粹为应用而产生,它是一个高性能的 ...

  6. ASP.NET Redis 开发(转载)

    Redis简介 Redis是一个开源的,使用C语言编写,面向“键/值”对类型数据的分布式NoSQL数据库系统,特点是高性能,持久存储,适应高并发的应用场景.Redis纯粹为应用而产生,它是一个高性能的 ...

  7. 《Redis开发与运维》读书笔记

    一.初始Redis 1.Redis特性与优点 速度快.redis所有数据都存放于内存:是用C语言实现,更加贴近硬件:使用了单线程架构,避免了多线程竞争问题 基于键值对的数据结构,支持的数据结构丰富.它 ...

  8. 第十章 企业项目开发--分布式缓存Redis(2)

    注意:本章代码是在上一章的基础上进行添加修改,上一章链接<第九章 企业项目开发--分布式缓存Redis(1)> 上一章说了ShardedJedisPool的创建过程,以及redis五种数据 ...

  9. Redis实战(七)Redis开发与运维

    Redis用途 1.缓存 Redis提供了键值过期时间设置, 并且也提供了灵活控制最大内存和内存溢出后的淘汰策略. 可以这么说, 一个合理的缓存设计能够为一个网站的稳定保驾护航. 2.排行榜系统 Re ...

随机推荐

  1. lodash用法系列(5),链式

    Lodash用来操作对象和集合,比Underscore拥有更多的功能和更好的性能. 官网:https://lodash.com/引用:<script src="//cdnjs.clou ...

  2. 关于流媒体(m3u8)的下载与播放

    求助:关于流媒体(m3u8)的下载与播放 http://www.cocoachina.com/bbs/read.php?tid-93389.html 此文有相关讨论.demo等,可关注.

  3. PPT幻灯片放映不显示备注,只让备注显示在自己屏幕上-投影机 设置

    无论是老师或是讲师还是即将要演讲的人,在讲课之前一定会做好课件,到哪一页该讲哪些内容,到哪里该如何去讲等等.那么一般的讲师会将这些课件存放到哪里呢?是用个书本记载下来呢,还是直接存放到电脑上呢?其实本 ...

  4. ios6sdk 和ios7sdk 分别在ios6设备和ios7设备上的效果 对比

  5. Linux学习9-CentOS搭建nginx环境

    前言 之前我们搭建网站的时候,把war包放到tomcat下就能运行起来了,为什么部署上线的时候,又用到了nginx呢? nginx可以做多台服务器的负载均衡,当用户非常少的时候,可以用一台服务直接部署 ...

  6. 毒枭第一季/全集Narcos迅雷下载

    英文全名Narcos,第1季(2015)Netflix.本季看点:<缉毒特警>该剧再现了上世纪八十年代末期警方与臭名昭著的大毒枭激烈交战的真实故事.律师.法官.政客.警察.军队甚至平民全都 ...

  7. http和https的区别与联系

    超文本传输协议HTTP协议被用于在Web浏览器和网站服务器之间传递信息,HTTP协议以明文方式发送内容,不提供任何方式的数据加密,如果攻击者截取了Web浏览器和网站服务器之间的传输报文,就可以直接读懂 ...

  8. Plupload设置自定义参数

    在HTML 5比较流行的当下,Plupload是文件上传的不二之选,特别是Adobe宣布2020年将停止对Flash的更新支持.本文记录一下如何在上传文件的时候,传递自定义参数. 了解到两种方式,一种 ...

  9. Asp.Net Core获取当前上下文对象

    HttpContext简介 .Net Core中的HttpContext上下文是个抽象类,命名空间为Microsoft.AspNetCore.Http 所在程序集 \netstandard2.0\Mi ...

  10. C#程序集Assembly学习随笔(增补版,附图)_AX

    上篇我讲了下我对Assembly的初步认知.现在来说说怎么使用已有的Assembly.比如说我在做一个解决方案时,发现你做的解决方案的某个项目中的类的方法(功能)我正好可以用到,哈,那我就不用写类了, ...