mysql实现商品自动下架_MK-商品上下架需求方案

针对商品自动上下架的需求,现有1台数据库服务器和2台无状态web服务器的架构。考虑使用quartz+spring+mysql的技术方案,但存在内存消耗和数据库扫描效率问题。一种方法是为每个商品设置cron表达式,另一种是设置定时器定期遍历数据库。然而,这两种方式分别可能导致内存浪费和数据库扫描时间增加。
摘要由CSDN通过智能技术生成

1.需求

商家把需要上下架的商品设置一个上下架时间,后台服务端需要按时将该商品上下架。

2.现状

目前服务端:1台数据库服务器+2台无状态web服务器,通过web服务器读写数据库,可能存在冲突。

3.技术

考虑 quartz+spring+mysql

4.方案

1)给每一个商品设置一个qurartz cron表达式,问题在于:每一个商品都要给它new一个quartz实例,容易产生内存消耗。

CronTrigger trigger = new CronTrigger(jobName, TRIGGER_GROUP_NAME);

trigger.setCronExpression(updownTime);// 触发器时间设定

2)设置quartz定时器,每秒遍历数据库(可以考虑时延减轻负担),每秒遍历DB,可以配置里面写死,比如通过spring配置:

class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">

work

0/1 * * * * ?

如果不用spring配置quartz的话,还可以通过quartz.properties进行配置。

#==================================

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值