redis的介绍和安装步骤

Redis简单介绍

Redis介绍
        Redis本质上一个Key/Value数据库,与Memcached类似的NoSQL型数据库,但是他的数据可以持久化的保存在磁盘上,解决了服务重启后数据不丢失的问题,他的值可以是string(字符串)、list(列表)、sets(集合)或者是ordered  sets(被排序的集合),所有的数据类型都具有push/pop、add/remove、执行服务端的并集、交集、两个sets集中的差别等等操作,这些操作都是具有原子性的,Redis还支持各种不同的排序能力
        Redis 2.0更是增加了很多新特性,如:提升了性能、增加了新的数据类型、更少的利用内存(AOF和VM)
        Redis支持绝大部分主流的开发语言,如:C、Java、C#、PHP、Perl、Python、Lua、Erlang、Ruby等等

Redis性能:
        根据Redis官方的测试结果:在50个并发的情况下请求10w次,写的速度是110000次/s,读的速度是81000次/s
        测试环境:
        1.        50个并发,请求100000次
        2.        读和写大小为256bytes的字符串
        3.        Linux2.6 Xeon X3320 2.5GHz的服务器上
        4.        通过本机的loopback interface接口上执行
地址: http://code.google.com/p/redis/wiki/Benchmarks


Redis的功能:
       1、Redis的Sharding:Redis支持客户端的Sharding功能,通过一致性hash算法实现,当前Redis不支持故障冗余,在集群中不能在线增加或删除Redis
       2、Redis的master/slave复制:
                    1.        一个master支持多个slave
                    2.        Slave可以接受其他slave的连接来替代他连接master
                    3.        复制在master是非阻塞的,而在slave是阻塞的
                    4.        复制被利用来提供可扩展性,在slave端只提供查询功能及数据的冗余
       3、Redis的Virtual Memory功能:vm是Redis2.0新增的一个非常稳定和可靠的功能,
vm的引入是为了提高Redis的性能,也就是把很少使用的value保存到disk,而key保存在内存中。实际上就是如果你有10w的keys在内存中,而只有仅仅10%左右的key经常使用,那么Redis可以通过开启VM尝试将不经常使用的Value转换到disk上保存

       4、Redis的附加档案(AOF)功能:Redis通过配置的策略将数据集保存到aof中,当Redis挂掉后能够通过aof恢复到挂掉前的状态

在linux下安装redis

       说起这个比mysql的安装过程简单多乐,它不需要configure,只需要解压之后make就可以,无需make install

        ~$ wget http://redis.googlecode.com/files/redis-2.4.10.tar.gz

        ~$ tar -zxvf redis-2.4.10.tar.gz

        ~$ cd redis-2.4.10/src

        ~$ make

       待执行完之后你会看到redis-benchmark,redis-cli,redis-server文件,证明已经成功了;

       为了方便调用,我们自己新建一个目录来存放执行文件以及日志配置文件

        ~$ cd ~

        ~$ mkdir redis

        ~$ mkdir redis/bin

        ~$ mkdir redis/etc

        ~$ mkdir redis/var

       拷贝执行文件和配置文件到相应目录

        ~$ cp redis-2.4.10/src/redis-benchmark   redis/bin

        ~$ cp redis-2.4.10/src/redis-cli                 redis/bin

        ~$ cp redis-2.4.10/src/redis-server          redis/bin

        ~$ cp redis-2.4.10/redis.conf                   redis/etc

       修改配置文件准备启动redis,激动人心的时刻即将来临了

        ~$ vi redis/etc/redis.conf

        配置如下

        daemonize   yes                                           #支持后台运行

        pidfile   /home/demon/redis/var/redis.pid      #运行pid文件的位置

        port  6400                                                     #端口号,默认是6379

        timeout  300                                                  #超时时间

        loglevel   debug                                            #记录日志级别

        logfile    /home/demon/redis/var/redis.log     #日志位置

        databases    16                                             #支持数据库个数

        save   900 1

        save   300  10

        save    60    10000

        rdbcompression yes

        dbfilename    dump.rdb                                 #持久化缓存文件

        dir       /home/demon/redis/var/                     #持久化缓存文件目录

        slave-server-stale-data  yes

        appendonly   no

        appendfsync  always

        ......其余的均为默认值

       启动服务:

       ~$ cd ~/redis/bin

       ~$ ./redis-server  ../etc/redis.conf

       可能没有任何输出,你可以查看进程

       ~$ ps -x | grep redis

       或者去var目录下查看日志文件观察运行情况

       ~$ vi ~/redis/var/redis.log

      OK,这些都是简单的查看服务情况,要想真实确定,就连上去试下手

       ~$ cd ~/redis/bin

       ~$ ./redis-cli -p 6400      #多端口连接方法,如果想关闭哪个redis,使用./redis-cli -p 6400 shutdown

       你会看到

        redis 127.0.0.1:6400>

        我们来简单试验下

        redis 127.0.0.1:6400> set name  demon

        redis 127.0.0.1:6400> get name

        输出"demon"

        over,一个redis服务安装配置完成


大家可以慢慢了解和实践各种redis命令

命令详解链接:http://redis.readthedocs.org/en/latest/index.html


你可能感兴趣的:(redis的介绍和安装步骤)