NoSQL:redis

4 篇文章 0 订阅
4 篇文章 0 订阅

NoSQL基本概念

NoSQL:新出现的数据库(not only sql)。特点:

  • 不支持SQL语法
  • 存储结构跟传统的关系型数据库中的那样关系表完全不通,nosql中存储的数据都是KV形式
  • NoSQL的世界中没有一种通用的语言,每种nosql数据库都有自己的api和语法,以及擅长的业务场景
  • NoSQL的产品种类很多:Mongodb、Redis、Hbase hadoop、Cassandra hadoop
    NoSQL和SQL数据库比较:
  • 适用场景不同:sql数据库适合用于关系特别复杂的数据查询,nosql反之
  • 事务特性的支持:sql对事务支持非常完善,而nosql基本不支持事务
  • 两者在不断的取长补短,呈现融合趋势

Redis-概念

Redis简介

Redis是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。从2010年3月15日起,Redis的开发工作由VMware主持。从2013年5月开始,Redis的开发由Pivotal赞助。
Redis是 NoSQL技术阵营中的一员,它通过多种键值数据类型来适应不同场景下的存储需求,借助一些高层级的接口使用其可以胜任,如缓存、队列系统的不同角色
redis官网
redis中文网

Redis特性

Redis 与其他 key - value 缓存产品有以下三个特点:

  • 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-实战

安装

  • macos:
#brew安装
$ brew install redis
:<<'
配置Redis
安装完成后redis默认的配置文件redis.conf位于/usr/local/etc
同时,redis-sentinel.conf也在这里。
'
#启动
redis-server /usr/local/etc/redis.conf
#检测
redis-cli ping
PONG

output

  • Redhat or Debian(都类似):
#下载
wget http://download.redis.io/releases/redis-4.0.6.tar.gz
#解压
tar -zxvf redis-4.0.6.tar.gz
#yum安装gcc依赖
yum install gcc
cd redis-4.0.6
#编译安装
make MALLOC=libc
cd src && make install
#-----------------#
#启动
cd src && ./redis-server
#-----------------#
#以后台进程方式启动redis
#修改redis.conf文件daemonize no改为daemonize yes
cd src
./redis-server /usr/local/redis-4.0.6/redis.conf
#-----------------#
#设置redis开机自启动
mkdir redis
cp /usr/local/redis-4.0.6/redis.conf /etc/redis/6379.conf
cp /usr/local/redis-4.0.6/utils/redis_init_script /etc/init.d/redisd
chkconfig redisd on
:<<'
 如果报service redisd does not support chkconfig 
 使用vim编辑redisd文件,在第一行加入如下两行注释,保存退出
 chkconfig:   2345 90 10
 description:  Redis is a persistent key-value database
'
chkconfig redisd on
service redisd start
#-----------------#

核心配置选项

Redis的配置信息在/etc/redis/redis.conf下。

sudo vi /etc/redis/redis.conf
#绑定ip:如果需要远程访问,可将此⾏注释,或绑定⼀个真实ip
bind 127.0.0.1
#端⼝,默认为6379
port 6379
:<<'是否以守护进程运⾏
如果以守护进程运⾏,则不会在命令⾏阻塞,类似于服务
如果以⾮守护进程运⾏,则当前终端被阻塞
设置为yes表示守护进程,设置为no表示⾮守护进程
推荐设置为yes'
daemonize yes
#数据⽂件
dbfilename dump.rdb
#数据⽂件存储路径
dir /var/lib/redis
#⽇志⽂件
logfile /var/log/redis/redis-server.log
#数据库,默认有16个
database 16
#主从复制,类似于双机备份。
slaveof

服务器端

服务器端的命令为redis-server
可以使⽤help查看帮助⽂档

redis-server --help

推荐使⽤服务的⽅式管理redis服务
启动

sudo service redis start

停⽌

sudo service redis stop
#重启 
sudo service redis restart

个人习惯

ps -ef|grep redis #查看redis服务器进程
sudo kill -9 pid #杀死redis服务器
sudo redis-server /etc/redis/redis.conf #指定加载的配置文件

客户端

客户端的命令为redis-cli
可以使⽤help查看帮助⽂档

redis-cli --help

连接redis

redis-cli
#运⾏测试命令
ping
#切换数据库
#数据库没有名称,默认有16个,通过0-15来标识,连接redis默认选择第一个数据库
select 9

String类型

#设置键值
set key value
#例:设置键为name值为itcast的数据
set name itcast
#设置键值及过期时间,以秒为单位
setex key seconds value
#例:设置键为aa值为aa过期时间为3秒的数据
setex aa 3 aa
#设置多个键值
mset key1 value1 key2 value2 ...
#例:设置键为'a1'值为'python'、键为'a2'值为'java'、键为'a3'值为'c'
mset a1 python a2 java a3 c
#追加值
append key value
#例:向键为a1中追加值' haha'
append 'a1' 'haha'
#获取:根据键获取值,如果不存在此键则返回nil
get key
#例:获取键'name'的值
get 'name'
#根据多个键获取多个值
mget key1 key2 ...
#例:获取键a1、a2、a3'的值
mget a1 a2 a3

键命令

#查找键,参数⽀持正则表达式
keys pattern
#例:查看所有键
keys *
#查看所有键
#例:查看名称中包含a的键
keys 'a*'
#查看键
#判断键是否存在,如果存在返回1,不存在返回0
exists key1
#例:判断键a1是否存在
exists a1
#判断键是否存在
#查看键对应的value的类型
type key
#例:查看键a1的值类型,为redis⽀持的五种类型中的⼀种
type a1
#查看值类型
#删除键及对应的值
del key1 key2 ...
#例:删除键a2、a3
del a2 a3
#删除键
#设置过期时间,以秒为单位
#如果没有指定过期时间则⼀直存在,直到使⽤DEL移除
expire key seconds
#例:设置键'a1'的过期时间为3秒
expire 'a1' 3
#设置过期时间
#查看有效时间,以秒为单位
ttl key
#例:查看键'bb'的有效时间
ttl bb

hash类型

#增加、修改
#设置单个属性
hset key field value
#例:设置键 user的属性name为itheima
hset user name itheima
:<<'设置键
#MISCONF Redis is configured to save RDB snapshots, but is currently not able to persist on disk. Commands that may modify the data set are disabled. Please check Redis logs for details about the error.
#Redis被配置为保存数据库快照,但它目前不能持久化到硬盘。用来修改集合数据的命令不能用
#原因:
#强制关闭Redis快照导致不能持久化。 解决方案:
#运行config set stop-writes-on-bgsave-error no 命令后,关闭配置项stop-writes-on-bgsave-error解决该问题'
#设置多个属性
hmset key field1 value1 field2 value2 ...
#例2:设置键u2的属性name为itcast、属性age为11
hmset u2 name itcast age 11
#设置多个属性
#获取
#获取指定键所有的属性
hkeys key
#例:获取键u2的所有属性
hkeys u2
#获取键属性
#获取⼀个属性的值
hget key field
#例:获取键u2属性'name'的值
hget u2 'name'
#获取键属性值
#获取多个属性的值
hmget key field1 field2 ...
#例:获取键u2属性'name'、'age的值
hmget u2 name age
#获取键属性值
#获取所有属性的值
hvals key
#例:获取键'u2'所有属性的值
hvals u2
#删除整个hash键及值,使⽤del命令
#删除属性,属性对应的值会被⼀起删除
hdel key field1 field2 ...
#例:删除键'u2'的属性'age'
hdel u2 age

list类型

#增加
#在左侧插⼊数据
lpush key value1 value2 ...
#例:从键为'a1'的列表左侧加⼊数据a 、 b 、c
lpush a1 a b c
#在右侧插⼊数据
rpush key value1 value2 ...
#例:从键为'a1'的列表右侧加⼊数据0 1
rpush a1 0 1
#在指定元素的前或后插⼊新元素
linsert key before或after 现有元素 新元素
#例:在键为'a1'的列表中元素'b'前加⼊'3'
linsert a1 before b 3
#获取
#返回列表⾥指定范围内的元素
start、stop为元素的下标索引
#索引从左侧开始,第⼀个元素为0
#索引可以是负数,表示从尾部开始计数,如-1表示最后⼀个元素
lrange key start stop
#例:获取键为'a1'的列表所有元素
lrange a1 0 -1
#设置指定索引位置的元素值
#索引从左侧开始,第⼀个元素为0
#索引可以是负数,表示尾部开始计数,如-1表示最后⼀个元素
lset key index value
#例:修改键为'a1'的列表中下标为1的元素值为'z'
lset a 1 z
#删除指定元素
#将列表中前count次出现的值为value的元素移除
count > 0: 从头往尾移除
count < 0: 从尾往头移除
count = 0: 移除所有
lrem key count value
#例:向列表'a2'中加⼊元素'a'、'b'、'a'、'b'、'a'、'b'
lpush a2 a b a b a b
#例:从'a2'列表右侧开始删除2个'b'
lrem a2 -2 b
#例:查看列表'py12'的所有元素
lrange a2 0 -1

redis命令参考文档
redis.py参考文档

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值