IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> Redis基础(上)(超简洁)(适合温习)(笔记) -> 正文阅读

[大数据]Redis基础(上)(超简洁)(适合温习)(笔记)

1. Redis 简介

1.1 NoSQL概念

(1)概念

NoSQL:即 Not-Only SQL( 泛指非关系型的数据库),作为关系型数据库的补充。

(2)特征

可扩容,可伸缩。(因为不存在必然的数据关系)

大数据量下高性能。(因为你不走磁盘IO,你走的是内存,性能肯定要比磁盘IO的性能快一些)

灵活的数据模型、高可用。

1.2 Redis概念

?(1)就记它是NoSQL特别流行的一种

1.3 Redis 的下载与安装

?(1)网上教程自己找

1.4 Redis服务器启动

1.4.1 Redis服务器启动

????????启动服务器——参数启动 redis-server [--port port]

????????启动服务器——配置文件启动 redis-server config_file_name

1.4.2 Redis客户端启动

????????启动客户端 redis-cli [-h host] [-p port]

注意:服务器启动指定端口--port,客户端启动指定端口-p。-的数量不同。

1.4.3 Redis基础环境设置约定

????????创建配置文件存储目录 mkdir conf

????????创建服务器文件存储目录(包含日志、数据、临时配置文件等)mkdir data

????????创建快速访问链接 ln -s redis-5.0.0 redis

1.5 配置文件启动与常用配置

1.5.1 服务器端设定

????????设置服务器以守护进程的方式运行,开启后服务器控制台中将打印服务器运行信息(同日志内容相同)daemonize yes|no

????????绑定主机地址 bind ip

????????设置服务器端口 port port

????????设置服务器文件保存地址 dir path

1.5.2 客户端配置

????????服务器允许客户端连接最大数量,默认0,表示无限制

????????????????maxclients count

????????客户端闲置等待最大时长,达到最大值后关闭对应连接。关闭,设置为 0

????????????????timeout seconds

1.5.3 日志配置

????????设置服务器以指定日志记录级别?loglevel debug|verbose|notice|warning

????????日志记录文件名?logfile filename

注意:开发期设置为verbose,生产环境中配置为notie,

1.6 Redis基本操作

1.6.2 信息读写

设置 key,value 数据 set key value

根据 key 查询对应的 value,如果不存在,返回空? get key

1.6.3 帮助信息

获取命令帮助文档 help [command]

获取组中所有命令信息名称 help [@group-name]

1.6.4 退出命令行客户端模式

退出客户端 quit 或者 exit

快捷键 Ctrl+C

2. 数据类型

2.1?string数据类型

(1)存储的数据:单个数据,最简单的数据存储类型,也是最常用的数据存储类型。。

2.2.3 string 类型数据的基本操作

(1)基础指令

添加/修改数据添加/修改数据 set key value

获取数据 get key

删除数据 del key

判定性添加数据 setnx key value

添加/修改多个数据 mset key1 value1 key2 value2 …

获取多个数据 mget key1 key2 …

获取数据字符个数(字符串长度)strlen key

追加信息到原始信息后部(如果原始信息存在就追加,否则新建)append key value

2.2?string 类型数据的扩展操作

2.2.1 string 类型数据的扩展操作

设置数值数据增加指定范围的值

?????????incr key ???????

?????????incrby key increment ???????

?????????incrbyfloat key increment

设置数值数据减少指定范围的值

????????decr key ???????

????????decrby key increment

设置数据具有指定的生命周期

????????setex key seconds value

????????psetex key milliseconds value

2.2.2 string 类型数据操作的注意事项

(1)数据操作不成功的反馈与数据正常操作之间的差异

????????表示运行结果是否成功

????????????????(integer) 0 → false 失败

????????????????(integer) 1 → true 成功

????????表示运行结果值

????????????????(integer) 3 → 3 3个

????????????????(integer) 1 → 1 1个

(2)数据未获取到时,对应的数据为(nil),等同于null

(3)数据最大存储量:512MB

(4)string在redis内部存储默认就是一个字符串,当遇到增减类操作incr,decr时会转成数值型进行计算

(5)按数值进行操作的数据,如果原始数据不能转成数值,或超越了redis 数值上限范围,将报错 9223372036854775807(java中Long型数据最大值,Long.MAX_VALUE)

(6)redis所有的操作都是原子性的,采用单线程处理所有业务,命令是一个一个执行的,因此无需考虑并发带来的数据影响.


2.3hash的基本操作

2.3.1?hash?类型

?

快速理解:hash就是存了一个key value的存储空间

注意:底层使用哈希表结构实现数据存储

如果field数量较少,存储结构优化为类数组结构

如果field数量较多,存储结构使用HashMap结构

2.3.2?hash 类型数据的基本操作

添加/修改数据 hset key field value

获取数据 hget key field或者?hgetall key

删除数据 hdel key field1 [field2]

设置field的值,如果该field存在则不做任何操作 hsetnx key field value

添加/修改多个数据 hmset key field1 value1 field2 value2 …

获取多个数据 hmget key field1 field2 …

获取哈希表中字段的数量 hlen key

获取哈希表中是否存在指定的字段 hexists key field

2.4?hash的拓展操作

2.4.1 hash 类型数据扩展操作

获取哈希表中所有的字段名或字段值

????????hkeys key
????????hvals key

设置指定字段的数值数据增加指定范围的值

? ? ? ? hincrby key field increment
????????hincrbyfloat key field increment

2.4.2 hash类型数据操作的注意事项

(1)hash类型中value只能存储字符串

(2)hgetall 操作可以获取全部属性,如果内部field过多,遍历整体数据效率就很会低,有可能成为数据访问瓶颈。

2.5?list基本操作

2.5.1 list 类型

? ? ? ? 类似java中的list

2.5.2 list 类型数据基本操作

添加/修改数据

????????lpush key value1 [value2] ……

????????rpush key value1 [value2] ……

获取数据

????????lrange key start stop

????????lindex key index

????????llen key

获取并移除数据

????????lpop key

????????rpop key

2.6?list扩展操作

2.6.1 list 类型数据扩展操作

移除指定数据

????????lrem key count value

规定时间内获取并移除数据

????????blpop key1 [key2] timeout

????????brpop key1 [key2] timeout

????????brpoplpush source destination timeout

2.6.2 list 类型数据操作注意事项

(2)list具有索引的概念,但是操作数据时通常以队列的形式进行入队出队操作,或以栈的形式进行入栈出栈操作

(3)获取全部数据操作结束索引设置为-1

(4)list可以对数据进行分页操作,通常第一页的信息来自于list,第2页及更多的信息通过数据库的形式加载

2.7?set 基本操作

2.7.1 set类型

set类型:与hash存储结构完全相同,仅存储键,不存储值(nil),并且值是不允许重复的。

2.7.2 set类型数据的基本操作

添加数据?sadd key member1 [member2]

获取全部数据?smembers key

删除数据 srem key member1 [member2]

获取集合数据总量 scard key

判断集合中是否包含指定数据 sismember key member

随机获取集合中指定数量的数据 srandmember key [count]

随机获取集中的某个数据并将该数据移除集合 spop key [count]

2.8?set 类型数据的扩展操作

2.8.1 set 类型数据的扩展操作

求两个集合的交、并、差集

????????sinter key1 [key2 …] ?

????????sunion key1 [key2 …] ?

???????? sdiff key1 [key2 …]

求两个集合的交、并、差集并存储到指定集合中

????????sinterstore destination key1 [key2 …] ?

????????sunionstore destination key1 [key2 …] ?

????????sdiffstore destination key1 [key2 …]

将指定数据从原始集合中移动到目标集合中 smove source destination member

2.8.2 set 类型数据操作的注意事项

set 类型不允许数据重复,如果添加的数据在 set 中已经存在,将只保留一份。

set 虽然与hash的存储结构相同,但是无法启用hash中存储值的空间。

3. 常用指令

3.1 key 操作分析

3.1.1?key 基本操作

删除指定key del key

获取key是否存在 exists key

获取key的类型 type key

排序 sort

改名

rename key newkey

renamenx key newkey

3.1.2?key 扩展操作(时效性控制)

为指定key设置有效期

????????expire key seconds
????????pexpire key milliseconds
????????expireat key timestamp
????????pexpireat key milliseconds-timestamp

获取key的有效时间

????????ttl key
????????pttl key

切换key从时效性转换为永久性 persist key

3.1.3?key 扩展操作(查询模式)

查询key keys pattern

查询模式规则

*匹配任意数量的任意符号 ? 配合一个任意符号 [] 匹配一个指定符号

keys *  keys ?  查询所有
it*  keys ? ? ? 查询所有以it开头
*heima ? ? ? ?  查询所有以heima结尾
keys ??heima ?  查询所有前面两个字符任意,后面以heima结尾 查询所有以
keys user:? ? ? user:开头,最后一个字符任意
keys u[st]er:1  查询所有以u开头,以er:1结尾,中间包含一个字母,s或t

3.2 数据库指令

3.2.1?数据库的基本操作

切换数据库 select index

3.2.4 数据库扩展操作

数据移动?move key db

数据总量 dbsize

数据清除 flushdb flushall

4. Jedis

简而言之:Java整合redis

(1)maven依赖

<dependency>
<groupId>redis.clients</groupId>
<artifactId>jedis</artifactId>
<version>2.9.0</version>
</dependency>

API文档

http://xetorthio.github.io/jedis/

public class JedisTest {

    public static void main(String[] args) {
        //1.获取连接对象
        Jedis jedis = new Jedis("192.168.40.130",6379);
        //2.执行操作
        jedis.set("age","39");
        String hello = jedis.get("hello");
        System.out.println(hello);
        jedis.lpush("list1","a","b","c","d");
        List<String> list1 = jedis.lrange("list1", 0, -1);
        for (String s:list1 ) {
            System.out.println(s);
        }
        jedis.sadd("set1","abc","abc","def","poi","cba");
        Long len = jedis.scard("set1");
        System.out.println(len);
        //3.关闭连接
        jedis.close();
    }
}

4.2 Jedis简易工具类开发

简单来说,就是做一个创建Jedis的这样的工具。

4.2.1 基于连接池获取连接

JedisPool的构造器如下:

public JedisPool(GenericObjectPoolConfig poolConfig, String host, int port) {
this(poolConfig, host, port, 2000, (String)null, 0, (String)null);
}

4.2.2 封装连接参数

创建jedis的配置文件:jedis.properties

jedis.host=192.168.40.130 ?
jedis.port=6379 ?
jedis.maxTotal=50 ?
jedis.maxIdle=10

4.2.3 加载配置信息

创建JedisUtils:使用静态代码块初始化资源

public class JedisUtils {
 ? ?private static int maxTotal;
 ? ?private static int maxIdel;
 ? ?private static String host;
 ? ?private static int port;
 ? ?private static JedisPoolConfig jpc;
 ? ?private static JedisPool jp;
?
 ? ?static {
 ? ? ? ?ResourceBundle bundle = ResourceBundle.getBundle("redis");
 ? ? ? ?maxTotal = Integer.parseInt(bundle.getString("redis.maxTotal"));
 ? ? ? ?maxIdel = Integer.parseInt(bundle.getString("redis.maxIdel"));
 ? ? ? ?host = bundle.getString("redis.host");
 ? ? ? ?port = Integer.parseInt(bundle.getString("redis.port"));
 ? ? ? ?//Jedis连接池配置
 ? ? ? ?jpc = new JedisPoolConfig();
 ? ? ? ?jpc.setMaxTotal(maxTotal);
 ? ? ? ?jpc.setMaxIdle(maxIdel);
 ? ? ? ?jp = new JedisPool(jpc,host,port);
 ?  }
?
}

4.2.4 获取连接

public static Jedis getJedis(){
    Jedis jedis = jedisPool.getResource();
    return jedis;
}

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-02-16 13:11:15  更:2022-02-16 13:11:39 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/17 0:14:06-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码