redis incr incrby decr decrby命令
incr、incrby、decr、decrby命令的作用和用法
redis中incr、incrby、decr、decrby属于string数据结构,它们是原子性递增或递减操作。
- incr递增1并返回递增后的结果;
- incrby根据指定值做递增或递减操作并返回递增或递减后的结果(incrby递增或递减取决于传入值的正负);
- decr递减1并返回递减后的结果;
- decrby根据指定值做递增或递减操作并返回递增或递减后的结果(decrby递增或递减取决于传入值的正负);
设置incr:key和decr:key观察用法和执行结果
1.首次观察incr:key的值,可以看到没有结果
127.0.0.1:> GET incr:key 127.0.0.1:6381>
2.对incr:key执行incr命令,可以看到redis返回了递增后的结果1。incr命令会返回递增后的结果
127.0.0.1:> incr incr:key 127.0.0.1:>
3.对incr:key执行incrby命令,能看到redis返回了递增后的结果5。incrby命令会返回递增后的结果
127.0.0.1:> incrby incr:key 127.0.0.1:>
4.对incr:key执行incrby命令,这次传入一个负数,能观察到redis返回了递减后的结果2
127.0.0.1:> incrby incr:key - 127.0.0.1:>
5.对incr:key执行incrby命令,同样传入负数, 可以观察到incr:key经过递减后结果变成了负数
127.0.0.1:> incrby incr:key -
-
127.0.0.1:>
6.首次观察decr:key,没有任何结果
127.0.0.1:> GET decr:key 127.0.0.1:>
7.对decr:key执行decr命令,可以看到redis返回了递减后的结果
127.0.0.1:> decr decr:key
-
127.0.0.1:>
8.对decr:key执行decrby命令,可以看到redis返回了递减后的结果,这里的值输入的是4而不是-4
127.0.0.1:> decrby decr:key
-
127.0.0.1:>
9.对decr:key执行decrby命令,这次输入一个负数,观察一下结果
127.0.0.1:> decrby decr:key -
-
127.0.0.1:>
并发递增和递减
做一个实验,并发100个线程对同一个key做操作,其中50个执行incr命令,另外50个执行decr命令,观察一下结果
/**
* 并发100个线程,50个线程做decr命令,另外50个线程做incr命令
*
* @author tianshu on 16/10/31 上午10:52.
*/
public class MultipleDecrIncr { /** decr线程数量 */
private static final int DECR_THREAD_COUNT = 50;
/** incr线程数量 */
private static final int INCR_THREAD_COUNT = 50; private static CountDownLatch begin = new CountDownLatch(DECR_THREAD_COUNT + INCR_THREAD_COUNT); private static CountDownLatch finish = new CountDownLatch(DECR_THREAD_COUNT + INCR_THREAD_COUNT); static final String KEY = "string:decr:incr"; public static void main(String[] args) throws InterruptedException { for(int i = 0; i < DECR_THREAD_COUNT; ++i) {
new DecrThread().start();
begin.countDown();
} for(int i = 0; i < INCR_THREAD_COUNT; ++i) {
new IncrThread().start();
begin.countDown();
} finish.await(); JedisConnect jedisConnect = JedisConnect.getJedisConnect();
Jedis jedis = jedisConnect.getJedis(); String value = jedis.get(KEY);
System.out.println(value); jedisConnect.releaseJedis(jedis);
} /**
* decr命令线程
*/
static class DecrThread extends Thread { @Override
public void run() { try {
begin.await();
} catch (InterruptedException e) {
e.printStackTrace();
} JedisConnect jedisConnect = JedisConnect.getJedisConnect();
Jedis jedis = jedisConnect.getJedis(); jedis.decr(KEY);
jedisConnect.releaseJedis(jedis); finish.countDown();
}
} /**
* incr命令线程
*/
static class IncrThread extends Thread { @Override
public void run() { try {
begin.await();
} catch (InterruptedException e) {
e.printStackTrace();
} JedisConnect jedisConnect = JedisConnect.getJedisConnect();
Jedis jedis = jedisConnect.getJedis(); jedis.incr(KEY);
jedisConnect.releaseJedis(jedis); finish.countDown();
} } }
应用场景
个人觉得这类命令一般会应用到计数器场景
- 单号生成:根据业务生成key,每当需要单号时可以使用incr获得一个新的序列号。
- 错误拦截:比如有的网站账号密码输入错误N次之后,会做一些特殊处理;使用incr是实现这种功能的方式之一,可以根据用户的特殊标识表示key,每当账号密码输错时使用incr命令做递增。
- 非法拦截:某段时间限制同IP请求同一接口次数
redis incr incrby decr decrby命令的更多相关文章
- redis介绍(1)命令介绍
redis 的五大基本类型的简单命令 对key--value中的value的一些简单命令 keys * 查询redis中的所有key exists key 查询key是否存在 flushdb 清空当前 ...
- Memcached incr 与 decr 命令
Memcached incr 与 decr 命令用于对已存在的 key(键) 的数字值进行自增或自减操作. incr 与 decr 命令操作的数据必须是十进制的32位无符号整数. 如果 key 不存在 ...
- Redis数据结构及相应的命令
Redis可以存储键(key)与5种不同类型值(value)之间的映射,5中不同类型的值分别为字符串(string),列表(list),散列(hash),集合(set)和有序集合(sorted set ...
- Redis的增删改查命令总结与持久化方式
原文:Redis的增删改查命令总结与持久化方式 Redis是用C语言实现的,一般来说C语言实现的程序"距离"操作系统更近,执行速度相对会更快. Redis使用了单线程架构,预防了多 ...
- Redis 几个类型常用命令
Redis 字符串(String) 下表列出了常用的 redis 字符串命令: 序号 命令及描述1 SET key value 设置指定 key 的值2 GET key 获取指定 key 的值.3 G ...
- 【数据库】Redis(2)--Redis的常用数据类型及命令
1.Redis主要数据类型分类 Redis中存储数据常用的数据类型主要有五种:String.List.Set.Sorted Set.Hash,这五种数据结构在Redis中存储数据的命令掌握对于我们后期 ...
- 解析Redis操作五大数据类型常用命令
摘要:分享经常用到一些命令和使用场景总结,以及对Redis中五大数据类型如何使用cmd命令行的形式进行操作的方法. 本文分享自华为云社区<Redis操作五大数据类型常用命令解析>,作者:灰 ...
- Redis 常用数据结构及其控制命令整合
Redis 键值支持5种基本结构,分别是字符串,列表,哈希,集合,有序集合.每一种数据结构都有对应的取值和设值命令,辅助命令,除此之外,还有一些全局命令,用来管理Redis存储的所有 键. 全局命令 ...
- Linux+Redis实战教程_day02_3、redis数据类型_4、String命令_5、hash命令_6、java操作redis数据库技术
3. redis数据类型[重点] redis 使用的是键值对保存数据.(map) key:全部都是字符串 value:有五种数据类型 Key名:自定义,key名不要过长,否则影响使用效率 Key名不要 ...
随机推荐
- ajax请求和aspx返回数据
ajax请求: $(function () { $.ajax({ url: "index.aspx?method=send", ...
- SVN的使用
- Zephyr OS 简介
最新发布的开源 Zephyr Project™(Zephyr 项目)是一款小型且可伸缩的实时操作系统,尤其适用于资源受限的系统,可支持多种架构:该系统高度开源,对于开发人员社区完全开放,开发人员可根据 ...
- windows系统路径环境变量
当前系统盘符%systemdrive%或%HOMEDRIVE%C:\ 当前系统目录%systemroot%或%Windir%C:\WINDOWS 当前用户文件夹%UserProfile%或%HOMEP ...
- SpringMVC(关于HandlerMapping执行流程原理分析)
请求过来先碰见中央调度器(前端调度器) //Determine handler for the current request; 对当前请求决定交给哪个handler, 当前请求地址过来 处理器执行链 ...
- 模拟实现Spring中的注解装配
本文原创,地址为http://www.cnblogs.com/fengzheng/p/5037359.html 在Spring中,XML文件中的bean配置是实现Spring IOC的核心配置文件,在 ...
- Objective-C中NSInvocation的使用
OC中调用方法某个对象的消息呦两种方式: #1. performanceSelector: withObject: #2. NSInvocation. 第一个PerformaceSelector比较常 ...
- Atitit 动态按钮图片背景颜色与文字组合解决方案
Atitit 动态按钮图片背景颜色与文字组合解决方案 转换背景颜色,setFont("cywe_img", fontScale, 50, 5) 设置文字大小与坐标 文字分拆,使用字 ...
- 解析大型.NET ERP系统 单据标准(新增,修改,删除,复制,打印)功能程序设计
ERP系统的单据具备标准的功能,这里的单据可翻译为Bill,Document,Entry,具备相似的工具条操作界面.通过设计可复用的基类,子类只需要继承基类窗体即可完成单据功能的程序设计.先看标准的销 ...
- NodeJs+http+fs+request+cheerio 采集,保存数据,并在网页上展示(构建web服务器)
目的: 数据采集 写入本地文件备份 构建web服务器 将文件读取到网页中进行展示 目录结构: package.json文件中的内容与上一篇一样:NodeJs+Request+Cheerio 采集数据 ...