Redis4- llist的操作

数据类型List链表

(1)介绍
list类型其实就是一个双向链表。通过push,pop操作从链表的头部或者尾部添加删除元素。
这使得list既可以用作栈,也可以用作队列。

该list链表类型应用场景:

获得最新的10个登录用户信息:select * from user order by logintime desc limit 10;

以上sql语句可以实现用户需求,但是数据多的时候,全部数据都要受到影响,对数据库的
负载比较高。必要情况还需要给关键字段(id或logintime)设置索引,索引也比较耗费系统
资源。

如果通过list链表实现以上功能,可以在list链表中只保留最新的10个数据,每进来一个新
数据就删除一个旧数据。每次就可以从链表中直接获得需要的数据。极大节省各方面资源消耗。

(2)操作指令
lpush key string         在key对应list的头部添加字符串元素
lpop key                 从list的头部删除元素,并返回删除元素
rpush key string         在key对应list的尾部添加字符串元素
rpop key                 从list的尾部删除元素,并返回删除元素
llen key 返回 key        对应list的长度,key不存在返回0,如果key对应类型不是list返回错误
lrange key start end     返回指定区间内的元素,下标从0开始
ltrim key start          截取list,保留指定区间内元素

实践:
通过list链表保存登录系统的最新的5个用户信息:

例子数据
jim    xiaoli    jack    xiaoming    linken    mary    tom
注:tom是第六个,我们先存5个,当第六个出现的时候,我们看看结果会不会改变。

1.设置一个list链表key newlogin,内部有5个元素:

2.当第六个用户tom进来的时候,我们要将尾部的元素(其实就是jim)删除

该链表每增加一个新元素,就删除一个旧元素

3.我们使用lrange key start end来查看现有的五个数据

然后看一下实际长度,其实也是5:

我们现在只留中间三个人的信息,可以使用ltrim指令截取list:

转载请注明出处:http://blog.csdn.net/acmman/article/details/53240967

时间: 2024-10-17 20:48:13

Redis4- llist的操作的相关文章

java使用POI操作excel文件,实现批量导出,和导入

一.POI的定义 JAVA中操作Excel的有两种比较主流的工具包: JXL 和 POI .jxl 只能操作Excel 95, 97, 2000也即以.xls为后缀的excel.而poi可以操作Excel 95及以后的版本,即可操作后缀为 .xls 和 .xlsx两种格式的excel. POI全称 Poor Obfuscation Implementation,直译为"可怜的模糊实现",利用POI接口可以通过JAVA操作Microsoft office 套件工具的读写功能.官网:htt

Redis4.0 主从复制(PSYN2.0)

Redis4.0版本相比原来3.x版本,增加了很多新特性,如模块化.PSYN2.0.非阻塞DEL和FLUSHALL/FLUSHDB.RDB-AOF混合持久化等功能.尤其是模块化功能,作者从七年前的redis1.0版本就开始谋划,终于在4.0版本发布了,所以版本号也就从3.x直接迭代到了4.0以表示版本变化之大.简单看了一下新版的PSYN2.0,虽然很多细节没搞清楚,但是大概流程倒是搞明白了. 一.主要流程 在新版的PSYN2.0中,相比原来的PSYN功能,最大的变化支持两种场景下的部分重同步,一

图的操作和l邻接矩阵存储

/* 1.图是由顶点集合及顶点之间的关系集合组成的一种数据结构.图的定义:G=(V,E) 2.顶点和边:图中的结点一般称作顶点,顶点与顶点相关联称作遍 3.完全图:在n个顶点的无向图中,若有n(n-1)/2条边,即任意两个顶点之间有且只有一条边,则称此图 为无向完全图:在n个顶点的右向图中,若有n(n-1)条边,即任意两个顶点之间有且只有方向相反的2条边, 则称此图为有向完全图. 4.顶点的度:顶点的度=出度+入度 5.连通图和强连通图: 在无向图中,若从顶点vi到顶点vj有路径,则称顶点vi和

redis4安装

第一步官网下载 https://redis.io/ rz 上传或者直接wget   http://download.redis.io/releases/redis-4.0.2.tar.gz 2.将其下载到我的/server/tools/目录下 3.解压并进入其目录 tar xf redis-4.0.2.tar.gz 4.编译源程序 make cd src make install PREFIX=/usr/local/redis 5.将配置文件移动到redis目录 mv /server/tools

redis-4.0.1安装配置(CentOS 6.6)

一.redis服务安装配置 1.        下载解压redis软件包 # wget http://download.redis.io/releases/redis-4.0.1.tar.gz # tar zxvf redis-4.0.1.tar.gz # cd redis-4.0.1 2.        编译安装redis # make MALLOC=jemalloc # make PREFIX=/application/redis-4.0.1 install # ln -s /applica

linux7.0下2台服务器安装redis4.0.2集群

分配端口和ip 172.16.1.23 redis01 172.16.1.24 redis02   redis01:7000 redis02:7003     redis01:7001   redis02:7004    redis01:7002 redis02:7005   1 安装gcc  Redis在linux上的安装首先必须先安装gcc,这个是用来编译redis的源文件的 # yum install gcc -y 2.下载解压redis的源文件  https://redis.io/dow

阿里云 CentOS7安装redis4.0.9并开启远程访问

1 安装redis编译的c环境 yum install gcc-c++ redis是c语言开发的,安装redis需要先将官网下载的源码进行编译,编译依赖gcc环境. 如果没有gcc环境,需要安装gcc环境 输入y开始安装: 2 redis安装 1 上传文件 2 解压文件到/usr/local下 进入到/soft目录后执行下面的命令. tar -xvf redis-4.0.9.tar.gz -C /usr/local 3 编译redis(将.c文件编译成.o文件)  1) 进入redis-4.0.

Redis4.0.10集群搭建

192.168.254.128192.168.254.129192.168.254.127注意事项安裝 GCC 编译工具 不然会有编译不过的问题yum install -y gcc g++ gcc-c++ make升级所有的包,防止出现版本过久不兼容问题yum -y update 环境准备安装ruby: 关闭防火墙 节点之前需要开放指定端口,为了方便,生产不要禁用centos 6.xservice iptables stop # 关闭命令:centos 7.xsystemctl stop fir

redis-4.0.9安装

1 参考文档 https://redis.io/download http://www.redis.cn/topics/cluster-tutorial.html 2 安装 # redis安装 $ wget http://download.redis.io/releases/redis-4.0.9.tar.gz $ tar xzf redis-4.0.9.tar.gz $ cd redis-4.0.9 $ make $ sudo make install 3 服务器调优 3.1 WARNING:

5种redis常用操作(数据类型+键值+服务+安全)

[toc] 5种redis常用数据类型操作 一.Redis常用操作 (string, list) 1.1 如果一个key设置两个不同的值,第二个值会覆盖第一个值. [[email protected] ~]# cd /usr/local/src/redis-4.0.9 [[email protected] redis-4.0.9]# redis-cli 127.0.0.1:6379> set key1 xavi OK 127.0.0.1:6379> set key2 xavilinux OK