2.1 入门概述

2.1.1 1是什么

Redis:REmote DIctionary Server(远程字典服务器)

57cbc388e30556d174159b4d2afac71a.png

clip_image046.jpg

是完全开源免费的,用C语言编写的,遵守BSD协议, 是一个高性能的(key/value)分布式内存数据库,基于内存运行 并支持持久化的NoSQL数据库,是当前最热门的NoSql数据库之一, 也被人们称为数据结构服务器

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

Redis支持数据的持久化,可以将内存中的数据保持在磁盘中,重启的时候可以再次加载进行使用

Redis不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存储

Redis支持数据的备份,即master-slave模式的数据备份

2.1.2 2 能干嘛

内存存储和持久化:redis支持异步将内存中的数据写到硬盘上,同时不影响继续服务

取最新N个数据的操作,如:可以将最新的10条评论的ID放在Redis的List集合里面

模拟类似于HttpSession这种需要设定过期时间的功能

发布、订阅消息系统

定时器、计数器

2.1.3 3 去哪下

Http://redis.io/

1dad2e52de6755af8772576576b63cee.png

clip_image048.jpg

Http://www.redis.cn/

6efac82fc6271d9f380d296a83735a19.png

clip_image050.jpg

2.1.4 4 怎么玩

数据类型、基本操作和配置

持久化和复制,RDB/AOF

事务的控制

复制

......

2.2 VMWare+VMTools千里之行始于足下

2.2.1 VMWare虚拟机的安装

2.2.2 CentOS或者RedHad5的安装

如何查看自己的linux是32位还是64位

793ddcbf1bfb2dddd978796322aa907b.png

clip_image052.jpg

getconf LONG_BIT

返回是多少就是几位

假如出现了不支持虚拟化的问题

我的笔记本cpu是64位的,操作系统也是64位的,问题应该如虚拟机右下角提示所说,

97493387c84062e113b6c89ba86a618c.png

clip_image054.jpg

是“宿主机BIOS设置中的硬件虚拟化被禁用了。”

需要打开笔记本BIOS中的IVT对虚拟化的支持。

找到菜单“Security”–“System Security”,

将Virtualization Technology(VTx)和Virtualization Technology DirectedI/O(VTd)设置为 Enabled。

保存并退出BIOS设置,重启电脑,

9f0c0f9ff0ed0f61e91b1b08b68b5f1f.png

clip_image056.jpg

f3e8688ea90e994b45a2e4cfb265b40c.png

clip_image058.jpg

9d634420bb7fc268c8012b24c6e6435c.png

clip_image060.jpg

2.2.3 VMTools的安装

2.2.4 设置共享目录

2.2.5 上述环境都OK后开始进行Redis的服务器安装配置

2.3 Redis的安装

2.3.1 Windows版安装

Window 下安装

下载地址:https://github.com/dmajkic/redis/downloads

下载到的Redis支持32bit和64bit。根据自己实际情况选择,将64bit的内容cp到自定义盘符安装目录取名redis。 如 C:eids

打开一个cmd窗口 使用cd命令切换目录到 C:edis 运行 redis-server.exe redis.conf 。

如果想方便的话,可以把redis的路径加到系统的环境变量里,这样就省得再输路径了,后面的那个redis.conf可以省略,

如果省略,会启用默认的。输入之后,会显示如下界面:

263232e5638f19d7a4685c763cf0648a.png

clip_image062.jpg

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

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

设置键值对 set myKey abc

取出键值对 get myKey

770ec63d5ecd3d05e11fb00fbdb8d5e4.png

clip_image064.jpg

2.3.2 重要提示:

04bb5fe7eb75e36b34b05b1ee17540c5.png

clip_image066.jpg

由于企业里面做Redis开发,99%都是Linux版的运用和安装, 几乎不会涉及到Windows版,上一步的讲解只是为了知识的完整性, Windows版不作为重点,同学可以下去自己玩,企业实战就认一个版:Linux

2.3.3 Linux版安装

下载获得redis-3.0.4.tar.gz后将它放入我们的Linux目录/opt

/opt目录下,解压命令:tar -zxvf redis-3.0.4.tar.gz

解压完成后出现文件夹:redis-3.0.4

c4a747292d932c4038188476c417c669.png

clip_image068.jpg

进入目录:cd redis-3.0.4

420f609571542b8255c6c1502759c099.png

clip_image070.jpg

在redis-3.0.4目录下执行make命令

运行make命令时故 意出现的错误解析:

安装gcc

gcc是linux下的一个编译程序,是C程序的编译工具。

GCC(GNU Compiler Collection) 是 GNU(GNU's Not Unix) 计划提供的编译器家族,它能够支持 C, C++, Objective-C, Fortran, Java 和 Ada 等等程序设计语言前端,同时能够运行在 x86, x86-64, IA-64, PowerPC, SPARC 和 Alpha 等等几乎目前所有的硬件平台上。鉴于这些特征,以及 GCC 编译代码的高效性,使得 GCC 成为绝大多数自由软件开发编译的首选工具。虽然对于程序员们来说,编译器只是一个工具,除了开发和维护人员,很少有人关注编译器的发展,但是 GCC 的影响力是如此之大,它的性能提升甚至有望改善所有的自由软件的运行效率,同时它的内部结构的变化也体现出现代编译器发展的新特征。

c43fdaf0f8a15513ae96caf1f8b025df.png

clip_image072.jpg

能上网:yum install gcc-c++

不上网:

二次make

Jemalloc/jemalloc.h:没有那个文件或目录

运行make distclean之后再make

ebc0ed9aaf69adc46c6bee32f3aa1928.png

clip_image074.jpg

Redis Test(可以不用执行)

a6fdf258274ae73ab410f6bf4310dbeb.png

clip_image076.jpg

下载TCL的网址:

http://www.linuxfromscratch.org/blfs/view/cvs/general/tcl.html

55b47cd09c6ebee4cbb337e39daa621b.png

clip_image078.jpg

安装TCL

1425ce50613c36365144a602561f4ef5.png

clip_image080.jpg

如果make完成后继续执行make install

7caf620f07346f2c5057667e8131c512.png

clip_image082.jpg

查看默认安装目录:usr/local/bin

8058dd5dd47906aaf42fc129a1057fec.png

clip_image084.jpg

Redis-benchmark:性能测试工具,可以在自己本子运行,看看自己本子性能如何

服务启动起来后执行

Redis-check-aof:修复有问题的AOF文件,rdb和aof后面讲

Redis-check-dump:修复有问题的dump.rdb文件

Redis-cli:客户端,操作入口

Redis-sentinel:redis集群使用

Redis-server:Redis服务器启动命令

启动

f313f2e2fdfdb85477dcbe02bf2098c4.png

clip_image086.jpg

修改redis.conf文件将里面的daemonize no 改成 yes,让服务在后台启动

将默认的redis.conf拷贝到自己定义好的一个路径下,比如/myconf

启动

3089d42cd1957e8d29dd6052dd4a9051.png

clip_image088.jpg

连通测试

9ec69665dfff82a1bea7d8595fb68e1c.png

clip_image090.jpg

/usr/local/bin目录下运行redis-server,运行拷贝出存放了自定义conf文件目录下的redis.conf文件

永远的helloworld

54436dcad66453c88c7339f7aae5ba3b.png

clip_image092.jpg

关闭

9b5b72bde4df37531cbaf333e19278e6.png

clip_image093.png

单实例关闭:redis-cli shutdown

多实例关闭,指定端口关闭:redis-cli -p 6379 shutdown

2.4 Redis启动后杂项基础知识讲解

2.4.1 单进程

单进程模型来处理客户端的请求。对读写等事件的响应 是通过对epoll函数的包装来做到的。Redis的实际处理速度完全依靠主进程的执行效率

Epoll是Linux内核为处理大批量文件描述符而作了改进的epoll,是Linux下多路复用IO接口select/poll的增强版本, 它能显著提高程序在大量并发连接中只有少量活跃的情况下的系统CPU利用率。

2.4.2 默认16个数据库,类似数组下表从零开始,初始默认使用零号库

设置数据库的数量,默认数据库为0,可以使用SELECT 命令在连接上指定数据库id

databases 16

2.4.3 Select命令切换数据库

2.4.4 Dbsize查看当前数据库的key的数量

2.4.5 Flushdb:清空当前库

2.4.6 Flushall;通杀全部库

2.4.7 统一密码管理,16个库都是同样密码,要么都OK要么一个也连接不上

2.4.8 Redis索引都是从零开始

2.4.9 为什么默认端口是6379

Logo

开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!

更多推荐