什么是redis?
redis是一个开源,先进的key-value存储,并用于构建高性能,可扩展的Web应用程序的完美解决方案。
redis从它的许多竞争继承来的三个主要特点:
redis数据库完全在内存中,使用磁盘仅用于持久性。
相比许多键值数据存储,redis拥有一套较为丰富的数据类型。
redis可以将数据复制到任意数量的从服务器。
redis 优势
异常快速:redis的速度非常快,每秒能执行约11万集合,每秒约81000+条记录。
支持丰富的数据类型:redis支持最大多数开发人员已经知道像列表,集合,有序集合,散列数据类型。这使得它非常容易解决各种各样的问题,因为我们知道哪些问题是可以处理通过它的数据类型更好。
操作都是原子性:所有redis操作是原子的,这保证了如果两个客户端同时访问的redis服务器将获得更新后的值。
多功能实用工具:redis是一个多实用的工具,可以在多个用例如缓存,消息,队列使用(redis原生支持发布/订阅),任何短暂的数据,应用程序,如Web应用程序会话,网页命中计数等。
redis - 数据类型
redis支持5种类型的数据类型,它描述如下的:
字符串
redis字符串是字节序列。redis字符串是二进制安全的,这意味着他们有一个已知的长度没有任何特殊字符终止,所以你可以存储任何东西,512兆为上限。
哈希
redis的哈希是键值对的集合。 redis的哈希值是字符串字段和字符串值之间的映射,因此它们被用来表示对象
列表
redis的列表是简单的字符串列表,排序插入顺序。您可以添加元素到redis的列表的头部或尾部。
列表的最大长度为 232 - 1 元素(4294967295,每个列表中可容纳超过4十亿的元素)。
集合
redis的集合是字符串的无序集合。在redis您可以添加,删除和测试文件是否存在,在成员O(1)的时间复杂度。
集合中的元素最大数量为 232 - 1 (4294967295,可容纳超过4十亿元素)。
有序集合
redis的有序集合类似于Redis的集合,字符串不重复的集合。不同的是,一个有序集合的每个成员用分数,以便采取有序set命令,从最小的到最大的成员分数有关。虽然成员具有唯一性,但分数可能会重复。
redis安装
通过源码方式安装
下载地址:http://download.redis.io/releases/
什么版本的都有
这里就就安装 redis-2.8.21版本
安装依赖
yum install wget make gcc gcc-c++ zlib-devel openssl openssl-devel pcre-devel kernel keyutils patch perl tcl*
wget http://download.redis.io/releases/redis-2.8.21.tar.gz tar zxvf redis-2.8.21.tar.gz cd redis-2.8.21/src make PREFIX=/usr/local/redis install
安装完了再配置下
useradd -M -s /sibn/nologin redis mkdir /usr/local/redis/etc // 存放配置文件 mkdir /usr/local/redis/var && chown redis:redis /usr/local/redis/var // 存放日志文件、PID文件
创建redis.conf配置文件
vim /usr/local/redis/etc/redis.conf
内容如下:
daemonize yes // 后台运行 pidfile /usr/local/redis/var/redis.pid port 6379 // 监听端口 tcp-backlog 511 // 在高并发的环境中,为避免慢客户端的连接问题,需要设置一个高速后台日志 timeout 300 // 请求超时时间 loglevel verbose // 日志级别 Redis 总共支持四个级别: debug 、 verbose 、 notice 、 warning logfile /usr/local/redis/var/redis.log // 日志文件 databases 16 // redis数据库的数量 save 900 1 // 保存快照的频率,第一个*表示多长时间,第三个*表示执行多少次写操作。在一定时间内执行一定数量的写操作时,自动保存快照。可设置多个条件 save 300 10 save 60 10000 rdbcompression yes // 是否使用压缩 dbfilename dump.rdb // 本地持久化数据库文件名,默认值为 dump.rdb dir /usr/local/redis/var/ appendonly no // 是否开启appendonlylog,开启的话每次写操作会记一条log,这会提高数据抗风险能力,但影响效率 appendfsync always // appendonlylog如何同步到磁盘 三个选项:分别是每次写都强制调用fsync、每秒启用一次fsync、不调用fsync等待系统自己同步
更多详细解释可参考:http://wangwei007.blog.51cto.com/68019/1548167
现在可以启动了,为了方便先编写一个init服务启动脚本
vim /etc/init.d/redis
内容如下:
#!/bin/sh # # redis init file for starting up the redis daemon # # chkconfig: - 20 80 # description: Starts and stops the redis daemon. # Source function library. . /etc/rc.d/init.d/functions name="redis-server" basedir="/usr/local/redis" exec="$basedir/bin/$name" pidfile="$basedir/var/redis.pid" REDIS_CONFIG="$basedir/etc/redis.conf" [ -e /etc/sysconfig/redis ] && . /etc/sysconfig/redis lockfile=/var/lock/subsys/redis start() { [ -f $REDIS_CONFIG ] || exit 6 [ -x $exec ] || exit 5 echo -n $"Starting $name: " daemon --user ${REDIS_USER-redis} "$exec $REDIS_CONFIG" retval=$? echo [ $retval -eq 0 ] && touch $lockfile return $retval } stop() { echo -n $"Stopping $name: " killproc -p $pidfile $name retval=$? echo [ $retval -eq 0 ] && rm -f $lockfile return $retval } restart() { stop start } reload() { false } rh_status() { status -p $pidfile $name } rh_status_q() { rh_status >/dev/null 2>&1 } case "$1" in start) rh_status_q && exit 0 $1 ;; stop) rh_status_q || exit 0 $1 ;; restart) $1 ;; reload) rh_status_q || exit 7 $1 ;; force-reload) force_reload ;; status) rh_status ;; condrestart|try-restart) rh_status_q || exit 0 restart ;; *) echo $"Usage: $0 {start|stop|status|restart|condrestart|try-restart}" exit 2 esac exit $?
修改权限并设置为开机启动
chmod 755 /etc/init.d/redis chkconfig --add redis chkconfig redis on
启动
service redis start
把 /usr/local/redis/bin 添加到PATH里
echo "export PATH=$PATH:/usr/local/redis/bin" >> /etc/profile && source /etc/profile
测试输入命令
redis-cli
出现以下内容就安装成功了
127.0.0.1:6379>
参考:
1.http://www.yiibai.com/redis/redis_quick_guide.html