MK-商品上下架需求方案

1.需求

商家把需要上下架的商品設(shè)置一個(gè)上下架時(shí)間,后臺服務(wù)端需要按時(shí)將該商品上下架。

2.現(xiàn)狀

目前服務(wù)端:1臺數(shù)據(jù)庫服務(wù)器+2臺無狀態(tài)web服務(wù)器,通過web服務(wù)器讀寫數(shù)據(jù)庫,可能存在沖突。

3.技術(shù)

考慮 quartz+spring+mysql

4.方案

1)給每一個(gè)商品設(shè)置一個(gè)qurartz cron表達(dá)式,問題在于:每一個(gè)商品都要給它new一個(gè)quartz實(shí)例,容易產(chǎn)生內(nèi)存消耗。

CronTrigger trigger = new CronTrigger(jobName, TRIGGER_GROUP_NAME);
trigger.setCronExpression(updownTime);// 觸發(fā)器時(shí)間設(shè)定

2)設(shè)置quartz定時(shí)器,每秒遍歷數(shù)據(jù)庫(可以考慮時(shí)延減輕負(fù)擔(dān)),每秒遍歷DB,可以配置里面寫死,比如通過spring配置:

<beans>
??????? <!-- 要調(diào)用的工作類 -->
<bean id="quartzJob" class="com.kay.quartz.QuartzJob"></bean>
??????? <!-- 定義調(diào)用對象和調(diào)用對象的方法 -->
<bean id="jobtask"
class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
??????????? <!-- 調(diào)用的類 -->
??????????? <property name="targetObject">
??????????????? <ref bean="quartzJob"/>
??????????? </property>
??????????? <!-- 調(diào)用類中的方法 -->
??????????? <property name="targetMethod">
??????????????? <value>work</value>
??????????? </property>
??????? </bean>
??????? <!-- 定義觸發(fā)時(shí)間 -->
<bean id="doTime" class="org.springframework.scheduling.quartz.CronTriggerBean">
??????????? <property name="jobDetail">
??????????????? <ref bean="jobtask"/>
??????????? </property>
??????????? <!-- cron表達(dá)式 ,每秒執(zhí)行-->
??????????? <property name="cronExpression">
??????????????? <value>0/1 * * * * ?</value>
??????????? </property>
??????? </bean>
??????? <!-- 總管理類 如果將lazy-init='false'那么容器啟動就會執(zhí)行調(diào)度程序? -->
<bean id="startQuertz" lazy-init="false" autowire="no" class="org.springframework.scheduling.quartz.SchedulerFactoryBean">
??????????? <property name="triggers">
??????????????? <list>
??????????????????? <ref bean="doTime"/>
??????????????? </list>
??????????? </property>
??????? </bean>
</beans>

如果不用spring配置quartz的話,還可以通過quartz.properties進(jìn)行配置。

#============================================================================??
# Configure Datasources????
#============================================================================?

org.quartz.dataSource.NAME.driver = 數(shù)據(jù)庫驅(qū)動(requried)
org.quartz.dataSource.NAME.URL = 連接數(shù)據(jù)庫的url (requried)
org.quartz.dataSource.NAME.user = 連接的數(shù)據(jù)庫的用戶名(not requried)
org.quartz.dataSource.NAME.password =連接的數(shù)據(jù)庫的密碼(not requried)
org.quartz.dataSource.NAME.maxConnections = 連接池中最大連接數(shù)(not requried)
org.quartz.dataSource.NAME.validationQuery = sql查詢語句(not requried)

#============================================================================??
#*********************************
#============================================================================?

問題在于:數(shù)據(jù)庫過大時(shí),掃描時(shí)間可能會增加。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 136,711評論 19 139
  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語法,類相關(guān)的語法,內(nèi)部類的語法,繼承相關(guān)的語法,異常的語法,線程的語...
    子非魚_t_閱讀 34,855評論 18 399
  • Spring Boot 參考指南 介紹 轉(zhuǎn)載自:https://www.gitbook.com/book/qbgb...
    毛宇鵬閱讀 47,290評論 6 342
  • Quartz 中集群如何工作 一個(gè) Quartz 集群中的每個(gè)節(jié)點(diǎn)是一個(gè)獨(dú)立的 Quartz 應(yīng)用,它又管理著其他...
    那臉憔悴閱讀 2,837評論 1 52
  • 一. Java基礎(chǔ)部分.................................................
    wy_sure閱讀 4,037評論 0 11

友情鏈接更多精彩內(nèi)容