在Redis里,数据库简单的使用一个数字编号来进行辨认,默认数据库的数字编号是0。若是你想切换到一个不一样的数据库,你可使用select命令来实现。在命令行界面里键入select 1,Redis应该会回复一条OK的信息,而后命令行界面里的提示符会变成相似redis 127.0.0.1:6379[1]>这样。若是你想切换回默认数据库,只要在命令行界面键入select 0
便可html
Redis不只仅是一种简单的关键字-值型存储,从其核心概念来看,Redis的5种数据结构中的每个都至少有一个关键字和一个值linux
关键字(Keys)是用来标识数据块,值(Values)是关联于关键字的实际值,能够是字符串、整数、序列化对象(使用JSON、XML或其余格式)redis
Redis命令的基本构成,如:set users:leto "{name: leto, planet: dune, likes: [spice]}"算法
关键字和值的是Redis的基本概念,而get和set命令是对此最简单的使用数据库
对于Redis而言,关键字就是一切,而值是没有任何意义。Redis不容许经过值来进行查询缓存
Redis是一种持久化的存储器内存储(in-memory persistent store)默认状况下,Redis会根据已变动的关键字数量来进行判断,而后在磁盘里建立数据库的快照(snapshot)。你能够对此进行设置,若是X个关键字已变动,那么每隔Y秒存储数据库一次。默认状况下,若是1000个或更多的关键字已变动,Redis会每隔60秒存储数据库;而若是9个或更少的关键字已变动,Redis会每隔15分钟存储数据库安全
至于存储器,Redis会将全部数据都保留在存储器中。显而易见,运行Redis具备不低的成本:由于RAM仍然是最昂贵的服务器硬件部件bash
关键字(Keys)是用于标识一段数据的一个字符串服务器
值(Values)是一段任意的字节序列,Redis不会关注它们实质上是什么微信
Redis展现了(也实现了)5种专门的数据结构
上面的几点使得Redis快速并且容易使用,但要知道Redis并不适用于全部的应用场景
关于key
127.0.0.1:6379> set mynum "2" OK 127.0.0.1:6379> get mynum "2" 127.0.0.1:6379> incr mynum (integer) 3 127.0.0.1:6379> get mynum "3"
因为INCR等指令自己就具备原子操做的特性,因此咱们彻底能够利用redis的INCR、INCRBY、DECR、DECRBY等指令来实现原子计数的效果,假如,在某种场景下有3个客户端同时读取了mynum的值(值为2),而后对其同时进行了加1的操做,那么,最后mynum的值必定是5。很多网站都利用redis的这个特性来实现业务上的统计计数需求。
lists的经常使用操做包括LPUSH、RPUSH、LRANGE等。咱们能够用LPUSH在lists的左侧插入一个新元素,用RPUSH在lists的右侧插入一个新元素,用LRANGE命令从lists中指定一个范围来提取元素。
//新建一个list叫作mylist,并在列表头部插入元素"1" 127.0.0.1:6379> lpush mylist "1" //返回当前mylist中的元素个数 (integer) 1 //在mylist右侧插入元素"2" 127.0.0.1:6379> rpush mylist "2" (integer) 2 //在mylist左侧插入元素"0" 127.0.0.1:6379> lpush mylist "0" (integer) 3 //列出mylist中从编号0到编号1的元素 127.0.0.1:6379> lrange mylist 0 1 1) "0" 2) "1" //列出mylist中从编号0到倒数第一个元素 127.0.0.1:6379> lrange mylist 0 -1 1) "0" 2) "1" 3) "2"
lists的应用至关普遍,随便举几个例子:
redis的集合,是一种无序的集合,集合中的元素没有前后顺序。集合相关的操做也很丰富,如添加新元素、删除已有元素、取交集、取并集、取差集等.
//向集合myset中加入一个新元素"one" 127.0.0.1:6379> sadd myset "one" (integer) 1 127.0.0.1:6379> sadd myset "two" (integer) 1 //列出集合myset中的全部元素 127.0.0.1:6379> smembers myset 1) "one" 2) "two" //判断元素1是否在集合myset中,返回1表示存在 127.0.0.1:6379> sismember myset "one" (integer) 1 //判断元素3是否在集合myset中,返回0表示不存在 127.0.0.1:6379> sismember myset "three" (integer) 0 //新建一个新的集合yourset 127.0.0.1:6379> sadd yourset "1" (integer) 1 127.0.0.1:6379> sadd yourset "2" (integer) 1 127.0.0.1:6379> smembers yourset 1) "1" 2) "2" //对两个集合求并集 127.0.0.1:6379> sunion myset yourset 1) "1" 2) "one" 3) "2" 4) "two"
对于集合的使用,也有一些常见的方式,好比,QQ有一个社交功能叫作“好友标签”。
redis还提供了有序集合(sorted sets)。有序集合中的每一个元素都关联一个序号(score),这即是排序的依据。不少时候,咱们都将redis中的有序集合叫作zsets,这是由于在redis中,有序集合相关的操做指令都是以z开头的,好比zrange、zadd、zrevrange、zrangebyscore等等
//新增一个有序集合myzset,并加入一个元素baidu.com,给它赋予的序号是1: 127.0.0.1:6379> zadd myzset 1 baidu.com (integer) 1 //向myzset中新增一个元素360.com,赋予它的序号是3 127.0.0.1:6379> zadd myzset 3 360.com (integer) 1 //向myzset中新增一个元素google.com,赋予它的序号是2 127.0.0.1:6379> zadd myzset 2 google.com (integer) 1 //列出myzset的全部元素,同时列出其序号,能够看出myzset已是有序的了。 127.0.0.1:6379> zrange myzset 0 -1 withscores 1) "baidu.com" 2) "1" 3) "google.com" 4) "2" 5) "360.com" 6) "3" //只列出myzset的元素 127.0.0.1:6379> zrange myzset 0 -1 1) "baidu.com" 2) "google.com" 3) "360.com"
hashes存的是字符串和字符串值之间的映射,好比一个用户要存储其全名、姓氏、年龄等等,就很适合使用哈希
//创建哈希,并赋值 127.0.0.1:6379> HMSET user username antirez password P1pp0 age 34 OK //列出哈希的内容 127.0.0.1:6379> HGETALL user 1) "username" 2) "antirez" 3) "password" 4) "P1pp0" 5) "age" 6) "34" //更改哈希中的某一个值 127.0.0.1:6379> HSET user password 12345 (integer) 0 //再次列出哈希的内容 127.0.0.1:6379> HGETALL user 1) "username" 2) "antirez" 3) "password" 4) "12345" 5) "age" 6) "34"
持久化不属于入门范围,找了几篇比较好的文章,有兴趣欢迎阅读
redis.conf 配置项说明以下:
daemonize no
/var/run/redis.pid
文件,能够经过pidfile指定pidfile /var/run/redis.pid
6379
,这里有个故事,由于6379在手机按键上MERZ对应的号码,而MERZ取自意大利歌女Alessia Merz的名字port 6379
bind 127.0.0.1
timeout 30
loglevel verbose
/dev/null
logfile stdout
databases 16
save <seconds> <changes>
rdbcompression yes
dbfilename dump.rdb
指定本地数据库存放目录
`dir ./`
设置当本机为slav服务时,设置master服务的IP地址及端口,在Redis启动时,它会自动从master进行数据同步
`slaveof <masterip> <masterport>`
当master服务设置了密码保护时,slav服务链接master的密码
`masterauth <master-password>`
设置Redis链接密码,若是配置了链接密码,客户端在链接Redis时须要经过AUTH <password>命令提供密码,默认关闭
`requirepass foobared`
maxclients 128
指定Redis最大内存限制,Redis在启动时会把数据加载到内存中,达到最大内存后,Redis会先尝试清除已到期或即将到期的Key,当此方法处理后,仍然到达最大内存设置,将没法再进行写入操做,但仍然能够进行读取操做。Redis新的vm机制,会把Key存放内存,Value会存放在swap区
`maxmemory <bytes>`
appendonly no
appendfilename appendonly.aof
指定更新日志条件,共有3个可选值:
no:表示等操做系统进行数据缓存同步到磁盘(快)
always:表示每次更新操做后手动调用fsync()将数据写到磁盘(慢,安全)
everysec:表示每秒同步一次(折衷,默认值)
appendfsync everysec
vm-enabled no
vm-swap-file /tmp/redis.swap
vm-max-memory 0
vm-page-size 32
vm-pages 134217728
vm-max-threads 4
glueoutputbuf yes
activerehashing yes
include /path/to/local.conf
MULTI、EXEC、DISCARD、WATCH指令构成了redis事务处理的基础
MULTI用来组装一个事务;
EXEC用来执行一个事务;
DISCARD用来取消一个事务;
WATCH用来监视一些key,一旦这些key在事务执行以前被改变,则取消事务的执行。
搜索关注微信公众号:寸土币争 ID: bbcoins