基础知识

redis默认有16个数据库;默认使用的是第0个。

  1. 可以使用select num切换
  2. 查看DB大小 DBSIZE
  3. 查看所有的key **keys **
  4. 清空当前数据库 flushdb
  5. 清空全部的数据库 FLUSHALL

为什么是6379?追星

Redis是单线程

明白Redis是很快的,官方表示,Redis是基于内存操作的,CPU不是redis的性能瓶颈,Redis的瓶颈是根据机器的内存和网络带宽,既然可以用单线程来实现,就使用单线程了!所以就使用单线程了!

Redis是c语言写的。官方数据每秒的10万+的QPS,不比Memecache差

Redis为什么单线程还很快?

1.误区:高性能的服务器一定是多线程的

2.误区:多线程(cpu上下文切换)一定比单线程效率高

核心:Redis是将所有的数据全部放在内存中,所以说使用单线程去操作效率就是最高的,多线程(CPU上下文切换:耗时操作!!),对于内存系统来说,如果没有上下文切换效率就是最高的!多次读写都是在一个CPU上的,在内存的情况下,这个就是最佳方案。

五大基本数据类型

Redis 是一个开源(BSD许可)的,内存中的数据结构存储系统,它可以用作数据库缓存消息中间件MQ。 它支持多种类型的数据结构,如 字符串(strings), 散列(hashes), 列表(lists), 集合(sets), 有序集合(sorted sets) 与范围查询, bitmaps, hyperloglogs 和 地理空间(geospatial) 索引半径查询。 Redis 内置了 复制(replication)LUA脚本(Lua scripting), LRU驱动事件(LRU eviction)事务(transactions) 和不同级别的 磁盘持久化(persistence), 并通过 Redis哨兵(Sentinel)和自动 分区(Cluster)提供高可用性(high availability)。

非关系性数据库

  • 结构灵活
  • 访问速度快

基于内存存储,支持key-value形式,底层使用c语言编写的。

基于key-value形式的数据字典,结构非常简单,没有数据表的概念,直接用键值对的形式完成数据的管理,Redis支持5中数据类型。

  • 字符串
  • 列表 list
  • 集合set
  • 有序集合
  • 哈希 hashMap
{

	key:value,

	key:{key:value}

}

字符串

Redis:

基本操作

基本

  • 字符串追加字符 ,如果不存在相当于set key
append key1 hello
  • 显示字符的长度
strlen key1
  • 判断是否存在
EXISTS key1
  • 自增
127.0.0.1:6379> set views 0
OK
127.0.0.1:6379> get views
"0"
127.0.0.1:6379> incr views
(integer) 1
127.0.0.1:6379> incr views
(integer) 2
  • 自减
127.0.0.1:6379> decr views
(integer) 1
  • 设置步长的自增
127.0.0.1:6379> incrby views 5
(integer) 6
  • 设置步长的自减
127.0.0.1:6379> decrby views 5
(integer) 1

range

  • 截取部分字符串
127.0.0.1:6379> set key1 hello,kuangshen
OK
127.0.0.1:6379> get key1
"hello,kuangshen"
127.0.0.1:6379> getrange key1 0 5
"hello,"
  • 查看全部的字符串
127.0.0.1:6379> getrange key1 0 -1
"hello,kuangshen"
  • 替换指定位置的字符
127.0.0.1:6379> setrange key1 1 xx
(integer) 15
127.0.0.1:6379> get key1
"hxxlo,kuangshen"

不存在

  • 设置 存在时间
127.0.0.1:6379> setex key2 30 hello
  • 显示时间
127.0.0.1:6379> ttl key2
(integer) 20
  • 如果不存在再设置 分布式锁中常用
setnx key1 redis

批量 原子性的操作,要么一起成功,要么一起失败

  • 批量设置值
127.0.0.1:6379> mset k1 v1 k2 v2 k3 v3
OK
127.0.0.1:6379> keys *
1) "k3"
2) "k2"
3) "k1"
  • 不存在则批量设置
127.0.0.1:6379> msetnx k4 v4 k1 v1
(integer) 0
127.0.0.1:6379> get key4
(nil)

例子

127.0.0.1:6379> set user:1 {name:hjz,age:3}
OK

改进:

127.0.0.1:6379> mset user:1:name hjz user:1:age 20
OK
127.0.0.1:6379> mget user:1:name user:1:age
1) "hjz"
2) "20"

先获取再设置 更新

  • 先获取再设置
127.0.0.1:6379> getset db redis
(nil)
127.0.0.1:6379> get db
"redis"
127.0.0.1:6379> getset db mongdb
"redis"
127.0.0.1:6379> get db
"mongdb"

CAS 比较再交换

String类型的数据例子:

  • 计数器
  • 统计多单位的数量
  • 对象缓存存储

List

列表--栈--队列--阻塞队列

所有的list命令都是l开头的

  • 添加列表 头部添加
127.0.0.1:6379> lpush list one
(integer) 1
127.0.0.1:6379> lpush list two
(integer) 2
127.0.0.1:6379> lpush list three
(integer) 3
  • 得到对应的列表
127.0.0.1:6379> lrange list 0 2
1) "three"
2) "two"
3) "one"
  • 尾部添加值
127.0.0.1:6379> rpush list four
(integer) 4
127.0.0.1:6379> lrange list 0 -1
1) "three"
2) "two"
3) "one"
4) "four"

下标 index

posted on 2022-06-24 23:06  Steam残酷  阅读(106)  评论(0)    收藏  举报