Redis-安装与配置

Nosq的介绍
  • NoSQL的特点
    • 不支持SQL语法
    • 存储结构跟传统关系型数据库中的那种关系表完全不同,nosql中存储的数据都是KV形式
    • NoSQL的世界中没有一种通用的语言,每种nosql数据库都有自己的api和语法,以及擅长的业务场景
    • NoSQL中的产品种类相当多:
      • Mongodb
      • Redis
      • Hbase hadoop
      • Cassandra hadoop
  • NoSQl和SQL数据库的比较
    • sql数据库适合用于关系特别复杂的数据查询场景,nosql反之
    • sql对事务的支持非常完善,而nosql基本不支持事务
      • 事务是必须满足4个条件(ACID): Atomicity(原子性)、Consistency(一致性)、Isolation(隔离性)、Durability(持久性)
    • 两者在不断地取长补短,呈现融合趋势
  • Redis简介
    • Redis是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。从2010年3月15日起,Redis的开发工作由VMware主持。从2013年5月开始,Redis的开发由Pivotal赞助。
    • Redis是 NoSQL技术阵营中的一员,它通过多种键值数据类型来适应不同场景下的存储需求,借助一些高层级的接口使用其可以胜任,如缓存、队列系统的不同角色
  • Redis缓存产品有以下三个特点
    • Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用。
    • Redis不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存储。
    • Redis支持数据的备份,即master-slave模式的数据备份。
  • Redis的优势
    • 性能极高 – Redis能读的速度是110000次/s,写的速度是81000次/s 。
    • 丰富的数据类型 – Redis支持二进制案例的 Strings, Lists, Hashes, Sets 及 Ordered Sets 数据类型操作。
    • 原子 – Redis的所有操作都是原子性的,同时Redis还支持对几个操作全并后的原子性执行。
    • 丰富的特性 – Redis还支持 publish/subscribe, 通知, key 过期等等特性。
  • Redis的应用场景
    • 用来做缓存(ehcache/memcached)——redis的所有数据是放在内存中的(内存数据库)
    • 可以在某些特定应用场景下替代传统数据库——比如社交类的应用
    • 在一些大型系统中,巧妙地实现一些特定的功能:session共享、购物车
    • 只要你有丰富的想象力,redis可以用在可以给你无限的惊喜…….
安装redis服务
  • 前提:环境准备(如果要编译安装redis)
    • sudo apt-get update        更新apt
    • sudo apt-get install build-essential tcl      安装c/c++的编译环境
  • 安装redis-server
    • sudo apt-get install redis-server -y         安装redis-server
      • 当前redis最新版本是4.0,它是一个测试版本,稳定版本是3.2.8版本
  • 查看redis主要的文件详解
    • sudo  find  /  -name  "*redis*"     查找redis安装的所有相关文件及其所在目录
    • /etc/    存放应用的配置
      • /etc/redis/redis.conf             redis的配置文件
        • 如果不是通过apt下载该文件可能不在不在/etc目录下需要手动将该文件移动到该位置
      • /etc/init.d/redis-server         redis启动文件
        • 使用redis启动配置文件也可以用来启动redis-server
          • /etc/init.d/redis-server start       开启redis-server
          • /etc/init.d/redis-server stop     关闭redis-server
          • /etc/init.d/redis-server status      检查redis-server状态
          • /etc/init.d/redis-server restart      重启redis-server
          • /etc/init.d/redis-server force-reload      强制重载
    • /var/log/    存放应用的log日志
      • /var/log/redis       redis日志路径
    • /usr/bin/     存放系统引用的启动脚本文件
      • /usr/bin/redis-cli                        redis客户端命令
      • /usr/bin/redis-server                 redis服务端命令
        • 启动服务可以在命令后面传入配置配件,该文件可以自定义,用来启动自定义配置的redis服务器
      • /usr/bin/redis-check-aof          redis数据存储(AOF文件)监测工具
      • /usr/bin/redis-benchmark        redis性能压测工具
      • /usr/bin/redis-check-dump      redis数据监测工具
配置redis
  • redis的配置信息所在位置
    • /etc/redis/redis.conf下
  • 核心redis配置选项
    • 绑定ip:如果需要远程访问,可将此⾏注释,或绑定⼀个真实ip
      • bind 127.0.0.1
    • port,默认为6379
      • port  6379
    • 是否以守护进程运⾏
      • daemonize yes
        • 如果以守护进程运⾏,则不会在命令⾏阻塞,类似于服务
        • 如果以⾮守护进程运⾏,则当前终端被阻塞
        • 设置为yes表示守护进程,设置为no表示⾮守护进程
        • 推荐设置为yes
        • 设置为yes  进程将不能被kill杀死,但是使用 kill   - 9可以杀死
    • 数据库,默认有16个
      • database 16
    • 进程文件
      • pidfile /var/run/redis/redis-server.pid
        • 在一个用户使用服务的时候,会创建锁文件,同一时间只能一个用户使用
    • ⽇志⽂件
      • logfile /var/log/redis/redis-server.log
    • 主从复制,类似于双机备份。
      • slaveof
    • 数据⽂件
      • dbfilename dump.rdb
    • 数据⽂件存储路径
      • dir /var/lib/redis
自定义配置redis服务器
  • 原理
    • 因为可以通过 redis-server  配置文件    的方式来以传入的配置文件配置来启动redis服务,所以,这通这种方式可以启动多个redis服务端
  • 自定义redis配置的步骤
    • 创建目录和拷贝文件
      • cd  ~ 
      • mkdir redis
      • sudo cp /etc/redis/redis.conf   ./
    • 赋权
      • sudo  chown  python.python  -a  -R  redis
    • 修改配置文件:
      • 46:pidfile redis-server.pid
      • 50:port 6380
      • 69:bind 127.0.0.1
      • 108:logfile redis-server.log
      • 如果不是sudo用户最少要修改 pidfile、logfile,不然的话,运行过程中会报权限问题
    • 启动和终止方式:
      • cd redis
      • redis-server redis.conf
      • ps aux | grep 6080
      • kill pid_num


刘小恺(Kyle) wechat
如有疑问可联系博主