Redis是一个强大的内存数据结构存储,包含数据库,缓存和消息代理等多种用途。大多数人经常认为它不过是一个简单的键值存储,但其实它有更多的能力。下面我将会总结一些Redis可以做的事情的真实例子。
1.全页面缓存
首先是整页缓存。如果你正在使用服务器端呈现的内容,则不需要为每个单独的请求重新渲染每个页面。使用如Redis这样的缓存,你可以缓存经常请求的内容,从而大大减少请求最多的页面的延迟,并且大多数框架针对Redis缓存页面都有hooks。
简单命令
- / Set the page that will last 1 minuteSET key "<html>...</html>" EX 60// Get the pageGET key
2.排行榜
Redis令人耀眼的地方之一就是排行榜。由于Redis在内存中,因此可以非常快速和高效地处理递增和递减。将此与每个请求运行SQL查询比较,性能收益巨大!这与Redis的排序集相结合意味着你可以以毫秒为单位抓取列表中评分最高的项目,而且实现起来非常容易。
简单命令
- // Add an item to the sorted setZADD sortedSet 1 "one"// Get all items from the sorted setZRANGE sortedSet 0 -1// Get all items from the sorted set with their score
- ZRANGE sortedSet 0 -1 WITHSCORES
3.会话Session存储
我所见的Redis最常见的用途是会话存储。与其他会话存储(如Memcache)不同,Redis可以保留数据,以便在缓存停止的情况下,在重新启动时,所有数据仍然存在。即便不是需要严格持续的任务,此功能仍可以为你的用户省去大量的麻烦。没有人会乐于见到他们的会话被无缘无故随机删掉。
简单命令
- // Set session that will last 1 minuteSET randomHash "{userId}" EX 60// Get userIdGET randomHash
4.队列
使用Redis可以做的一个不太常见,但非常有用的事情是排队。无论是电子邮件队列还是其他应用程序使用的数据,你都可以在Redis中创建一个高效的队列。任何熟悉堆栈以及会push和pop项目的开发人员都可以轻松自然地使用此功能。
简单命令
- // Add a Message
- HSET messages <id> <message>ZADD due <due_timestamp> <id>// Recieving Message
- ZRANGEBYSCORE due -inf <current_timestamp> LIMIT 0 1
- HGET messages <message_id>// Delete Message
- ZREM due <message_id>HDEL messages <message_id>
5.pub/sub
Redis在真实世界的最终用法即我将在这篇文章中提出的pub / sub。这是Redis内置的最强大的功能之一;得到的可能是无限的。你可以创建一个实时聊天系统,在社交网络上触发好友请求的通知等等。这个功能是Redis提供的最被低估的功能之一,但功能非常强大,而且使用简单。
简单命令
- // Add a message to a channelPUBLISH channel message// Recieve messages from a channelSUBSCRIBE channel
结论
我希望你会喜欢这些Redis在真实世界的使用。虽然这篇文章只抓住了Redis能为你做的事情的表面,但是我希望你能从中获得应如何充分利用Redis的启发。
相关推荐
生产者消费者模式是一种经典的多线程同步问题解决方案,它源于现实世界中的生产流水线,用于描述生产者(Producer)和消费者(Consumer)之间的协作关系。在这个模式中,生产者负责生成产品并放入仓库,而消费者则从...
它是一个基于烧瓶的REST Web服务,旨在部署到Heroku,并依靠Anaconda来安装科学计算依赖项,并依靠Redis来存储预先计算的相似性。 阅读engine.py中的注释以查看其工作原理。 非常简单! web.py包含两个端点: / ...
为了在现实世界中使用,您需要获得一种由数据库驱动的引擎: 如果此处未列出您选择的数据存储,请创建一个引擎并向我发送拉取请求。 要查看有关如何创建引擎的示例,请参见 。 安装 npm install save 例子 var ...
Java具有强大的面向对象编程能力,使得系统设计可以更贴近现实世界中的业务模型。例如,我们可以创建Bank、Account、Customer等类,分别代表银行、账户和客户,通过类与类之间的继承、封装和多态性来构建复杂的关系...
3. 数据库代表现实世界的一个方面,有时称为微观世界。微观世界的变化会在数据库中反映出来。 换句话说,数据库有其数据来源,与现实世界事件有一定的互动,并有一群积极关注数据库内容的受众。数据库可以有任意...
面向对象编程是一种编程范式,它通过将数据和行为封装在对象中来模拟现实世界的实体。面向对象的核心概念包括: - **类与对象**:类是对象的模板或蓝图,定义了一组相似对象的共同属性和行为。对象则是类的一个实例...
该库是从现实世界中提取的,在现实世界中,需要FTP接口位于非文件系统持久层的前面。 一些示例用例包括将数据持久保存到: 一个Amazon S3存储桶关系数据库Redis 记忆examples目录包含内存持久性的演示。安装gem ...
《Introducing Data Science - Big Data, Machine Learning and more, using Python》这...通过对书中的知识点的深入学习和实践,读者能够构建起一个坚实的数据科学基础,并能够开始解决现实世界中复杂的数据科学问题。
3. **抽象**:通过类来抽象现实世界中的概念,简化问题复杂度。 4. **继承**:子类可以继承父类的属性和方法,实现代码复用,增加代码的灵活性。 5. **多态**:不同对象对同一消息可以有不同的响应,增强了程序的...
数学建模是将现实世界问题转换为数学问题的过程,然后利用数学方法来解决问题。在数学建模中,数据集是关键的组成部分,因为它们提供了模型所需的数据输入。数据集通常存储在数据库中,因此对于想要参与数学建模项目...
在数据库编程方面,笔记介绍了JDBC的基本概念和使用方法,强调了在使用JDBC编程时需要注意的细节,例如Properties属性配置对象的使用,以及数据库连接池的配置和管理,这些都是提升应用程序性能和响应速度的关键技术...
- **Synchronized关键字**:在方法或代码块上使用`synchronized`关键字可以确保同一时刻只有一个线程能够执行该方法或代码块。 - **Synchronized块**:可以对特定的代码块进行同步,例如`{ synchronized (object) ...
E-R模型通过实体、属性和关系来描述现实世界的数据结构。 3. 关系数据库:重点讲解关系模型,包括关系、元组、属性、键和索引等概念。此外,还会涉及关系操作,如选择、投影、连接和除法等。 4. SQL语言:SQL...
最常用的是实体-关系(E-R)模型,它通过实体、属性和关系来表示现实世界中的对象。此外,还有层次模型、网状模型和关系模型。在本课件中,我们将重点讨论关系模型,因为它在实际应用中最广泛。 接着,我们将会接触...
5个目标文件 内容索引:Java源码,窗体界面,3DMenu Java 3DMenu 界面源码,有人说用到游戏中不错,其实平时我信编写Java应用程序时候也能用到吧,不一定非要局限于游戏吧,RES、SRC资源都有,都在压缩包内。...
在医疗系统中,OOP可以帮助我们创建模块化的代码,更好地模拟现实世界中的实体,如病人、医生、药品等,使得代码易于维护、扩展和重用。核心的面向对象原则包括封装、继承和多态性,这些都是构建复杂系统的关键要素...
概念设计是将现实世界的问题域转化为数据模型的过程,通常使用实体-关系模型(E-R Model)来表示。逻辑设计则涉及将E-R模型转化为特定数据库系统的数据结构,如关系模式。 在数据库系统中,SQL(结构化查询语言)是...
关系模型的基础是实体-关系(E-R)模型,用于描述现实世界的实体及其相互关系。 3. **SQL语言**:结构化查询语言(SQL)是管理和操纵数据库的标准语言,包括数据查询、数据插入、数据更新和数据删除等操作。SQL还...