Redis Util实现

package test.jedis;

import java.util.List;
import java.util.Set; import redis.clients.jedis.Jedis;
import redis.clients.jedis.Transaction; public class JedisUtil {
public static Jedis redis = new Jedis("localhost", 6379);// 连接redis static{
//初始化购物数据
redis.set("buy:number:1", "10000");
} /**
* 执行事务的过程其他客户端改变了其中的key值,解决数据一致性问题
* 通过watch 对key的监控来实现其他客户端修改数据后,事务取消
* 用法 首先用watch 开始对key的监控 在开启事务,顺序一定要先监控在执行事务
* */
public synchronized static String buy_trans(String userId) throws InterruptedException{
//1、通过对keys 的设计保证 每个用户只能购买一个
if(!redis.exists(userId)){ //2、当数量不购时提示 秒杀完
if(Integer.parseInt(redis.get("buy:number:1"))>0){ //3、redis 事务 监控数量的变化key=buy:number:1 监控1号商品的数量变化
redis.watch("buy:number:1"); //4、开启事务
Transaction tx = redis.multi(); //5、购买用户购买 成功 成功购买
tx.incr(userId); //6、设置数量减1
tx.decr("buy:number:1"); //7、执行事务
List<Object> results = tx.exec(); }else{
return "数量不足";
}
redis.disconnect();
return "抢购购买成功";
}else{
return "该用户已经购买了";
}
} public static Set<String> getKeys(String keys){
return redis.keys(keys);
} }

  Controller 端实现

package com.sf.fs.view;

import java.util.Set;

import javax.servlet.http.HttpServletRequest;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping; import com.sf.fs.service.SeckillService; /**
* seckill test
* */
@Controller
public class SeckillController { private SeckillService seckillService; public void setSeckillService(SeckillService seckillService) {
this.seckillService = seckillService;
} /**
* 抢购方法
* */
@RequestMapping("/buying")
public String buying(HttpServletRequest req){ //测试用于方便测试用sessionid 作为用户id
String sessionId=req.getSession().getId(); //存储的key 是 user:sessionId
String msg=seckillService.buying("user:"+sessionId);
System.out.println("返回的操作结果:"+msg);
return "succeed";
} /**
* 测试成功抢购的用户数,是否会出现超卖
* */
@RequestMapping("/result")
public void getResult(HttpServletRequest req){
Set<String> sets=seckillService.getUsers("user:*");
System.out.println("成功秒杀到的用户数:"+sets.size());
}
}

  Service 实现

package com.sf.fs.service.impl;

import java.util.List;
import java.util.Set; import com.sf.fs.service.SeckillService; import test.jedis.JedisUtil; public class SeckillServiceImpl implements SeckillService { public static int number=100; private JedisUtil jedisUtil; public void setJedisUtil(JedisUtil jedisUtil) {
this.jedisUtil = jedisUtil;
} @Override
public String buying(String key) { try {
return jedisUtil.buy_trans(key);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return "操作失败";
} public Set<String> getUsers(String prefixKey){ return jedisUtil.getKeys(prefixKey);
} }

  

Redis-秒杀场景应用的更多相关文章

  1. 【转载】秒杀场景下MySQL的低效原因和改进以及Redis的处理

    分享的PPT在如下网址: http://www.doc88.com/p-4199037770087.html 秒杀场景下mysql的低效原因和改进 另外有一个篇文章是针对以上内容的总结: http:/ ...

  2. 重学 Java 设计模式:实战享元模式「基于Redis秒杀,提供活动与库存信息查询场景」

    作者:小傅哥 博客:https://bugstack.cn 沉淀.分享.成长,让自己和他人都能有所收获! 一.前言 程序员‍‍的上下文是什么? 很多时候一大部分编程开发的人员都只是关注于功能的实现,只 ...

  3. 秒杀场景下MySQL的低效(转)

    秒杀场景下MySQL的低效 2016-01-14 17:12 178人阅读 评论(0) 收藏 举报 最近业务试水电商,接了一个秒杀的活.之前经常看到淘宝的同行们讨论秒杀,讨论电商,这次终于轮到我们自己 ...

  4. Redis应用场景-转载

    1.  MySql+Memcached架构的问题 实际MySQL是适合进行海量数据存储的,通过Memcached将热点数据加载到cache,加速访问,很多公司都曾经使用过这样的架构,但随着业务数据量的 ...

  5. Redis应用场景(转)

    (来源:http://www.cnblogs.com/shanyou/archive/2012/09/04/2670972.html) Redis常用数据类型 Redis最为常用的数据类型主要有以下五 ...

  6. redis(二)Redis适用场景,如何正确的使用

    网络IO模型 Memcached是多线程,非阻塞IO复用的网络模型,分为监听主线程和worker子线程,监听线程监听网络连接,接受请求后,将连接描述字pipe 传递给worker线程,进行读写IO, ...

  7. redis使用场景

    Redis应用场景   Redis开创了一种新的数据存储思路,使用Redis,我们不用在面对功能单调的数据库时,把精力放在如何把大象放进冰箱这样的问题上,而是利用Redis灵活多变的数据结构和数据操作 ...

  8. <转>Redis 应用场景

    http://blog.csdn.net/hguisu/article/details/8836819 1.  MySql+Memcached 架构的问题 Memcached采用客户端-服务器的架构, ...

  9. Redis作者谈Redis应用场景

    Redis作者谈Redis应用场景 毫无疑问,Redis开创了一种新的数据存储思路,使用Redis,我们不用在面对功能单调的数据库时,把精力放在如何把大象放进冰箱这样的问题上,而是利用Redis灵活多 ...

  10. Redis应用场景 及其数据对象 string hash list set sortedset

    原文地址:http://www.cnblogs.com/shanyou/archive/2012/09/04/2670972.html Redis开创了一种新的数据存储思路,使用Redis,我们不用在 ...

随机推荐

  1. HDU 1533 & KM模板

    题意 求二分图最小完备匹配. SOL 建个图那么方便的事情是吧...然后边权都是正的(好像根边权也没什么关系),既然要求最小那么把边权取个相反数跑个KM就好了.. CODE: /*========== ...

  2. BZOJ 1001 & SPFA

    1001: [BeiJing2006]狼抓兔子 Time Limit: 15 Sec  Memory Limit: 162 MB Description 现在小朋友们最喜欢的"喜羊羊与灰太狼 ...

  3. HDU 3966(树链剖分+点修改+点查询)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3966 题目大意:营地的分布成树型.每个营地都有一些人,每次修改修改一条链上的所有营地的人数,每次查询单 ...

  4. Java中的HashTable详解

    Hashtables提供了一个很有用的方法可以使应用程序的性能达到最佳. Hashtables(哈 希表)在计算机领域中已不 是一个新概念了.它们是用来加快计算机的处理速度的,用当今的标准来处理,速度 ...

  5. JQuery LazyLoad实现图片延迟加载-探究

    对于大量图片的网站,图片延迟加载是提高速度和性能的好方法. 目前图片延迟加载主要分两大块,一是触发加载(根据滚动条位置加载图片):二是自动预加载(加载完首屏后n秒后自动加载其他位置的图片).大体常用的 ...

  6. TYVJ P1075 硬币游戏 Label:dp

    背景 农民John的牛喜欢玩硬币,所以John就为它们发明了一个新的两人硬币游戏,叫做Xoinc. 描述 最初地面上有一堆n个硬币(5<=n<=2000),从上面数第i个硬币的价值为C_i ...

  7. freemarker 直接使用List来遍历set集合,可能会报错

    转摘:http://www.javaweb1024.com/java/JavaWebzhongji/2015/04/08/528.html freemarker  直接使用List来遍历set集合,可 ...

  8. linux下查看一个进程的启动时间和运行时间

    使用 ps命令 :#ps -A -opid,stime,etime,args ps -A -opid,stime,etime,args 结果: root:src# ps -A -opid,stime, ...

  9. [转载] c++ cout 格式化输出浮点数、整数及格方法

    C语言里可以用printf(),%f来实现浮点数的格式化输出,用cout呢...? 下面的方法是在网上找到的,如果各位有别的办法谢谢留下... iomanip.h是I/O流控制头文件,就像C里面的格式 ...

  10. Leetcode | Valid Sudoku & Sudoku Solver

    判断valid,没有更好的方法,只能brute force. class Solution { public: bool isValidSudoku(vector<vector<char& ...