Redis AND ScheduledThreadPoolExecutor

**一个定时器每一秒生产定量订单放入缓存;
另一个定时器每一秒从缓存中取出符合条件的数据并处理**

/**
 * 运行逻辑:
 * 一个定时器每一秒生产定量订单放入缓存;
 * 另一个定时器每一秒从缓存中取出符合条件的数据并处理。
 * @author waniz
 *
 */
public class ProduceOrder {
    private static ScheduledThreadPoolExecutor schedulerProducer;
    private static ScheduledThreadPoolExecutor schedulerConsumer;
    private static int ORDER_NUM = 10;
    static{
        schedulerProducer = new ScheduledThreadPoolExecutor(1);
        schedulerConsumer = new ScheduledThreadPoolExecutor(1);
    }
    /**
     * 定时产生订单的方法
     * 返回订单的Id
     * @return
     */
    @SuppressWarnings("boxing")
    public static void produce(){
        final Jedis jedis = JedisUnit.getEdis("**.**.**");
        System.out.println("jedis's status:"+jedis.ping());
        schedulerProducer.scheduleAtFixedRate(new Runnable() {
            @Override
            public void run() {
                List<String> list = generateNums();
                for(String str : list){
                    Double score = Double.valueOf(TimeUnit.getTime())+10;
                    System.out.println(str);
                    jedis.zadd("order",score, str);
                }
            }
        }, 0, 1, java.util.concurrent.TimeUnit.SECONDS);
    }
    /**
     * 每隔一秒扫描符合条件的订单并且执行操作
     */
    public static void consume(){
        final Jedis jedisMaster = JedisUnit.getEdis("**.**.**");
        final Jedis jedis = JedisUnit.getEdis("**.**.**");
        System.out.println("jedis's status:"+jedis.ping());
        schedulerConsumer.scheduleAtFixedRate(new Runnable() {
            @Override
            public void run() {

                Double time = Double.valueOf(TimeUnit.getTime());
                Set<String> set = jedis.zrangeByScore("order", time, time);
                Iterator<String> iterator = set.iterator();
                while(iterator.hasNext()){
                    System.out.println(iterator.next()+"命中,发送短信!");
                }
                if(set.size()>0){
                    jedisMaster.zremrangeByScore("order", time, time);
                }
            }
        }, 1, 1, java.util.concurrent.TimeUnit.SECONDS);
    }
    /**
     * 获取定量单子
     * @return
     */
    private static List<String> generateNums(){
        List<String> list = new ArrayList<String>();
        for(int i=0;i<ORDER_NUM;i++){
            list.add(TimeUnit.getTime()+":单"+i);
        }
        return list;
    }

    public static void main(String[] args){
        produce();
        consume();
    /*  new ScheduledThreadPoolExecutor(1).scheduleAtFixedRate(new Runnable() {
            @Override
            public void run() {
                System.out.println(System.currentTimeMillis());
            }
        }, 0, 1,java.util.concurrent.TimeUnit.SECONDS);*/
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值