Redis学习一(基础入门).

一、前言

Redis是一个开源的使用ANSI C语言编写、遵守BSD协议、支持网络、可基于内存亦可持久化的日志型、key-Value 的数据库、并提供多种语言的API。

通常,Redis 将数据存储于内存中,或被配置为使用虚拟内存。通过两种方式可以实现数据持久化:使用截图的方式,将内存中的数据不断写入磁盘;或使用类似 MySQL 的日志方式,记录每次更新的日志。前者性能较高,但是可能会引起一定程度的数据丢失;后者相反。

解释了为什么选用6379作为默认端口,因为6379在手机按键上MERZ对应的号码,而MERZ取自意大利歌女Alessia Merz的名字。

二、特点

  • 支持数据的持久化,可以将内存中的数据保存到磁盘中,重启的时候可以再次加载进行使用。
  • 丰富的数据类型存储:String、list、set、zset、hash。
  • 支持数据的备份,即master-slave模式的数据的备份。
  • 性能极高 – Redis能读的速度是110000次/s,写的速度是81000次/s。
  • 所有的操作都是基于原子性的。

三、数据对象

  • String

--redis的String可以包含任何数据,比如jpg图片或者序列后的对象,一个key最大能存储512MB。

  • Hash

--hash 是一个String类型的field 和 value 的映射表,hash 特别适合用于存储对象。每个hash可以存储2^32-1键值对 。

  • list

--Redis 列表是简单的字符串列表,按照插入的顺序可以在列表的头部(左边)或者尾部(右边)添加元素。

  • set

--Redis的Set是String类型的无序集合。集合是通过hash表实现的,所以。添加、删除、查找的复杂度都是O(1)。

  • zset

--zset 和 set一样也是String的类型元素的集合,且不允许重复的队员,不同的是每个元素都会关联一个double类型的score。redis正是通过score来为集合中的成员进行从小到大的排序。分数(score)可以重复。
添加元素到集合,元素在集合中存在则对应更新相应的score。

四、安装

1、Window

--服务端
  1、window下载地址:https://github.com/MicrosoftArchive/redis/releases
  2、打开一个 cmd 窗口 使用cd命令切换目录 E:\redis 运行 redis-server.exe redis.windows.conf
--客户端
  1、打开一个 cmd 窗口 使用cd命令切换目录 E:\redis 运行 redis-cli.exe -h 127.0.0.1 -p 6379 -a ‘mypass‘
  2、set myKey abc / get myKey

2、Linux

--服务端
  1、 wget http://download.redis.io/releases/redis-2.8.17.tar.gz
  2、 tar -zxvf redis-2.8.17.tar.gz redis-2.8.17
  3、 cd redis-2.8.17
  4、 make
  5、 cd src
  6、 ./redis-server redis.conf
--客户端
  1、 cd src
  2、 ./redis-cli
  redis> set foo bar
  OK
  redis> get foo
  "bar"

五、命令

1、String

-- set key value 保存key和value。
-- get key 根据key得到value。

2、Hash

-- hmset myhash key1 val1 key2 val2 存储hash值
-- hget myhash key1 根据hash中的某个key得到value
-- hgetall myhash 得到hash中的所有值
-- HDEL key field1 [field2] 删除一个或多个哈希字段
-- HKEYS key 获取所有哈希表中的字段
-- HLEN key 获取哈希字段数

3、List

-- lpush key val 向列表左边插入元素
-- lpop key 从列表左边移出元素
-- rpush key val 向列表右边插入元素
-- rpop key 从列表右边移出元素
-- rpushx key value 为已存在的列表添加值
-- LRANGE key start stop 获取列表指定范围内的元素
-- lindex key index 通过索引获取列表中的元素

4、Set

-- sadd key value 添加元素
-- smembers key 根据key获得集合中的所有成员
-- scard key 获取集合的成员数
-- sdiff key1 key2 返回给定所有集合的差集(key2的集合相对于key1集合的差集)
-- sunion 返回给定集合的并集
-- smove source des member 把member从source集合到des集合
-- sdiffstore des key1 key2 返回给定所有集合的差集,并存储在des中
-- srandmember key count 返回集合中一个或多个随机数
-- spop key1 移除并返回集合中的一个随机元素
-- sismember key mem 判断mem元素是否存在

5、Zset

-- zadd page 0 123
-- zadd page 1 234
-- zrangebyscore page 0 10

6、通用

-- 删除key:DEL key
-- 查看所有的key:keys *
-- 序列化给定key,并返回被返回的值:DUMP key
-- 检查给定key是否存在:EXISTS key
-- 为key设置过期时间:EXPIRE key seconds
-- 为key设置过期时间(时间戳):EXPIREAT key timestamp
-- 为key设过期时间(毫秒):PEXPIRE key milliseconds
-- 查找所有符合给定模式的key:KEYS pattern
-- 移除key的过期时间,key将持久保存:persist key
-- 以毫秒为单位返回key的剩余过期时间:PTTL key
-- 返回key所存储的值得类型:TYPE key

HyperLogLog:
       -- 添加指定元素到HyperLogLog中:PFADD key element
       -- 返回给定的HyperLogLog的基数估计值:PFCOUNT key
       -- 将多个HyperLogLog 合并为一个HyperLogLog:PFMERGE destkey sourcekey

订阅命令:
      -- 订阅一个或多个符合给定模式的频道:psubscribe pattern
      -- 退订一个或多个符合给定模式的频道:punsubscribe pattern
      -- 查看订阅与发布系统状态:pubsub subcommand
      -- 将信息发布到指定的频道:publish channel message
      -- 订阅给定的一个或多个频道的信息:subscribe channel
      -- 退订给定的频道:unsubscribe channel

原文地址:https://www.cnblogs.com/jmcui/p/8472909.html

时间: 2024-08-03 19:09:39

Redis学习一(基础入门).的相关文章

大数据系统学习零基础入门到精通加项目实战2017最新全套视频教程

38套大数据,云计算,架构,数据分析师,Hadoop,Spark,Storm,Kafka,人工智能,机器学习,深度学习,项目实战视频教程 视频课程包含: 38套大数据和人工智能精品高级课包含:大数据,云计算,架构,数据挖掘实战,实时推荐系统实战,电视收视率项目实战,实时流统计项目实战,离线电商分析项目实战,Spark大型项目实战用户分析,智能客户系统项目实战,Linux基础,Hadoop,Spark,Storm,Docker,Mapreduce,Kafka,Flume,OpenStack,Hiv

VS2013中Python学习笔记[基础入门]

前言 在上一节中简单的介绍了在VS2013中如何进行开发Hello World,在VS2013中进行搭建了环境http://www.cnblogs.com/aehyok/p/3986168.html.本节主要来简单的学习一下关于Python的基础. Python基础入门 1.打印一个字符串Hello World. print('Hello World') 2.打印一个路径 print('C:\aehyok\aehyok') 可以发现\a发生了转义.如果不想发生转义,只需要在字符串前添加一个r p

Redis学习笔记之入门基础知识——其他特性

1.订阅(subscribe)与发布(publish) 用户订阅某一个频道,频道发布新的信息时,会将信息告知用户 2.数据安全 1)     快照持久化(时间点转储,实质是数据副本) 操作:SAVA.BGSAVE(后台子进程SAVE) 功能:服务器会保存最近一次完成创建的快照的数据,注意,在创建快照的过程中的操作不会保存在快照中 SAVE seconds times:从上一次快照创建完成到seconds秒的时间内,如果有times次写入,那么会在seconds秒后执行一次BGSAVE,将数据写入

Redis学习一:Nosql入门和概述

现在Redis越来越火,为了适应技术的发展,开始学习一下Redis,在学习Redis之前先学习一下Nosql. 第一部分:入门概述 1.1 互联网时代背景下大机遇,为什么用nosql 1.1.1 单机Mysql的美好年代(好几年前) 当时的业务很相对简单,就是JSP--->Action---->Service---->DAO----->数据库,数据库也就是一个实例而已,无论是Mysql还是Oracle.把这五层缩减为三层的话便是:应用层------>DAO层------>

MySQL学习笔记-基础入门

MySQL学习笔记

redis学习研究--基础知识

以下内容多为摘抄转载: 1. Redis 是什么 Redis是一个开源的使用ANSI C语言编写的基于内存的key/value存储系统,与memcache类似,但它支持的value类型更多,包括:字符串(string).链表(list).集合(set).有序集合(sorted set)和hash tablehttp://blog.nosqlfan.com/html/2235.html等,这些数据类型支持push/pop.add/remove.交集并集差集及其他更丰富的操作,且这些操作均是原子性的

Socket.IO学习之基础入门

原文:http://blog.csdn.net/weichuang_1/article/details/48831957 这里贴出Socket.IO官网 一.Socket.IO的介绍 Socket.IO支持及时.双向与基于事件的交流.它可以在每个平台.每个浏览器和每个设备上工作,可靠性和速度同样稳定. 实时分析:将数据推送到客户端,这些客户端会被表示为实时计数器,图表或日志客户. 实时通信和聊天:只需几行代码便可写成一个Socket.IO的”Hello,World”聊天应用. 二进制流传输:从1

C#学习笔记---基础入门(三)

泛型<T> 使用泛型能够最大限度的重用代码/保护类型安全,提高性能 泛型成员因为类型的不确定性,不能使用算术运算符/比较运算符 类型参数可以有多个,可以是编译器能够识别的任何类型 类型参数的名字不能随便起,不能重名 //使用泛型 //数组类Array //泛型类-需要在类名前加上泛型类型 //定义的时候需要用T泛型类型表示任意一种数据类型 //T-Type,S/U/V 表示其他类型 //K/V-key/value public class Array<T,S,U,V> { //索引

排列组合的学习,基础入门,选修2-3

如题:用0,1,2,3,4,5可以组成多少个无重复数字比2000大的四位偶数? 答案为:在文末尾公布的数字%3214567 令:a=四位偶数 解法一(补偿法): N= N(a)-N(不大于2000的a) N(a)=N(个位为0的a)+N(个位为2的a)+N(个位为4的a) N(个位为0的a)    = 5*4*3 =60 N(个位为2,4的a) =(4*4*3)*2=48*2=96 N(不大于2000的a)=N(个位为1的a)= 3*4*3 =36 解法二(分类法): N=N(首位大于2的a)+