1.Redis介绍
1.1 NoSQL:一类新出现的数据库(not only sql),它的特点
- 不支持sql语法
- 存储结构跟传统关系型数据库中的那种关系表完全不同,nosql中存储的数据都是key value形式
- NoSQL的世界中没有一种通用的语言,每种nosql数据库都有自己的api和语法,以及擅长的业务场景
- NoSQL中的产品种类相当多:
- MongoDB
- Redis
- Hbase hadoop
- Cassandra hadoop
1.2 Redis简介
- Redis是一个开源的使用ANSI C语言编写,支持网络,可基于内存亦可持久化的日志型,key-value数据库,并提供多种语言的API。从2010年3月15日起,Redis的开发工作有Vmware主持。从2013年5月开始,Redis的开发由Pivotal赞助。
- Redis是NoSQL技术阵营中的一员,它通过多种键值类型来适应不同场景下的存储需求,借助一些高层级的接口使用其可以胜任,如缓存、队列系统的不同角色
1.3 Redis特性
Redis与其他key – value 缓存产品由以下三个特点:
- Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用。
- Redis不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存储。
- Redis支持数据的备份,即master-slave模式的数据备份。
1.4 NoSQL和SQL数据库的比较
- 适用场景不同:sql数据库适合用于关系特别复杂的数据查询场景,nosql反之
- “事务”特性的支持:sql对事务的支持非常完善,而nosql基本不支持事务
- 两者在不断地取长补短,呈现融合趋势
1.5 Redis优势
- 性能极高-Redis能读的速度是110000次/s,写的速度是81999次/s。
- 丰富的数据类型-Redis支持二进制案例的strings,lists,hashes,sets及ordered sets数据类型操作。
- 原子-Redis的所有操作都是原子性的,同时还支持对几个操作全并后的原子性执行。原子性就是操作没有多进程多线程。
- 丰富的特性-Redis还支持publish/subscribe 通知,key过期等等特性。
1.6 Redis应用场景
- 用来做缓存(ehcache/memcached)--redis的所有数据是放在内存中的(内存数据库)
- 可以在某些特定应用场景下替代传统数据库—比如社交类应用
- 在一些大型系统中,巧妙地实现一些特定的功能:session共享,购物车
- 只要你有丰富的想象力,redis可以给你无限的惊喜
2.Redis安装
我们安装两台为之后的主从和集群做准备
系统:CentOS 7
服务器:2台
redis-01 :IP地址:172.16.1.74
redis-02 :IP地址:172.16.1.111
关闭selinux,关闭防火墙...基础优化~
安装目录:/usr/local/
安装包版本:redis-3.2.12.tar.gz(比较稳定的3.2)
1 cd /usr/local/ 2 wget http://download.redis.io/releases/redis-3.2.12.tar.gz 3 tar xf redis-3.2.12.tar.gz 4 cd redis-3.2.12 5 make && make install 6 7 mkdir /etc/redis 8 cp redis.conf /etc/redis/redis.conf 9 /usr/local/bin 下会出现这些程序 10 redis-server redis服务器启动命令 11 redis-cli redis命令行客户端 12 redis-benchmark redis性能测试工具 13 redis-check-aof AOF文件修复工具 14 redis-check-rdb RDB文件检索工具 15 redis-sentinel redis哨兵进程(用于主从自动切换)