redis 简介
简单来说 redis 就是一个数据库,不过与传统数据库不同的是 redis 的数据是存在内存中的,所以读写速度非常快,因此 redis 被广泛应用于缓存方向。另外,redis 也经常用来做分布式锁。redis 提供了多种数据类型来支持不同的业务场景。除此之外,redis 支持事务 、持久化、LUA脚本、LRU驱动事件、多种集群方案。
谈到Redis和Memcached 的区别,大家更多的是谈到数据结构和持久化这两个特性,其实还有一个比较大的区别就是:
Redis 是单线程,多路复用方式提高处理效率。
Memcached 是多线程的,通过CPU线程切换来提高处理效率。
除此之外还有
- redis支持更丰富的数据类型(支持更复杂的应用场景):Redis不仅仅支持简单的k/v类型的数据,同时还提供list,set,zset,hash等数据结构的存储。memcache支持简单的数据类型,String。
- Redis支持数据的持久化,可以将内存中的数据保持在磁盘中,重启的时候可以再次加载进行使用,而Memecache把数据全部存在内存之中。
- 集群模式:memcached没有原生的集群模式,需要依靠客户端来实现往集群中分片写入数据;但是 redis 目前是原生支持 cluster 模式的.
- Memcached是多线程,非阻塞IO复用的网络模型;Redis使用单线程的多路 IO 复用模型。
redis数据类型
Redis支持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合)及zset(sorted set:有序集合)。
快速上手
下载最新版Redis https://github.com/MSOpenTech/redis/releases
解压即用,顺便配置环境变量,入门使用单机版,那也是要开启服务的
可选参数是配置文件路径,默认使用默认的配置文件,此命令打开redis服务器
redis-server.exe [configuration url]
再开启一个终端作为redis客户端,可选参数为远程服务器的信息,包括地址或域名,端口号,密码
redis-cli.exe [-h host -p port -a password]
可用ping命令检测服务器连接状态,正常的