Redis的基本知识
Redis:
1. 概念:开源的高性能键值对数据库,
提供多种键值对数据类型:字符串、(离散)哈希、列表、集合、有序集合类型
内部储存与持久化:内存的读写速度远高于磁盘;自身提供持久化机制(RDB、AOF)
Redis的字符串类型
字符串类型是Redis中最基本的数据类型,可以储存任何形式的字符串:二进制数据,JSON化的对象、字节数组等。一个字符串类型的最大存储空间为512M
2. 对数据的操作命令:
SET key1 value1
GET key1
EXPIRE key1 10 设置key1的生命周期为10秒
TTL key1 查看key1的剩余生命周期,返回:-1代表永久,-2代表已经失效
PEXPIRE key1 10000 设置key1的生命周期为10000毫秒
MSET key1 val1 key2 val2 设置多个键值对
MGET key1 key2 获取多个键所对应的值
APPEND key1 234 向key1的末尾追加234,如不存在这个键则相当于设置这个键值,返回结果是追加后字符串的总长度
STRLEN key1 获得key1的值的字符串的总长度,不存在返回0
存储的是整数时:
INCR key1 在原来的值上递增1
INCRBY key1 5 在原来的值上递增5
3. Redis客户端的使用:Jedis
方法1:
Jedis jedis = new Jedis(“127.0.0.1”,6379 ); 新建,设置IP、端口
//Jedis.auth(“123”); 配置访问密码(如有密码需要这句代码,另外只有全局密码,无针对各数据库的)
Jedis.set(“key1”,”val1”); 设置键值对
String value = jedis.get(“key1”); 根据键获取值
Jedis.close(); 关闭连接
方法2:连接池
JedisPoolConfig jedisPoolConfig = new JedisPoolConfig(); 新建连接池配置对象
jedisPoolConfig.setMaxTotal(50); 设置最大连接数
JedisPool jedisPool = new JedisPool(jedisPoolConfig,”127.0.0.1”,6379); 新建连接池对象
Jedis jedis = jedisPool.getResource(); 从连接池中获取连接
//Jedis.auth(“123”); 如有密码需要配置
String value = jedis.get(“key1”);
JedisPool.returnResource(jedis); 调用连接池回收连接
jedisPool.close(); 释放连接池
方法3:集群式连接池:
JedisPoolConfig jedisPoolConfig = new JedisPoolConfig(); 新建连接池配置对象
jedisPoolConfig.setMaxTotal(50); 设置最大连接数
List<JedisShardInfo> shards = new ArrayList<JedisShardInfo>; 定义集群信息
shards.add(new JedisShardInfo(“127.0.0.1”,6379));
shards.add(new JedisShardInfo(“127.0.0.1”,6380));
定义集群连接池
ShardedJedisPool shardedJedisPool = new SaradedJedisPool(jedisPoolConfig,shards);
ShardedJedis shardedJedis = null;
try{
shardedJedis = shardedJedisPool.getResource(); 从连接池获取jedis分片对象
}
相关操作………..
catch(Exception e){
e.printStakTrace();
} finally{
If(null != shardedJedis){
shardedJedis.close() 将jedis分片放回池中
}
}
sharedeJedisPool.close();
4. 多节点Redis(无集群的实现)

缺点:该方法在添加新的Redis节点时会出现问题,因为它会重新计算分配hash值,有可能会获取不到原来的值。
5. Hash结构
5.1. 结构说明

注意:Hash中存储的字段和值只能是字符串。
5.2. 基本命令使用
HSET key1 field1 val1
HGET key1 field1
HMSET key1 field1 val1 field2 val2
HMGET key1 field1 field2
HGETALL key
注意:HSET不会区分插入和更新操作,如操作是插入则返回1,更新返回0
5.3. Jedis中操作Hash结构

5.4. 判断字段是否存在

5.5. 增长和删除

5.6. 只获取字段名或字段值

5.7. 获取字段数量

5.8. Redis配置文件

达到内存限制后的处理策略:

5.9. 相关的推荐
Redis内存使用优化与存储
http://www.infoq.com/cn/articles/tq-redis-memory-usage-optimization-storage
Redis复制与可扩展集群搭建
http://www.infoq.com/cn/articles/tq-redis-copy-build-scalable-cluster
Redis 设计与实现
https://redisbook.readthedocs.org/en/latest/
SpringSource发布Spring Data Redis 1.0.0
http://www.infoq.com/cn/news/2012/01/spring-data-redis-1-0-0
Redis内存存储结构分析
http://www.searchtb.com/2011/05/redis-storage.html
6. Redis的持久化

6.1. RDB方式

6.1.1. 如何禁用RDB持久化
禁用RDB的触发条件即可。

6.1.2. RDB持久化过程

6.2. AOF方式
6.2.1. 原理

开启AOF:

6.2.2. AOF文件内容

注意:查询数据的操作不做记录。
6.2.3. AOF文件的优化

优化后:

6.2.4. 文件到磁盘的机制

参考资料:《传智播客》
Redis的基本知识的更多相关文章
- 新手初学Redis之基础知识命令
笔者最初接触Redis是因为了解了一些nosql方面的知识,觉得nosql是一个很有意思的方面.像其中的mongodb,redis等等.当初也没有深入的去了解Redis,直到自己前段时间在写一个web ...
- $Django redis内存数据库 (知识回顾cmd切换目录)
知识小回顾 #切换盘 C:\Users\WangDong>f: F:\> #切换文件 F:\>cd redis F:\redis> #返回上一级 F:\DJ\dj8>cd ...
- Redis的好处知识
参考文章 http://www.cnblogs.com/wupeiqi/articles/5132791.html 使用Redis有哪些好处? () 速度快,因为数据存在内存中,类似于HashMap, ...
- redis相关缓存知识
Redis redis是一个key-value存储系统.和Memcached类似,它支持存储的value类型相对更多,包括string(字符串).list(链表).set(集合).zset(sorte ...
- Redis系列-冷知识
下面是一些看了,但觉得用处不大,不记下又可惜的东西. Redis删除过期数据 redis通过expire/expireat(秒为单位)或者pexpire/pexpireat(毫秒为单位)来设置key的 ...
- Redis集群知识解析
redis集群在启动的时候就自动在多个节点间分好片.同时提供了分片之间的可用性:当一部分redis节点故障或网络中断,集群也能继续工作.但是,当大面积的节点故障或网络中断(比如大部分的主节点都不可用了 ...
- Redis Cluster 理论知识
http://www.ttlsa.com/redis/redis-cluster-theoretical-knowledge/ Redis 集群的 TCP 端口(Redis Cluster TCP p ...
- redis的相关知识
1. 依赖包安装 pom.xml 加入: <!-- redis cache related.....start --> <dependency> <groupId> ...
- Redis数据结构底层知识总结
Redis数据结构底层总结 本篇文章是基于作者黄建宏写的书Redis设计与实现而做的笔记 数据结构与对象 Redis中数据结构的底层实现包括以下对象: 对象 解释 简单动态字符串 字符串的底层实现 链 ...
随机推荐
- Navicat无法连接SqlServer数据库
一.起因 原来安装过SqlServer 2008 R2,后来不用卸载了(没清理,单卸载),之后一直通过Navicat远程连接服务器的SqlServer使用. 前两天工作需要,又安装了SqlServer ...
- ModelBiner不验证某个属性
问题 使用MVC的同学十有八九都会遇到这个错误:从客户端(Content="<script>...")中检测到有潜在危险的Request.Form 值. 这个错误是在请 ...
- 二、Python数据类型(一)
一.Python的基本输入与输出语句 (一)输出语句 print() 示例: print('你好,Python') print(4+5) a = 10 print(a) 输出的内容可以是字符串,变量, ...
- linux下的启停脚本
linux下的根据项目名称,进行进程的启停脚本 #!/bin/bash JAVA=/usr/bin/java APP_HOME=/opt/program/qa/wechat APP_NAME=prog ...
- DAY16 模块和包的导入
一.包 1.包的定义 包:就是一系列模块的结合体 2.重点 1.包中一定要有一个专门来管理包中所有模块的文件 2.包名:存放一系列模块的文件夹名字 3.包名(包对象)存放的是管理模块的那个文件的地址, ...
- (转)如何在maven的pom.xml中添加本地jar包
转载自: https://www.cnblogs.com/lixuwu/p/5855031.html 1 maven本地仓库认识 maven本地仓库中的jar目录一般分为三层:图中的1 2 3分别如下 ...
- c代码写数据到二进制的bin文件中
需要将数据写入到bin文件中,打开该文件是一堆乱码,增加数据的保密性 例如:要写入的数据为一个字符串,加上若干个int型整数 #define _CRT_SECURE_NO_WARNINGS #incl ...
- [CQOI2014]数三角形
[CQOI2014]数三角形 给定\(n\times m\)的网格,求三个点在其格点上的三角形个数,1<=m,n<=1000. 解 法一:直接 显然为组合计数问题,关键在于划分问题,注意到 ...
- 关于spark中DatatFrame函数操作中isin方法的使用
需求: 1.需要从一张mysql数据表中获取并筛选数据 2.通过spark将该表读进来,形成一个df:DataFrame,有一个集合 val list = List[String]("小李& ...
- English trip V2 - 3. A Healthy Diet Teacher:Corrine Key:各种前缀 im- un- in- re- over- under-
In this lesson you will learn to talk about foot and drink for a healthy diet. 课上内容(Lesson) What do ...