Redis简述
Redis 简单介绍
Redis 是全然开源免费的。遵守BSD协议,是一个高性能的key-value数据库。
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与其它key-value存储有什么不同?
- Redis有着更为复杂的数据结构而且提供对他们的原子性操作。这是一个不同于其它数据库的进化路径。
Redis的数据类型都是基于基本数据结构的同一时候对程序猿透明,无需进行额外的抽象。
 - Redis执行在内存中可是能够持久化到磁盘。所以在对不同数据集进行快速读写时须要权衡内存,应为数据量不能大于硬件内存。
在内存数据库方面的还有一个长处是, 相比在磁盘上同样的复杂的数据结构,在内存中操作起来非常easy,这样Redis能够做非常多内部复杂性非常强的事情。 同一时候,在磁盘格式方面他们是紧凑的以追加的方式产生的,由于他们并不须要进行随机訪问。
 
redis的安装
下载安装包。博主採用的是redis-3.0.5.tar.gz,能够在这里下载. 
安装步骤:
tar -zvxf redis-3.0.5.tar.gz
cd redis-3.0.5
make 
redis服务端开启
./redis-server
开启之后例如以下图所看到的: 
这样的方式是启动的redis使用的是默认配置,也能够通过启动參数考古redis使用指定配置文件:
./redis-server [redis.conf的路径]
假设改动redis.conf,採用redis默认的redis.conf文件, redis默认仅仅能通过127.0.0.1:6379这个地址訪问,这样就仅仅能在本机上操作了。假设想要远程操作就不可行了。
这里须要改动redis.conf这个配置文件,在配置文件里加入相应的ip地址,这里假如加入ip地址:10.10.195.112。仅仅需在redis.conf这个配置文件里加入:
bind 10.10.195.112
bind 127.0.0.1
这样就能够远程訪问redisserver了(先配置。后开启redis服务)。
redisclient连接
./redis-cli    (本地)
./redis-cli -h [host] -p [port] -a [password] (远程server)
Jedis开发
使用java开发redis,博主使用的是jedis,须要引入jedis的jar,能够在这里下载。
还须要commons-pool.jar包 
连接
    Jedis jedis = new Jedis("10.10.195.112");
    System.out.println(jedis.ping());
输出:PONG
操作字符串
        jedis.set("name", "zzh");
        System.out.println(jedis.get("name"));
输出:zzh
操作列表
        jedis.lpush("nblist", "jj");
        jedis.lpush("nblist", "jj");
        jedis.lpush("nblist", "yy");
        jedis.lpush("nblist", "qq");
        List<String> list = jedis.lrange("nblist", 0, -1);
        int length = list.size();
        for(int i=0;i<length;i++)
        {
            System.out.println(list.get(i));
        }
输出:
qq
yy
jj
jj
获取redis中全部的键
    Set<String> set = jedis.keys("*");
    for(String key : set)
    {
        System.out.println(key);
    }
输出:
nam
name
tutorial
list
tutorial-list
nblist
tutoriallist
keyname
user
listt
zsetkey
hash-key
Redis经常使用命令
1 连接操作命令
- quit:关闭连接(connection)
 - auth:简单密码认证
 - help cmd: 查看cmd帮助。比如:help quit
 
2 持久化
- save:将数据同步保存到磁盘
 - bgsave:将数据异步保存到磁盘
 - lastsave:返回上次成功将数据保存到磁盘的Unix时戳
 - shutdown:将数据同步保存到磁盘,然后关闭服务
 
3 远程服务控制
- info:提供server的信息和统计
 - monitor:实时转储收到的请求
 - slaveof:改变复制策略设置
 - config:在执行时配置Redisserver
 
4 对key操作的命令
- exists(key):确认一个key是否存在
 - del(key):删除一个key
 - type(key):返回值的类型
 - keys(pattern):返回满足给定pattern的全部key
 - randomkey:随机返回key空间的一个
 - keyrename(oldname, newname):重命名key
 - dbsize:返回当前数据库中key的数目
 - expire:设定一个key的活动时间(s)
 - ttl:获得一个key的活动时间
 - select(index):按索引查询
 - move(key, dbindex):移动当前数据库中的key到dbindex数据库
 - flushdb:删除当前选择数据库中的全部key
 - flushall:删除全部数据库中的全部key
 
5 String
- set(key, value):给数据库中名称为key的string赋予值value
 - get(key):返回数据库中名称为key的string的value
 - getset(key, value):给名称为key的string赋予上一次的value
 - mget(key1, key2,…, key N):返回库中多个string的value
 - setnx(key, value):加入string,名称为key。值为value
 - setex(key, time, value):向库中加入string,设定过期时间time
 - mset(key N, value N):批量设置多个string的值
 - msetnx(key N, value N):假设全部名称为key i的string都不存在
 - incr(key):名称为key的string增1操作
 - incrby(key, integer):名称为key的string添加integer
 - decr(key):名称为key的string减1操作
 - decrby(key, integer):名称为key的string降低integer
 - append(key, value):名称为key的string的值附加value
 - substr(key, start, end):返回名称为key的string的value的子串
 
6 List
- rpush(key, value):在名称为key的list尾加入一个值为value的元素
 - lpush(key, value):在名称为key的list头加入一个值为value的 元素
 - llen(key):返回名称为key的list的长度
 - lrange(key, start, end):返回名称为key的list中start至end之间的元素
 - ltrim(key, start, end):截取名称为key的list
 - lindex(key, index):返回名称为key的list中index位置的元素
 - lset(key, index, value):给名称为key的list中index位置的元素赋值
 - lrem(key, count, value):删除count个key的list中值为value的元素
 - lpop(key):返回并删除名称为key的list中的首元素
 - rpop(key):返回并删除名称为key的list中的尾元素
 - blpop(key1, key2,… key N, timeout):lpop命令的block版本号。
 - brpop(key1, key2,… key N, timeout):rpop的block版本号。
 - rpoplpush(srckey, dstkey):返回并删除名称为srckey的list的尾元素。并将该元素加入到名称为dstkey的list的头部
 
7 Set
- sadd(key, member):向名称为key的set中加入元素member
 - srem(key, member) :删除名称为key的set中的元素member
 - spop(key) :随机返回并删除名称为key的set中一个元素
 - smove(srckey, dstkey, member) :移到集合元素
 - scard(key) :返回名称为key的set的基数
 - sismember(key, member) :member是否是名称为key的set的元素
 - sinter(key1, key2,…key N) :求交集
 - sinterstore(dstkey, (keys)) :求交集并将交集保存到dstkey的集合
 - sunion(key1, (keys)) :求并集
 - sunionstore(dstkey, (keys)) :求并集并将并集保存到dstkey的集合
 - sdiff(key1, (keys)) :求差集
 - sdiffstore(dstkey, (keys)) :求差集并将差集保存到dstkey的集合
 - smembers(key) :返回名称为key的set的全部元素
 - srandmember(key) :随机返回名称为key的set的一个元素
 
8 Hash
- hset(key, field, value):向名称为key的hash中加入元素field
 - hget(key, field):返回名称为key的hash中field相应的value
 - hmget(key, (fields)):返回名称为key的hash中field i相应的value
 - hmset(key, (fields)):向名称为key的hash中加入元素field
 - hincrby(key, field, integer):将名称为key的hash中field的value添加integer
 - hexists(key, field):名称为key的hash中是否存在键为field的域
 - hdel(key, field):删除名称为key的hash中键为field的域
 - hlen(key):返回名称为key的hash中元素个数
 - hkeys(key):返回名称为key的hash中全部键
 - hvals(key):返回名称为key的hash中全部键相应的value
 - hgetall(key):返回名称为key的hash中全部的键(field)及其相应的value
 
关于Jedis的具体使用将在兴许更新,欢迎关注我的博客~
Redis简述的更多相关文章
- Linux+Redis实战教程_day02_2、redis简述及安装与启动
		
2. redis简述及安装 关系型数据库(SQL): Mysql,oracle 特点:数据和数据之间,表和字段之间,表和表之间是存在关系的 例如:部门表 001部门, 员工表 001 用户表,用户 ...
 - Redis(一)Redis简述
		
一 Redis 概念 Redis是一个开源的使用ANSI C语言编写.支持网络.可基于内存亦可持久化的日志型.Key-Value数据库,和Memcached类似,它支持存储的value类型相对更多,包 ...
 - linux系统下安装jdk,mysql,tomcat  和redis 和jedis入门案例
		
Day47笔记Linux+redis入门 Day47 知识讲解:Jedis 1.Linux上jdk,mysql,tomcat安装(看着文档安装) 准备工作: 因为JDK,TOMCAT,MYSQL的 ...
 - Redis面试题(46题)
		
1.什么是Redis?简述它的优缺点? Redis 的全称是:Remote Dictionary.Server,本质上是一个 Key-Value 类型的内存数据库,很像memcached,整个数据库统 ...
 - Redis之快速入门与应用[教程/总结]
		
内容概要 因为项目中用户注册发送验证码,需要学习redis内存数据库,故而下午花了些时间进行初步学习.本博文性质属于对今日redis学习内容的小结.在看本博文前或者看完后,可以反问自己三个问题:Red ...
 - 一天五道Java面试题----第十天(简述Redis事务实现--------->负载均衡算法、类型)
		
这里是参考B站上的大佬做的面试题笔记.大家也可以去看视频讲解!!! 文章目录 1.简述Redis事务实现 2.redis集群方案 3.redis主从复制的核心原理 4.CAP理论,BASE理论 5.负 ...
 - Redis入门简述
		
Redis 是一个开源的,使用 ANSI C (C语言)编写,高性能的 Key-Value(键值对) 的 NoSQL 数据库 NoSQL = Not Only SQL,意即“不仅仅是SQL”,是一项全 ...
 - Redis持久化存储与复制功能简述
		
一.分布式系统基础理论 分布式系统的两个基础理论: 1.CAP理论 如图: Consistency(强一致性):数据一致更新,所有数据变动都是同步的.Availability(可用性):好的响应性能. ...
 - 【原】Spring整合Redis(第一篇)—SDR简述
		
1.SDR说明 Spring Data Redis(SDR),是SpringFramework提供的一套简化访问Redis的API,是对Jedis的又一层封装. SDR集成了Jedis,JRedis, ...
 
随机推荐
- Linux下编辑利器vim,vimrc,viminfo的高级用法
			
1.ci" (由 change operator 和 text-object i" 组成) 这个命令会找到当前光标所在行的下一个 " 括起来的字符串,清除引号裏面的内容, ...
 - VS:"64位调试操作花费的时间比预期要长"的一解决途径
			
解决办法之一: 在命令提示符那里打入如下命令: netsh winsock reset catalognetsh int ip reset reset.log hit 重启电脑后,即可
 - 分布式缓存技术memcached学习系列(二)——memcached基础命令
			
上文<linux环境下编译memcahed>介绍了memcahed在linux环境下的安装以及登录,下面介绍memcahed的基本命令的使用. Add 功能:往内存增加一条新的缓存记录 语 ...
 - python学习笔记——进程间通信方式对比
			
通信方式对比 管道 消息队列 共享内存 信号 开辟空间 内存 内存 内存 不开辟额外空间 读写方式 双向/单向(信息流) 先进先出(消息体) 操作内存(数值数组) 发送处理信号 效率 一般 一般 ...
 - RHCE7 管理II-6ACL的使用
			
ACL允许向文件分配细化的权限.除标准的文件所有者.组所有者.和其他文件权限之外,还可以指定用户或组,以及uid或guid确定的用户和组授予权限. 命令: ·setfacl 设置acl策略 ·getf ...
 - C#封装百度Web服务API处理包含(Geocoding API,坐标转换API)
			
1.创建基础参数类 public static class BaiduConstParams { public const string PlaceApIv2Search = "http:/ ...
 - Python2 字典 has_key() 方法
			
描述 Python2 字典 has_key() 方法用于判断键(key)是否存在于字典(D)中,如果键在字典中返回True,否则返回False. 官方文档推荐用 in 操作符,因为它更短更通俗易懂.h ...
 - php 7.1安装教程
			
一.下载地址 http://php.net/downloads.php#v7.1.9 IIS如果你使用的是PHP的FastCGI IIS,你应该使用非线程安全(NTS)版本的PHP. Apache请使 ...
 - python标准库介绍——23    UserString 模块详解
			
==UserString 模块== (2.0 新增) ``UserString`` 模块包含两个类, //UserString// 和 //MutableString// . 前者是对标准字符串类型的 ...
 - JEECG中datagrid方法自定义查询条件
			
自定义加添加查询条件的用法: CriteriaQuery cq = new CriteriaQuery(EquipmentEntity.class, dataGrid); //查询条件组装器 org. ...