redis 简介与常用操作

简介

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对象换入患处的工作线程数量

时间: 2024-10-13 05:31:22

redis 简介与常用操作的相关文章

redis 的其他常用操作

#-*- coding: utf8 -*- import redis pool = redis.ConnectionPool() r = redis.Redis(connection_pool=pool) # 删除操作 print(r.keys()) r.delete(*["xxx"]) # 要加星号 * # 查看所有 Redis的 name #keys(pattern='*') keys * # 匹配所有的key keys h?llo # 匹配hello , hallo ,hxllo

Redis 简介与命令操作

redis 是 key-value 的数据,所以每个数据都是一个键值对,键的类型是字符串: 值的类型分为五种:string.hash.list.set(集合).zset(有序集合). 数据操作的全部命令:http://redis.cn/commands.html 一.String 概述:String 是 redis 最基本的类型,最大能存储512MB的数据,String 类型是二进制安全的, 即可以存储任何数据.比如数字.图片.序列化对象等. 1. 2.获取 3.运算 4.其他 原文地址:htt

oracle简介及常用操作

oracle数据库是基于C/S模式的技术,是分布式的数据库产品,它支持多用户.分布式数据.大事务量处理.oracle数据库结构分为逻辑存储结构和物理存储结构.(1)逻辑存储结构是由表空间.段.区.数据块组成的.(2)物理存储结构是由数据文件.归档日志文件.控制文件.跟踪文件等组成.oracle基本类型的输出: (1)表方式,将指定表的数据导出: (2)用户方式,将指定用户的所有对象及数据导出: (3)全库方式,将数据库中的所有对象导出. 整个Oracle数据库就是一个大的柜子,这个柜子会被分为多

properties文件简介及其常用Java操作

一.properties文件简介 java中的properties文件是一种配置文件,主要用于表达配置信息,文件类型为*.properties,格式为文本文件,文件的内容是格式是"键=值"(推荐)或"键:值"的格式,在properties文件中,可以用"#"(推荐)或者"//"来作注释,properties文件在Java编程中用到的地方很多,操作很方便. 现在定义一个databaseInfo.properties文件,如下:#

33. Python redis的 hash类型操作 其他常用操作

1.hash 类型操作 import redis pool = redis.ConnectionPool(host="192.168.48.131", port=6379, db=0) r = redis.Redis(connection_pool=pool) #hash类型操作:是一个name对应一个字典 #语法 hset(name, key, value) #name 对应的hash中设置一个键值对(不存在,则创建键值对:否则,修改键值对) # 语法参数解释: name: redi

5种redis常用操作(数据类型+键值+服务+安全)

[toc] 5种redis常用数据类型操作 一.Redis常用操作 (string, list) 1.1 如果一个key设置两个不同的值,第二个值会覆盖第一个值. [[email protected] ~]# cd /usr/local/src/redis-4.0.9 [[email protected] redis-4.0.9]# redis-cli 127.0.0.1:6379> set key1 xavi OK 127.0.0.1:6379> set key2 xavilinux OK

redis常用操作、 redis操作键值、 redis安全设置

一:redis常用操作 Redis常用操作?(string, list)set key1 aminglinuxget key1set key1 aming//第二次赋值会覆盖setnx key2 aaa //返回1 如果key2不存在直接创建keysetnx key2 bbb //返回0,如果key2存在,返回0setex key3 10 1 //给key3设置过期时间为10s,值为1,若key已经存在,会覆盖新的值mset k1 1 k2 a k3 cmget k1 k3 k2lpush li

redis常用操作和操作键值

string.list常用操作 string数据创建.覆盖及设置过期时间 127.0.0.1:6379> get key1 ? ? ? ? 查看原来的key1的值 "b" 127.0.0.1:6379> set key1 123 ? ? 覆盖创建一个新的key1的string的值 OK 127.0.0.1:6379> get key1 ? ? ? ? 查看 "123" 127.0.0.1:6379> setnx key1 456 ? ? 使用

Spring Boot 和 Redis 常用操作

1    第4-2课:Spring Boot 和 Redis 常用操作 Redis 是目前使用最广泛的缓存中间件,相比 Memcached,Redis 支持更多的数据结构和更丰富的数据操作,另外 Redis 有着丰富的集群方案和使用场景,这一课我们一起学习 Redis 的常用操作. 1.1    Redis 介绍 Redis 是一个速度非常快的非关系数据库(Non-Relational Database),它可以存储键(Key)与 5 种不同类型的值(Value)之间的映射(Mapping),可