Redis快速入门

Redis简介

  REmote DIctionary Server(Redis) 是一个由Salvatore Sanfilippo写的key-value存储系统。
  Redis是一个开源的使用ANSI C语言编写、遵守BSD协议、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API,如Java, Python, PHP等。
  它通常被称为数据结构服务器,因为值(value)可以是字符串(String), 哈希(Hash), 列表(List), 集合(Set)有序集合(Sorted Set)等类型。
  Redis有三个主要特点,使它优越于其它键值数据存储系统:

  • Redis将其数据库完全保存在内存中,仅使用磁盘进行持久化;
  • 与其它键值数据存储相比,Redis有一组相对丰富的数据类型;
  • Redis可以将数据复制到任意数量的从机(slave)中。

  关于Redis的安装与配置,可以参考网址:http://www.redis.net.cn/tutorial/3503.html ,本文将不再过多介绍。

Redis的基本数据结构

  Redis的基本数据结构有:

  • String: 字符串
  • Hash: 哈希(字典)
  • List: 列表
  • Set: 集合
  • Sorted Set: 有序集合

  以下,将针对这5中基本数据结构进行简单介绍。

String: 字符串

  redis 字符串数据类型的相关命令用于管理 redis字符串值。

127.0.0.1:6379> set testkey China
OK
127.0.0.1:6379> get testkey
"China"
127.0.0.1:6379> mset testkey1 USA testkey2 UK testkey3 GER
OK
127.0.0.1:6379> mget testkey1 testkey2 testkey3
1) "USA"
2) "UK"
3) "GER"
127.0.0.1:6379> del testkey3
(integer) 1
127.0.0.1:6379> get testkey3
(nil)

set和get命令分别为设置和获取String的值,mset和mget命令分别为设置和获取多个String的值,del命令为删除String的值。

Redis String

更多关于String的操作可参考网址:http://www.redis.net.cn/tutorial/3508.html

Hash: 哈希(字典)

  redis中的Hash是一个string类型的key和value的映射表,hash特别适合用于存储对象。
  redis中每个Hash可以存储 2^{32}-1个键值对(40多亿)。

127.0.0.1:6379> hset company1 name "baidu"
(integer) 1
127.0.0.1:6379> hget company1 name
"baidu"
127.0.0.1:6379> hmset company2 name "google" country "USA" type "tech corp"
OK
127.0.0.1:6379> hgetall company2
1) "name"
2) "google"
3) "country"
4) "USA"
5) "type"
6) "tech corp"
127.0.0.1:6379> hdel company1 name
(integer) 1

hset和hget命令分别为设置和获取某个key的键值对(field-value),hmset和hmget命令分别为设置和获取某个key的多个键值对,hgetall命令为获取某个key的全部键值对,hdel命令为删除某个key的键值对。

Redis Hash

更多关于Hash的命令可参考网址:http://www.redis.net.cn/tutorial/3509.html

List: 列表

  redis中的List是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边)
  一个列表最多可以包含2^{32}-1个元素。

127.0.0.1:6379> rpush databases mysql sql_server oracle mongodb redis hbase
(integer) 6
127.0.0.1:6379> lrange databases 0 4
1) "mysql"
2) "sql_server"
3) "oracle"
4) "mongodb"
5) "redis"
127.0.0.1:6379> lrem databases 0 sql_server
(integer) 1
127.0.0.1:6379> lrange databases 0 4
1) "mysql"
2) "oracle"
3) "mongodb"
4) "redis"
5) "hbase"

rpush命令为从List的右端(末尾)添加一个或多个元素,lrange命令为显示List的下标从start到end的元素,lrem命令为删除某个元素(count=0表示删除所有与该元素相等的元素)。

Redis List

更多关于List的命令可以参考网址:http://www.redis.net.cn/tutorial/3510.html

Set: 集合

  redis中的Set是String类型的无序集合。集合成员是唯一的,这就意味着集合中不能出现重复的数据。
  redis中的Set是通过哈希表实现的,所以添加,删除,查找的复杂度都是 O(1)。
  集合中最大的成员数为2^{32}-1

127.0.0.1:6379> sadd fruit apple banana orange apple pear
(integer) 4
127.0.0.1:6379> scard fruit
(integer) 4
127.0.0.1:6379> smembers fruit
1) "orange"
2) "pear"
3) "banana"
4) "apple"
127.0.0.1:6379> srem fruit pear
(integer) 1
127.0.0.1:6379> smembers fruit
1) "orange"
2) "banana"
3) "apple"
127.0.0.1:6379> scard fruit
(integer) 3

sadd命令为在集合中添加元素,scard命令为统计该集合元素个数,smembers命令为显示该集合中的所有元素,srem命令为删除该集合中的某个元素。

Redis Set

更多关于Set的命令可以参考网址:http://www.redis.net.cn/tutorial/3511.html

Sorted Set: 有序集合

  redis中的Sorted Set和Set一样也是string类型元素的集合,且不允许重复的成员。
  不同的是Sorted Set中的每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。
  有序集合的成员是唯一的,但分数(score)却可以重复。

127.0.0.1:6379> zadd databases 1 redis
(integer) 1
127.0.0.1:6379> zadd databases 2 mongodb
(integer) 1
127.0.0.1:6379> zadd databases 3 mysql
(integer) 1
127.0.0.1:6379> zadd databases 3 mysql
(integer) 0
127.0.0.1:6379> zadd databases 4 mysql
(integer) 0
127.0.0.1:6379> zadd databases 5 oracle
(integer) 1
127.0.0.1:6379> zcard databases
(integer) 4
127.0.0.1:6379> zrange databases 0 4 withscores
1) "redis"
2) "1"
3) "mongodb"
4) "2"
5) "mysql"
6) "4"
7) "oracle"
8) "5"
127.0.0.1:6379> zrangebyscore databases 0 4 withscores
1) "redis"
2) "1"
3) "mongodb"
4) "2"
5) "mysql"
6) "4"

zadd命令为在有序集合中添加元素(元素需要带有分数score),zcard命令为统计该有序集合中的元素个数,zrange命令为显示该有序集合下标从start到end的元素,zrangebyscore为显示该有序集合分数从start到end的元素。

Redis Sorted Set

更多关于Sorted Set的命令可以参考网址http://www.redis.net.cn/tutorial/3512.html

Python使用

  在Python中操作Redis,需要安装第三方模块redis。
  示例代码如下,以操作redis中的Hash为例(默认端口号为6379):

import redis

r = redis.Redis(host='localhost', port=6379, db=0)

# 设置employee1的键值对
r.hset('employee1', 'name', 'Jc')
r.hset('employee1', 'age', 25)
r.hset('employee1', 'city', 'Shanghai')

# 设置employee2的键值对
r.hset('employee2', 'name', 'Alex')
r.hset('employee2', 'age', 26)
r.hset('employee2', 'city', 'New York')

# 查询empolyee1, employee2的信息
print(r.hget('employee1', 'name'))
print(r.hgetall('employee1'))
print(r.hget('employee2', 'name'))
print(r.hgetall('employee2'))

输出结果:

b'Jc'
{b'name': b'Jc', b'age': b'25', b'city': b'Shanghai'}
b'Alex'
{b'name': b'Alex', b'age': b'26', b'city': b'New York'}

Java使用

  Java操作Redis的API为Jedis, maven仓库地址为: https://mvnrepository.com/artifact/redis.clients/jedis
  示例代码如下,以操作redis中的Hash为例(默认端口号为6379):

import redis.clients.jedis.Jedis;

public class JedisTest {
    public static void main(String[] args) {
        //连接本地的 Redis 服务
        Jedis jedis = new Jedis("localhost", 6379);
        System.out.println("连接成功");

        // 设置employee1的键值对
        jedis.hset("employee1", "name", "Jc");
        jedis.hset("employee1", "age", "25");
        jedis.hset("employee1", "city", "Shanghai");

        // 设置employee2的键值对
        jedis.hset("employee2", "name", "Alex");
        jedis.hset("employee2", "age", "26");
        jedis.hset("employee2", "city", "New York");

        // 获取存储的数据并输出
        System.out.println("employee1的姓名为: "+ jedis.hget("employee1", "name"));
        System.out.println("employee1的全部信息为: "+ jedis.hgetAll("employee1"));
        System.out.println("employee2的姓名为: "+ jedis.hget("employee2", "name"));
        System.out.println("employee2的全部信息为: "+ jedis.hgetAll("employee2"));
    }
}

输出:

连接成功
employee1的姓名为: Jc
employee1的全部信息为: {name=Jc, city=Shanghai, age=25}
employee2的姓名为: Alex
employee2的全部信息为: {name=Alex, city=New York, age=26}

总结

   本次分享到此结束,感谢大家阅读~
注意:本人现已开通微信公众号: Python爬虫与算法(微信号为:easy_web_scrape), 欢迎大家关注哦~~

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,830评论 5 468
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,992评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,875评论 0 331
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,837评论 1 271
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,734评论 5 360
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,091评论 1 277
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,550评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,217评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,368评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,298评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,350评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,027评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,623评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,706评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,940评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,349评论 2 346
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,936评论 2 341

推荐阅读更多精彩内容

  • 第一章 简介 Redis是一个开源高性能键值数据库。它通过提供多种键值数据类型类适应不同场景下的存储需求,并借助许...
    起个名忒难阅读 65,371评论 2 5
  • redis属于NoSql分类,它把数据都是缓存在内存中的,我们都知道内存的读写效率跟硬盘不是一个级别的,最后red...
    伍陆柒_阅读 1,626评论 0 0
  • Redis 是一个键值对数据库(key-value DB),数据库的值可以是字符串、集合、列表等多种类型的对象,而...
    吴昂_ff2d阅读 3,042评论 0 5
  • 哈哈根达斯阅读 249评论 0 1
  • 20170227 周一 南昌 气温8-19度 轻度污染 忙碌的工作日即将开始。 昨天培训的主要内容是强制性排序和把...
    cai彩阅读 622评论 0 1