设为首页 收藏本站
查看: 1204|回复: 0

[经验分享] redis 简介与常用操作

[复制链接]

尚未签到

发表于 2018-11-6 11:12:44 | 显示全部楼层 |阅读模式
  简介
  redis是一个key-value存储系统。和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)和zset(有序集合)。这些数据类型都支push/pop,add/remove及取交集并集和差集及更丰富的操作,而且这些操作都是原子性的。在此基础上,redis支持各种不同方式的排序。与memcached一样,为了保证效率,数据都是缓存在内存中。区别的是redis会周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,并且在此基础上实现了master-slave(主从)同步。
  Redis 是一个高性能的key-value数据库,redis的出现,很大程度补偿了memcached这类key/value存储的不足,在部分场合可以对关系数据库起到很好的补充作用,它提供了Python,Ruby,Erlang,PHP客户端,使用很方便。
  ACID
  ACID,指数据库事务正确执行的四个基本要素的缩写。包含:原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)、持久性(Durability)。一个支持事务(Transaction)的数据库系统,必需要具有这四种特性,否则在事务过程(Transaction processing)当中无法保证数据的正确性,交易过程极可能达不到交易方的要求。
  原子性
  整个事务中的所有操作,要么全部完成,要么全部不完成,不可能停滞在中间某个环节。事务在执行过程中发生错误,会被回滚(Rollback)到事务开始前的状态,就像这个事务从来没有执行过一样。
  一致性
  在事务开始之前和事务结束以后,数据库的完整性约束没有被破坏。
  隔离性
  两个事务的执行是互不干扰的,一个事务不可能看到其他事务运行时,中间某一时刻的数据。
  持久性
  在事务完成以后,该事务所对数据库所作的更改便持久的保存在数据库之中,并不会被回滚。
  具体操作:
1. 安装redis 并布置环境(指定后台运行)  
# tar -zxvf redis-2.4.17.tar.gz  解压
  
# cd redis-2.4.17  进入目录
  
# make   编译
  
# make PREFIX=/usr/local/redis install  指定目录安装
  
# cd /usr/local/redis/ 进入安装后的目录
  
# mkdir etc logs 新建两个目录
  
# cd etc
  
# cp /lamp/redis-2.4.17/redis.conf /usr/local/redis/etc/  复制配置文件
  
# cd etc/
  
# vi redis.conf
  
   修改配置文件:开启后台运行、指定日志文件。
  
     daemonize yes 开启后台运行
  
    logfile /usr/local/redis/logs/redis.log 指定日志文件。
  

  
# ./redis-server /usr/local/redis/etc/redis.conf  启动
  
# ps -ef | grep redis 查看进程
  
# netstat -tunpl | grep 6379 查看端口
  

  
# ./redis-cli 客户端命令链接服务器
  
  redis 127.0.0.1:6379>
  
  redis 127.0.0.1:6379>quit 退出
  

  
# pkill redis-server 结束redis进程。
  
或: # ./redis-cli shutdown 执行关闭
  Redis的数据类型
  1. 共计5种类型:string(字符串)、hashes类型、list(双向链表)、set(集合)和zset(有序集合)
  2. String(子串类型)
set命令:设置一个键和值,键存在则只覆盖,返回ok  
   > set 键  值    例如: >set name zhangsan
  

  
   get命令:获取一个键的值,返回值
  
   > get 键         例如:>get name
  

  
   setnx命令:设置一个不存在的键和值(防止覆盖),
  
   > setnx 键 值       若键已存在则返回0表示失败
  

  
   setex命令:设置一个指定有效期的键和值(单位秒)
  
   > setex 键 [有效时间] 值  例如: >setex color 10 red
  
    不写有效时间则表示永久有效,等价于set
  

  
   setrange命令:替换子字符串 (替换长度由子子串长度决定)
  

  
   > setrange 键 位置 子字串
  
   > setrange name 4 aa  将name键对应值的第4个位置开始替换
  

  
   mset命令:批量设置键和值,成功则返回ok
  
   > mset 键1 值1 键2 值2 键3 值3 ....
  

  
   msetnx命令:批量设置不存在的键和值,成功则返回ok
  
   > msetnx 键1 值1 键2 值2 键3 值3 ....
  

  
   getset命令:获取原值,并设置新值
  

  
   getrange命令:获取指定范围的值
  
   >getrange 键 0 4     //获取指定0到4位置上的值
  

  
   mget命令: 批量获取值
  
   >mget 键1 键2 键3....
  

  
   incr命令: 指定键的值做加加操作,返回加后的结果。
  
   > incr 键        例如: >incr kid
  
   incrby命令: 设置某个键加上指定值
  
   > incrby 键 m    //其中m可以是正整数或负整数
  

  
   decr命令: 指定键的值做减减操作,返回减后的结果。
  
   > decr 键        例如: >decr kid
  
   decrby命令: 设置某个键减上指定值
  
   > decrby 键 m    //其中m可以是正整数或负整数
  

  
   append命令:给指定key的字符串追加value,返回新字符串值的长度
  
   >append 键 追加字串ha
  

  
   strlen求长度   >strlen 键名   //返回对应的值。
  3. hashes类型
hset命令:设置一个哈希表的键和值  
>hset hash名 键  值
  
如:>hset user:001 name zhangsan
  

  
  hsetnx命令:设置一个哈希表中不存在的键和值
  
>hsetnx hash名 键  值  //成功返回1,失败返回0
  
如:>hsetnx user:001 name zhangsan
  

  
hmset命令: 批量设置
  

  
hget命令: 获取执行哈希名中的键对应值
  

  
>hexists user:001 name //是否存在, 若存在返回1
  

  
>hlen user:001  //获取某哈希user001名中键的数量
  

  
>hdel user:001 name //删除哈希user:001 中name键
  

  
>hkeys user:002   //返回哈希名为user:002中的所有键。
  
>hvals user:002   //返回哈希名为user:002中的所有值。
  
>hgetall user:002 //返回哈希名为user:002中的所有键和值。
  4. list类型(双向链表结构)
  list即可以作为“栈”也可以作为"队列"。
  操作:
>lpush list1 "world"  //在list1头部压入一个字串  
>lpush list1 "hello"  // 在list1头部压入一个字串
  
>lrange list1 0 -1  //获取list1中内容
  
     0:表示开头  -1表示结尾。
  

  
>rpush list2 "world"  //在list2尾部压入一个字串
  
>rpush list2 "hello"  // 在list2尾部压入一个字串
  
>lrange list2 0 -1  //获取list2中内容
  
     0:表示开头  -1表示结尾。
  

  
>linsert list2 before "hello" "there"
  
在key对应list的特定位置前或后添加字符串
  

  
>lset list2 1 "four"
  
修改指定索引位置上的值
  

  
>lrem list2 2 "hello"  //删除前两个hello值
  
>lrem list2 -2 "hello" //删除后两个hello值
  
>lrem list2 0 "hello"  //删除所有hello值
  

  
>ltrim mylist8 1 -1     //删除此范围外的值
  

  
>lpop list2   //从list2的头部删除元素,并返回删除元素
  
>rpop list2   //从list2的尾部删除元素,并返回删除元素
  
>rpoplpush list1 list2     //将list1的尾部一个元素移出到list2头部。并返回
  

  
>lindex list2 1 //返回list2中索引位置上的元素
  
>llen list2 //返回list2上长度
  5.sets类型和操作
>sadd myset "hello" //向myset中添加一个元素  
  成功返回1,失败(重复)返回0
  

  
>smembers myset //获取myset中的所有元素
  

  
>srem myset "one" //从myset中删除一个one
  
  成功返回1,失败(不存在)返回0
  

  
>spop myset //随机返回并删除myset中的一个元素
  

  
>sdiff myset1 myset2 //返回两个集合的差集
  
以myset1为标准,获取myset2中不存在的。
  

  
>sdiffstor
  Redis常用命令
  1. 键值相关命令
>keys *  //返回键(key)  
>keys list*   //返回名以list开头的所有键(key)
  
>exists list1  //判断键名为list1的是否存在
  
        存在返回1, 不存在返回0
  
>del list1 //删除一个键(名为list1)
  
>expire list1 10 //设置键名为list1的过期时间为10秒后
  
>ttl list1 //查看键名为list1的过期时间,若为-1表示以过期
  

  
>move age 1 //将键名age的转移到1数据库中。
  
>select 1 //表示进入到1数据库中,默认在0数据库
  

  
>persist age //移除age的过期时间(设置为过期)
  Redis高级实用特性
  1. 安全性:为Redis添加密码
  1.进入配置文件:
  requirepass redis的密码
  2. 重启服务:
  # ./redis-cli shutdown 执行关闭
  # ./redis-server /usr/local/redis/etc/redis.conf  启动
  3. 登录(两种)
  # ./redis-cli 客户端命令链接服务器
  >auth 密码值  //授权后方可使用
  # ./redis-cli -a  密码 //连接时指定密码来进行授权
  2.主从复制
  操作步骤:
  1.先将linux虚拟机关闭,之后克隆一个。
  2.启动两个虚拟机:master(主)和slave(从)
  3. 在slave(从)中配置一下ip地址
  # ifconfig eth0 192.168.128.229
  # ping 一下看看通不通。
  4. 配置从机
  进入:配置文件
  slaveof  192.168.128.228 6379   //配置连接主机的Redis的ip和端口
  masterauth 密码  //配置连接密码
  最后启动slave(从)机的Redis服务。
  其他:可以通过info命令中的role属性查看自己角色是master、slave
  3.事务处理
  >multi   //开启一个事务
  >set age 10 //暂存指令队列
  >set age 20
  >exec    //开始执行(提交事务)
  或>discard //清空指令队列(事务回滚)
  4.乐观锁
  在事务前对被操作的属性做一个:
  > watch age
  >multi   //开启一个事务(在此期间有其他修改,则此处会失败)
  >set age 10 //暂存指令队列
  >set age 20
  >exec    //开始执行(提交事务)
  或>discard //清空指令队列(事务回滚)
  5.持久化机制
  1. snapshotting(快照)默认方式
  配置save
  save 900 1 #900秒内如果超过1个key被修改,则发起快照保存
  save 300 10 #300秒内容如超过10个key被修改,则发起快照保存
  save 60 10000
  2. Append-only file(aof方式)
  配置 appendonly on 改为yes
  会在bin目录下产生一个.aof的文件
  关于aof的配置
  appendonly yes //启用aof 持久化方式
  # appendfsync always //收到写命令就立即写入磁盘,最慢,但是保证完全的持久化
  appendfsync everysec //每秒钟写入磁盘一次,在性能和持久化方面做了很好的折中
  # appendfsync no //完全依赖os,性能最好,持久化没保证
  6.发布及订阅消息
  需要开启多个会话端口
  会话1:>subscribe tv1      //监听tv1频道
  会话2:>subscribe tv1 tv2  //监听tv1和tv2频道
  会话3: >publish tv1 消息   //向tv1频道发送一个消息
  7.使用虚拟内存
  在redis配置文件中设置
  vm-enabled yes             #开启vm功能
  vm-swap-file  /tmp/redis.swap  #交换出来的value保存的文件路径
  vm-max-memory 1000000        #redis使用的最大内存上限
  vm-page-size 32            #每个页面的大小32字节
  vm-pages 134217728          #最多使用多少页面
  vm-max-threads 4            #用于执行value对象换入患处的工作线程数量



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-631485-1-1.html 上篇帖子: codis实现redis分片和在线扩展 下篇帖子: Redis的安装及原理介绍
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表