0

0

java:Redis是干什么的

怪我咯

怪我咯

发布时间:2017-06-26 11:45:14

|

4949人浏览过

|

来源于php中文网

原创

 

一 概述

1.Redis

Redis是使用C语言编写的基于内存且支持持久化的、高性能的key-value的noSQL数据库,主要储存访问量较大、更改频繁、安全要求不高的数据。

2.NoSQL

非关系型数据库。关系型数据库是基于关系模型建立的数据库,关系模型体现的是现实世界中实体间的关联关系。

3.BSD协议

BSD开源协议是一个给予使用者极大自由的协议,使用者可以修改源码,发布修改后的代码。

4.消息中间件

支持与保障分布式应用程序间同步或者异步收发消息的中间件。

立即学习Java免费学习笔记(深入)”;

5.消息队列

为了有效地控制消息的收发过程而在消息中间件中内置的存储消息的数据结构,采用队列,先进先出。

6.SOA

Service-Oriented Architecture,面向服务的架构,将应用程序分为若干个粗粒度、松耦合的应用模块,再通过中立的接口将这些模块联系起来。

二 key命名

key01::key02:多层,相邻层用:隔开

三 常用操作

  • redis-server.exe redis-windows-conf:启动服务器。

  • redis-cli.exe -h 127.0.0.1 -p 6379:通过IP与端口连接某个redis服务。

  • keys *:查看当前数据库中所有的key。

  • config get *:获取全部配置信息。

  • help command:查看操作含义。

  • help @string:查看string全部操作。

  • rename key01 key02:为key重命名。

  • type key:获取数据类型。

  • del key:删除key。

  • flushdb:清空当前数据库。

  • flushall:清空所有数据库。

四 string

1.增

  • set key value:赋值。

  • mset key01 value01 key02 value02:为多个键赋值,具有原子性,同时成功,同时失败。

  • set key value nx:只有在键不存在时才可以设置。

  • set key value xx:只有在键存在时才可以设置。

  • set key value ex seonds:设置键的超时。

  • getset key value:先取值,后赋值。

2.删

del key:删除key。

3.改

  • incr key:增1。

  • incrby key increment:增指定的量。

  • incrbyfloat key increment:增float型数据指定的量。

  • decr key:减1。

  • decrby key decrement:减指定的量。

4.查

  • get key:取值。

  • strlen key:获取字符串长度。

  • exists key:存在返回1,不存在返回0.

5.索引

从头开始,索引从0开始,1,2....
    从尾开始,索引从-1开始,-2.-3...

  •     setrange key index value:从index位置开始替换。

  •     getrange key begin end:获取指定索引区间的值。

  •     getrange key 0 -1:获取全部。

五 LinkedList

 1.LinkedList,双向链表,查询效率低,增删效率高。

  2.增

  •    LPUSH key value01 value02:从左侧压入元素。

  •     RPUSH key value02 value02:从右侧压入元素。

  3.删除

  •    LPOP KEY:从左侧弹出一个元素,相当于从list中删除该元素。

  •     RPOP KEY:从右侧弹出一个元素。

  • ltrim key start end :删除指定范围外的元素。

    lrem key count value:删除链表中值为value的元素count个。

  •     count>0:从左侧开始删除。

  •     count

  •     count=0:删除全部。

  4.改

   LINSERT key before/after oldValue newValue:在指定元素前后插入元素,如果指定元素不存在,则不进行任何操作。如果指定元素存在多个,只操作第一个元素。

    RPOPLPUSH key01 key02:从key01右侧弹出一个元素压入key02左侧。

  5.查

    llen key:长度即列表中元素个数。

  6.索引

   从左至右,从0开始;从右至左,从-1开始。

  •     LRANGE key start end:获取指定索引区间的元素。

  •     LRANGE key 0 -1:获取全部元素。

  •     LINDEX key index:获取指定索引位置的值。

  •     LSET key index value:设置指定索引位置的值。

六 hash

 key值空间存储的不仅仅是key值,还有其他信息,比如超时时间,因此key占用空间较大,应该减少key的数目,把相关数据存放到同一个key中,这样就产生了数据类型hash,hash相当于HashMap。

  在hash中,超时时长只能设定在key上,不能设定在field上。

  1.增

  •    hset key field value:为key中的一个字段赋值。

  •     hmset key field01 value01 field02 value02:同时为多个字段赋值。

  2.删

  •    hdel key field:删除key中指定字段。

  3.修改

  •    hincrby key filed increment:增加某个整数字段。

  •     hincrbyfloat field increment:增加某个浮点型字段的值。

  4.查

  •     hget key field:获取key中指定字段的值。

  •     hmget key field01 field02 :获取多个字段的值。

  •     hgetall key:获取所有字段及其对应的值。

  •     hkeys key:获取所有字段名。

  •     kvals key:获取所有字段的值。

  •     hexists key field:判断key中是否存在指定字段。

    手机在线人工冲值
    手机在线人工冲值

    说明:我不知道这个系统还能用到什么地方!他的运作方式是这样的,客户在其他地方比如掏宝购买了 你得卡,然后在你的网站进行冲值,你得有人登陆并看着后台,如果有人冲值,就会刷出记录,手工冲值完毕后,你得点击 [冲值完毕],客户的页面 就会返回 冲值信息!安装:上传所有文件,倒入(sql.txt)mysql数据库,使用myphpadminphplib 777phplib/sys.php 777phplib

    下载
  •     hlen key:获取key中字段数目。

七 set

 无序,不可重复。所谓无序就是不同时间查询同一集合,同一排序处元素不同。

  1.增

  •    sadd key value01 vlaue02:添加元素。

  2.删

  •    srem key value01 value02:删除元素。

  •     spop key:随机移除一个元素。

  3.查

  •    smembers key:获取全部元素

  •     srandmember key:随机返回一个元素。

  •     scard key:返回元素个数。

  •     sismember key value:判断value是否存在。

  4.交并集操作

   交并集操作并不会删除被操作集合中的元素。

  •     sdiff key01 key02:求差集,从key01中删除key02具有的元素,只是一个操作,不会删除key01中的元素。

  •     sdiffstore destination key01 key02:将差集存入指定集合中。

  •     suinon key01 key02:求并集。

  •     sninonstore destination key01 key02:将并集结果存到指定集合中。

  •     sinter key01 key02:求交集。

  •     sinterstore destination key01 key02:获取交集并存储到指定集合中。

八 sortedset

 有序集合,有序的原因,每一个元素都都关联一个分值,根据分值排序。

  1.增

  •    zadd key score01 value01 score02 value02。

  2.删

  •    zrem key value:删除指定元素。

  •     zremrangebyrank key start end:删除指定排序区间的元素。

  •     zremrangebyscore key min max:删除指定分值区间的元素。

  3.改

  •    zincrby key increment value:修改分值。

  •     zrank key value:获取排序,从小到大,从0开始。

  •     zrevrank key value:获取排序,从大到小,从0开始。

  4.查

  •    zscore key value01:获取分值。

  •     zcard key:获取集合中元素数目。

  •     zrange key start end [withscores]:获取指定索引区间的值。

  •     zrangebyscore key min max [limit offset count]:获取分值在指定区间的值,limit用于从指定偏移处截取count个数据。min前可以加(表示开区间,只能加载min上。

  •     zcount key min max:获取指定分值区间内元素个数。

  5.并集

zunionstore destination numKeys key[key...] weights weight aggregate max/min/sum
  • destination:并集结果存储的集合。

  • numKey:参与操作的集合数目。

  • weights:权重,即分值参与运算的百分比,为每一个集合分别指定。

  • aggregate:整合策略。

  • zinterstore destination numKeys key[key...] weights weight aggregate max/min/sum:交集操作。

九 Rdis持久化

1.什么是持久化?

将数据保存到硬盘中的过程叫做持久化。

2.Redis持久化方式

  • RDB: Redis DB,将所有数据以二进制形式保存到dump.rdb文件中,默认开启。

  • AOF: AppendOnlyFile,将对数据库的修改操作保存到文件中,默认关闭。

3.RDB

RDB持久化会生成一个dump.rdb文件,覆盖原有文件。RDB方式

  • 用户发出save操作:阻塞服务器。

  • 用户发出bgsave操作:后台执行,不会阻塞服务器。原理是创建一个子线程用来生成持久化文件。

  • 在配置文件中配置,满足指定条件自动持久化,这是常用方式。配置条件:save ,在指定的时间内至少发生指定次数的写操作,才执行bgsave操作,生成rdb文件。

RDB持久化方式每次都将数据库中的全部数据保存到硬盘当中,耗费系统资源,不能频繁执行,为了保证RDB间隔时间内数据的安全,可以并行使用AOF持久化方式。

4.AOF

⑴系统将内存中的数据写入文件的执行过程:先将数据写入缓冲区,缓冲区满后,再将缓冲区里的内容写入文件。

 ⑵将对数据库的修改操作追加到文件当中,先执行的操作在前面。

⑶AOP的几种方式

  • always:每执行一个修改操作,都立即写入文件。

  • everysec:每隔1秒,将修改操作写入文件一次,默认值。

  • no:由系统具体,缓冲区满后再写入文件。

⑷AOP文件的重写

为了避免AOP文件过大,可以重写AOP文件,将多个操作合并为一个操作。
      重写方式:
第一种方式,BGREWRITEAOP:用于发送该操作,重写AOP文件。
第二种方式,设定配置条件,满足条件时自动重写,以下是重写条件:

auto-aof-rewrite-percentage 100
auto-aof-rewrite-min-size 64mb

当AOP文件大小达到某个值时,重写。

十 集群

1.一个Redis服务可以有多个该服务的复制品,这个Redis服务叫做master服务,其他复制品叫做slave服务。

2.master服务会将自己的数据同步给slave服务。

3.master服务既可以读写,slave服务只可以读。

4.将一个服务设定为slave服务有两种方式:

  • 客户发出slaveof masterip masterport。

  • 在配置文件中配置:slaveof masterip masterport。

5.可以在配置文件取消设定slave的操作,也可以在由客户取消:slaveof no one

6.主从复制存在的问题
只有一个master服务器执行写操作,如果master服务器出现故障,写操作就无法执行。

十一 sentinal哨兵机制

   1.什么是哨兵机制?

     为主服务器配置一个监听器,这个监听器称作哨兵,当主服务器发生故障时,哨兵自动将某一个从服务器提升为主服务器,从而保证服务器不间断地执行。

十二 Twemproxy集群

   1.在主从复制中,写任务依然由一个节点承担,写压力并没有解决,因此产生了Twemproxy集群机制,用户向代理发出请求,由代理将写任务分配到服务器池中的节点。

    2.Twenproxy基本原理

     服务器池中的每一个服务器都有一个接收区间,客户发送请求到代理后,代理获取key的hashcode,该值落在哪个区间,就调用哪个服务器。

    3.缺点

     有一个中心对象,即代理,如果代理出现问题,整个Redis服务就无法使用,解决方式就是去中心化,使得某一部分出现故障,整体依然可以运行。

十三 原生集群模式

   1.什么是原生集群模式?

     多个Redis主服务器构成一个集群,其中每一个Redis主服务器都叫做一个节点,节点之间相互通信,节点可以有自己的从服务器来分担读的压力。

    2.节点之间通信的目的之一

     每一个节点都可以与其他全部节点通信,充当sentinal角色监控其他节点的运行状况,当某一个节点发生故障时其他多个节点综合信息,如果判断该节点无法正常工作,提升该节点的一个从服务器为节点。

十四 Jedis

   1.在java中访问Redis服务器,需要导入架包jedis.jar。

    2.Jedis是java语言中连接Redis服务器的客户端工具。

    3.Jedis基本保留了命令行访问Redis服务器的方法。

    4.正像连接关系型数据库最好建立连接池一样,连接Rdis数据库也最好建立连接池,建立连接池时使用的类JedisPoolConfig/JedisPool。

    5.单个Redis服务器压力较大,因此可以构建Redis服务器集群,构建集群使用时使用的类HostAndPort/JedisCluster。

 

相关文章

java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

616

2026.02.13

微博网页版主页入口与登录指南_官方网页端快速访问方法
微博网页版主页入口与登录指南_官方网页端快速访问方法

本专题系统整理微博网页版官方入口及网页端登录方式,涵盖首页直达地址、账号登录流程与常见访问问题说明,帮助用户快速找到微博官网主页,实现便捷、安全的网页端登录与内容浏览体验。

194

2026.02.13

Flutter跨平台开发与状态管理实战
Flutter跨平台开发与状态管理实战

本专题围绕Flutter框架展开,系统讲解跨平台UI构建原理与状态管理方案。内容涵盖Widget生命周期、路由管理、Provider与Bloc状态管理模式、网络请求封装及性能优化技巧。通过实战项目演示,帮助开发者构建流畅、可维护的跨平台移动应用。

91

2026.02.13

TypeScript工程化开发与Vite构建优化实践
TypeScript工程化开发与Vite构建优化实践

本专题面向前端开发者,深入讲解 TypeScript 类型系统与大型项目结构设计方法,并结合 Vite 构建工具优化前端工程化流程。内容包括模块化设计、类型声明管理、代码分割、热更新原理以及构建性能调优。通过完整项目示例,帮助开发者提升代码可维护性与开发效率。

20

2026.02.13

Redis高可用架构与分布式缓存实战
Redis高可用架构与分布式缓存实战

本专题围绕 Redis 在高并发系统中的应用展开,系统讲解主从复制、哨兵机制、Cluster 集群模式及数据分片原理。内容涵盖缓存穿透与雪崩解决方案、分布式锁实现、热点数据优化及持久化策略。通过真实业务场景演示,帮助开发者构建高可用、可扩展的分布式缓存系统。

54

2026.02.13

c语言 数据类型
c语言 数据类型

本专题整合了c语言数据类型相关内容,阅读专题下面的文章了解更多详细内容。

29

2026.02.12

雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法
雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法

本专题系统整理雨课堂网页版官方入口及在线登录方式,涵盖账号登录流程、官方直连入口及平台访问方法说明,帮助师生用户快速进入雨课堂在线教学平台,实现便捷、高效的课程学习与教学管理体验。

15

2026.02.12

豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法
豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法

本专题汇总豆包AI官方网页版入口及在线使用方式,涵盖智能写作工具、图片生成体验入口和官网登录方法,帮助用户快速直达豆包AI平台,高效完成文本创作与AI生图任务,实现便捷智能创作体验。

598

2026.02.12

PostgreSQL性能优化与索引调优实战
PostgreSQL性能优化与索引调优实战

本专题面向后端开发与数据库工程师,深入讲解 PostgreSQL 查询优化原理与索引机制。内容包括执行计划分析、常见索引类型对比、慢查询优化策略、事务隔离级别以及高并发场景下的性能调优技巧。通过实战案例解析,帮助开发者提升数据库响应速度与系统稳定性。

56

2026.02.12

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
进程与SOCKET
进程与SOCKET

共6课时 | 0.4万人学习

Redis+MySQL数据库面试教程
Redis+MySQL数据库面试教程

共72课时 | 6.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号