简介

  我所在的公司是一个以线下业务为主的公司,软件这一块的东西可以说是手工作坊,技术上的东西全靠大家自己折腾。最近也是觉得自己在社会主义的怀抱里安逸了太久,要提高思想政治觉悟,不能忘了资本主义的黑暗,要多学一点技术,武装自己,同资本主义做斗争,Redis 就是众多武器中的一个。

  Redis 全名 Remote Dictionary Server,是一个使用 ANSI C 预研编写的、遵守 BSD 协议的、支持网络的、可基于内存可持久化的、高性能 Key-Value 数据库,同时他也提供了多种语言(Java、C/C++、C#、PHP、JavaScript等)的 API。

  相交于其他的 Key-Value 数据库,Redis 的有如下优点:

  • Redis 是开源免费的,遵守 BSD 协议;
  • Redis 性能极高,读取数度能达到110000次/s,写的速度是81000次/s;
  • Redis 数据类型更为丰富,除了 string 类型之外,还支持 hash、list、set、zset 等数据的存储;
  • Redis 的所有操作都是原子的;
  • Redis 运行在内存中,但是可以持久化到磁盘,且支持 master-slave 模式的数据备份。

Windows 安装

  官网:http://redis.io/

  大家可以根据需要选择自己需要的版本自行下载,本篇文章以 Windows 环境下的安装为例:

  解压压缩包到指定位置,进入命令行,切换到解压的位置:64位机请进入 64bit 文件夹下,32位机请进入 32bit 文件夹下,运行 redis-server.exe redis.conf 命令启动服务端,会显示如下界面: 

运行成功后,请不要关闭当前窗口,不然无法访问服务端,如果觉得这样运行过于麻烦,你也可以将Redis注册为系统服务运行如下命令即可:

D:\Runtime\redis_2.4.5 --service-install D:\Runtime\redis \windows.conf

  启动一个新的命令行窗口,切换到 Redis 目录下运行 redis-cli.exe -h 127.0.0.1 -p 6379进入 Redis 的客户端界面:

在这个窗口中做一个简单的演示,设置键值对 set name lofei,再使用 get name 取出,如下:

Linux 安装

  不过Redis大多是部署在 Linux 服务器上的,这里顺便提一下 linux 服务器的安装:

$ wget http://download.redis.io/releases/redis-2.8.24.tar.gz
$ .tra.gz
$ cd redis-
$ make

  启动服务端:

$ cd src
$ ./redis-server redis.conf

  启动客户端:

$ cd src
$ ./redis-cli
redis> set name lofei
OK
redis> get name
"lofei"

  可视化管理工具推荐:RedisDesktopManager,大家可以到官网下载,不过前期学习还是建议使用命令进行操作。

  安装完成后,很多人想把Redis加入到开机启动中,按如下步骤操作(以3.0.7位例):

  1. 打开配置文件redis.conf将节点daemonize的值改为yes;
  2. 将redis-3.0.7拷贝到/usr/local/bin/redis_3.07下;
  3. 在/etc/init.d下创建redis文件,并添加内容如下:
    ###########################
    # chkconfig: 2345 10 90
    # description: Start and Stop redis  
    
    PATH=/usr/local/bin:/sbin:/usr/bin:/bin  
    
    REDISPORT=6379
    EXEC=/usr/local/bin/redis_3.0.7/src/redis-server
    REDIS_CLI=/usr/local/bin/redis_3.0.7/src/redis-cli  
    
    PIDFILE=/var/run/redis.pid
    CONF="/usr/local/bin/redis_3.0.7/redis.conf"  
    
    case "$1" in
        start)
            if [ -f $PIDFILE ]
            then
                    echo "$PIDFILE exists, process is already running or crashed"
            else
                    echo "Starting Redis server..."
                    sudo $EXEC $CONF
            fi
            " ]
            then
                  echo "Redis is running..."
            fi
            ;;
        stop)
            if [ ! -f $PIDFILE ]
            then
                    echo "$PIDFILE does not exist, process is not running"
            else
                    PID=$(cat $PIDFILE)
                    echo "Stopping ..."
                    $REDIS_CLI -p $REDISPORT SHUTDOWN
                    while [ -x ${PIDFILE} ]
                   do
                        echo "Waiting for Redis to shutdown ..."
                        sleep 1
                    done
                    echo "Redis stopped"
            fi
            ;;
       restart|force-reload)
            ${0} stop
            ${0} start
            ;;
      *)
        echo "Usage: /etc/init.d/redis {start|stop|restart|force-reload}" >&2
            exit 1
    esac
    ##############################
  4. 为redis赋予执行权限: chmod +x /etc/init.d/redis
  5. 设定开机启动: chkconfig redis on

目录结构

  Redis 由5个可执行文件和1个配置文件构成,他们的作用如下:

  • /redis-server:Redis 服务器的启动程序;
  • /redis-cli:Redis 的命令行操作工具;
  • /redis-benchmark:Redis 性能测试工具,测试 Redis 运行环境的读写性能
  • /redis-check-aof:用于修复出问题的 AOF 文件;
  • /redis-check-dump:用于修复出问题的 dump.rdb 文件;
  • /redis.conf:Redis 的配置文件。

Redis学习笔记(一) 初识 Redis的更多相关文章

  1. Redis 学习笔记4: Redis 3.2.1 集群搭建

    在CenOS 6.7 linux环境下搭建Redis 集群环境 1.下载最新的Redis版本 本人下载的Redis版本是3.2.1版本,下载之后,解压,编译(make): 具体操作可以参考我的博文:R ...

  2. Redis学习笔记2-使用 Redis 作为 LRU 缓存

    当 Redis 作为缓存使用时,当你添加新的数据时,有时候很方便使 Redis 自动回收老的数据.LRU 实际上是被唯一支持的数据移除方法.Redis 的 maxmemory 指令,用于限制内存使用到 ...

  3. Redis 学习笔记2:redis.conf配置文件详解

    Redis 的配置文件位于 Redis 安装目录下,文件名为 redis.conf. 参数说明: 参数说明 redis.conf 配置项说明如下: 1. Redis默认不是以守护进程的方式运行,可以通 ...

  4. Redis学习笔记一(Redis的详细安装及Linux环境变量配置和启动)

     Redis Redis是一个开源的使用ANSI C语言编写.支持网络.可基于内存亦可持久化的日志型.Key-Value数据库,并提供多种语言的API. 我使用的是下面这个版本: 若没有资源的话,我在 ...

  5. Redis学习笔记一:Redis安装

    Redis安装 1.下载进入redis官网下载redis-xxx.tar.gz包 2.将redis-xxx.tar.gz拷贝到Linux某一目录下并对其进行解压 tar -zxvf Redis-xxx ...

  6. redis学习笔记-01:redis简介

    1.redis是一个高性能的Nosql数据库,遵守BSD协议,使用c语言编写.支持网络.可基于内存亦可持久化,是一种日志型.Key-Value数据库,也可看做是一个分布式的.基于内存的缓存工具. 2. ...

  7. Redis学习笔记(二):Redis集群

    集群通过分片(sharding)来进行数据共享,并提供复制和故障转移功能.   1.节点 一个节点就是一个运行在集群模式下的Redis服务器.启动Redis服务器时,通过判断cluster-enabl ...

  8. redis学习之旅-初识Redis

    定义: redis是一种支持Key-Value等多种数据结构的存储系统.可用于缓存,事件发布或订阅,高速队列等场景.该数据库使用ANSI C语言编写,支持网络,提供字符串,哈希,列表,队列,集合结构直 ...

  9. redis学习笔记-04:redis五大数据结构类型

    redis的命令大全网站:http://redisdoc.com/ 一.redis五大数据类型 1.String(字符串).Hash(哈希,类似Java里的Map).List(列表).Set(集合)和 ...

  10. redis学习笔记-03:redis安装

    一.redis的安装和配置 1.下载redis-5.0.4.tar.gz到/opt目录下,解压命令 :tar -zxvf redis-5.0.4.tar.gz,解压后出现redis-5.0.4的文件夹 ...

随机推荐

  1. Spring学习笔记之依赖的注解(2)

    Spring学习笔记之依赖的注解(2) 1.0 注解,不能单独存在,是Java中的一种类型 1.1 写注解 1.2 注解反射 2.0 spring的注解 spring的 @Controller@Com ...

  2. Android ToolBar自定义图标,关联DrawerLayout

    Android5.0出现了一个可以代替ActionBar的控件ToolBar,使用更加灵活,一般我们使用ToolBar来和DrawerLayout配合使用,官方提供了一个开关类ActionBarDra ...

  3. Websphere 手动模拟删除应用操作

    Websphere  手动模拟删除应用操作 切记:不要在程序还在运行的时候,直接的remove掉应用程序,不然,会发生意外的错误.       最近,在项目中,不小心手动移除了正在运行的应用,发现se ...

  4. 工厂模式-CaffeNet训练

    参考链接:http://blog.csdn.net/lingerlanlan/article/details/32329761 RNN神经网络:http://nbviewer.ipython.org/ ...

  5. JVM上的下一个Java——Scala

    Scala是一种针对 JVM 将函数和面向对象技术组合在一起的编程语言.Scala编程语言近来抓住了很多开发者的眼球.它看起来像是一种纯粹的面向对象编程语言,而又无缝地结合了命令式和函数式的编程风格. ...

  6. 关于编译PCL1.71

    最近在编译PCL1.71时总会出现错误, 编译的时候就出现无法生成pcl_io_debug.lib 由于无法生成pcl_io_debug.lib,. 借鉴PCL中国的经验: (1):把io\inclu ...

  7. javascript中创建对象和实现继承

    # oo ##创建对象 1. 原型.构造函数.实例之间的关系 * 原型的construct->构造函数:调用isPrototypeOf(obj)方法可以判定和实例的关系:  * 构造函数的pro ...

  8. PHP 判断一个字符是否在字符串中

    strpos() - 查找字符串 在另一字符串中 第一次出现的位置(区分大小写) stripos() - 查找字符串 在另一字符串中 第一次出现的位置(不区分大小写) strrpos() - 查找字符 ...

  9. ToDoList(原生JS)了解一下

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  10. 动态规划——独立任务最优调度(Independent Task Scheduling)

    题目链接 题目描述 用2 台处理机A 和B 处理n 个作业.设第i 个作业交给机器A 处理时需要时间i a ,若由机器B 来处理,则需要时间i b .由于各作业的特点和机器的性能关系,很可能对于某些i ...