一、memcached和redis区别

1. redis 可以存储,memcached用来缓存,

2. 数据类型,memcached只有string;redis有string,链表,哈希结构,集合,有序集合

二、redis安装

1. http://download.redis.io/releases/  在这里下载

2. 下载源码,解压,不用config  ,直接make

3. 注意:一碰到时间错误的问题,

  原因:源码官方configure过,官方configure时生成的文件有时间戳信息,make只能发生在configure之后,如果虚拟机时间比configure的时间早就会报错,

  解决:data -s ‘yyyy-mm-dd hh:mm:ss’    重写时间,再lock -w  写入cmos

4. 在src下make test

5. 在 redis目录下,make install

6.  安装之后bin文件讲解

1. redis-benchmark    redis性能测试工具
2. redis-check-aof 检查aof日志工具
3. redis-check-dump 检查rdb日志工具
4. redis-cli 链接用的客户
5. redis-server redis服务进程

7. 拷贝redis.conf 配置文件 到bin目录下

cp /usr/common/redis-2.6.16/redis.conf ./

8. 启动与连接

    //启动
./bin/redis-server ./redis.conf //打开一个终端链接redis
./bin/redis-cli 

9. 让redis以后台进程的形式运行

修改配置文件redis.conf:
daemonize yes ps aux|grep redis //看进程

三、基本命令

注意:redis默认有16个数据库,分别是从0-15进行编号的,默认在0号数据库中操作,在conf中配置database

1.  set/get

set aa bcd

get aa

2. key


keys * //获取所有的keys
keys site //精确查
keys s* //模糊查
keys sit[ey] //模糊查 site或者sity
keys pattern //查询相应的key
在redis中允许模糊查询key,有三个通配符*,?,[]
*:统配任意多个字符
?:统配任意单个字符
[]:统配[]内的某一个字符 ②
randomkey:返回随机的key ③
type age //显示变量类型,存储类型 ④
exits key 判断是否存在,存在返回 1 ;不存在 返回 0 ⑤
del age //删除key ⑥
rename site an //重命名,site改为an ⑦
renamenx an ab //把key改名为新key 如果ab不存在则修改,存在就不修改

an 1 //移动key=an 到1库
select 1 //转换到1库

3. redis字符串类型的操作


set key value [ex 秒数] [px 毫秒数] [nx]/[xx]
如:set a 1 ex 10 10秒有效
  set a 1 px 9000 9秒有效
注:ex,px不要同时写否则以后面的有效期为准
如:set a 1 ex 100 px 9000 实际有效期是9000毫秒
nx:表示key不存在时执行操作
  如:set site www.abc.com nx
xx:表示key存在时执行操作
  如:set site www.abc.com xx (相当于修改site的值) ②
mset multi set 一次性设置多个键值
如:mset key1 v1 key2 v2... ③
mget key1 key2 keyn 获取多个key值 ④
setrange key 2 ?? hello--->he??o
setrange key 6 ! hello--->hello\x00\xa3\xa1
append word ## hello--->hello## 追加
getrange key start stop //获取字符产中【start stop范围的值】 包括start和stop
                //注意:对于字符串的小标,左数从0开始,右数从-1开始
  eg : getrange area 1 4 area = chinese chinese--->hine(最终)
    getrange area 0 -3 chinese--->chine(最终)
     getrange area 1 -3           chinese--->hine(最终)
注意: start>=length,则返回空字符串
        stop>=length,则截取至字符结尾
        如果start所处的位置在stop右边,则返回空字符串 ⑤
getset key newvalue 获取并返回旧值,设置新值 ⑥
incr age 加一 (计数,抢单)
decr age 减一
incrby age 5 加5
decrby age 10 减10
incrbyfloat age 0.5 //浮点数增加0.5

4. redis  link 链表结构 类型的操作

①:lpush key value  把值插入到链表头部    l:left  r:right

②:rpop key  返回病删除链表尾元素

③:rpush 尾部插入   lpop 左侧删除

④:lrange key start stop  返回链表中[start,stop]中的元素 规律,左数从0开始,右数从-1开始

⑤:lrem key count value  从key链表中删除value值  注:删除count的绝对值个value后结束 count>0 从表头删除  count<0 从表尾删除

⑥:ltrim key start stop  剪切key对应的链接,切[start,stop]一段,并把该段重新赋值给key
⑦:lindex key index  返回index索引上的值

⑧:llen key   作用计算链接表的元素个数 

⑨:linsert key after|before seach value 在key链表中寻找search,并在search值之前之后,插入value  注:一旦找到一个search之后,命令就结束了,因此不会插入多个value

⑩:rpoplpush source dest  把sourch的尾部拿出来放在dest的头部并返回该单元值
⑪:brpop ,blpop key timeout  等待弹出key的尾/头元素  timeout尾等待超时时间,如果timeout为0则一直等待

5. redis hash 哈希数据类型

①:hset key field value   把key中filed域的值设为value  注:如果没有field域,直接添加,如果有,则覆盖原field域的值

②:hmset key field1 value1[field2 value2 field3 value3 ... fieldn valuen] 设置field1->N个域,对应的值是value1->N (感觉有点像 HashMap hashMap(key) = {field1->value1 ...})

③:hget key field   返回key中field域的值

④:hmget key field1 field2 fieldN  返回key中field1,field2,fieldN域的值

⑤:hgetall key 返回key中,所有域与其值

⑥:hdel key field 删除key中field域

⑦:hlen key 返回key中元素的数量

⑧:hexists key field 判断key中有没有field域

⑨:hinrby key field value 是把key中的field域的值增长整型值value

⑩:hinrby float key field value 是把key中的field域的值增长浮点值value

⑪:hkeys key 返回key中所有的field

redis的安装和类型及基本命令的更多相关文章

  1. redis的安装与类型

    redis Redis 是一个开源(BSD许可)的,内存中的数据结构存储系统,它可以用作数据库.缓存和消息中间件 源码安装 redis , 编译安装 为何用源码安装,不用yum安装, 编译安装的优势 ...

  2. Linux安装redis PHP安装Redis扩展 and基本命令

    一.安装redis 用超级管理员身份运行: $ mkdir /usr/local/redis #redis安装目录 $ cd /usr/local/src #安装包下载目录 $ wget http:/ ...

  3. 沉淀再出发:redis的安装和使用

    沉淀再出发:redis的安装和使用 一.前言 下面让我们看看Redis这个键值对内存数据库的使用方法和相关注意事项. 二.Redis的安装和使用 2.1.Redis的定义 REmote DIction ...

  4. Redis的安装、基本使用以及与SpringBoot的整合

    1.概述 Redis 是现在很流行的一个 NoSql 数据库,每秒读取可以达到10万次,能够将数据持久化,支持多种数据结构,容灾性强,易扩展,常用于项目的缓存中间件. 今天我们就来聊聊关于Redis的 ...

  5. Linux下Redis的安装和部署

    一.Redis介绍 Redis是当前比较热门的NOSQL系统之一,它是一个key-value存储系统.和Memcache类似,但很大程度补偿了Memcache的不足,它支持存储的value类型相对更多 ...

  6. 基于C#的MongoDB数据库开发应用(4)--Redis的安装及使用

    在前面介绍了三篇关于MongoDB数据库的开发使用文章,严格来讲这个不能归类于MongoDB数据库开发,不过Redis又有着和MongoDB数据库非常密切的关系,它们两者很接近,Redis主要是内存中 ...

  7. Linux下Redis的安装与配置

    redis是当前比较热门的NOSQL系统之一,它是一个key-value存储系统.和Memcached类似,但很大程度补偿了 memcached的不足,它支持存储的value类型相对更多,包括stri ...

  8. Redis简介-安装-入门

    前言 我们team马上要用Redis了. 所以先学习一下这东西. Redis大名很早以前就听过了,以前在的公司都没有用到. 现在有机会终于接触到了,果断学习起来. 什么是redis Redis是完全开 ...

  9. Redis的安装与使用

    一.什么 Redis REmote DIctionary Server,简称 Redis,是一个类似于Memcached的Key-Value存储系统.相比Memcached,它支持更丰富的数据结构,包 ...

随机推荐

  1. springBean获取的几种方法

    1.通过FileSystemApplicationContext来获取(不常用,因为要spring配置文件的绝对路径) 2.通过ClassPathXmlApplicationContext来获取(常用 ...

  2. NUnit单元测试笔记

    vs2010 和 NUnit 问题处理. . 在 <configuration> 下 加 ... <startup> <requiredRuntime version=& ...

  3. javascript onclick 函数不执行

    今天被这个问题搞伤了. 原本是要给table中的元素添加onclick事件处理函数,刚开始还可以,后来就不行了,百试不得其解,反复检查,程序也没问题,耗了一个多小时,偏偏我就不信电脑会扯拐,就要看看还 ...

  4. Rancher + K8S RestApi使用

      1前言 1.1使用的软件及版本 软件 版本号 Rancher 1.6stable Kubernetes 1.8.3 Docker 1.12.6 1.2 Rancher与K8S的RESTAPI差异 ...

  5. 单网卡安装neutron

    devstack中机器只有一个物理网卡,如何设置neutron中的external网络? 方式是: 创建一个linux bridge和veth,把eth0和veth1加入到brige,用veth的另一 ...

  6. python学习笔记(接口自动化框架 V2.0)

    这个是根据上次框架版本进行的优化 用python获取excel文件中测试用例数据 通过requets测试接口.并使用正则表达式验证响应信息内容 生成xml文件测试报告 版本更新内容: 1. 整理了Cr ...

  7. cin关闭流同步加速

    习惯了用cin 很多人会说cin的速度比scanf慢很多, 其实不然. cin慢的原因主要在于默认cin与stdin总是保持同步, 这一步是消耗时间大户. 只需要加上std::iOS::sync_wi ...

  8. python面向对象编程 继承 组合 接口和抽象类

    1.类是用来描述某一类的事物,类的对象就是这一类事物中的一个个体.是事物就要有属性,属性分为 1:数据属性:就是变量 2:函数属性:就是函数,在面向对象里通常称为方法 注意:类和对象均用点来访问自己的 ...

  9. 蓝牙(cc2540) 协议栈 学习一

    ---------------------------------------------------------- app ------------------------------------- ...

  10. Andriod 四大组件,六大布局

    一.四大组件 Android四大组件分别为activity.service.content provider.broadcast receiver. 一.android四大组件详解 1.activit ...