数据缓存机制-数据同步
在数据同步方式中,对于一些无法监听数据变更,或者数据变更太频繁的,我采用了定时器定时更新缓存数据的方式,例:
@Scheduled(fixedRate = 1000) public void getCurrentDate() { List<Map<String, Object>> instanceList = assemblyService.getInstanceList(); for (Map<String, Object> instance : instanceList) { String url = DataUtil.objToString(instance.get("homePageUrl")); String instanceId = DataUtil.objToString(instance.get("instanceId")); insert(url, instanceId); } }
使用这种方式的弊端就在于,容易发生线程阻塞,于是,改为长连接的方式:
private static void run() { Date date =new Date(); SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); System.out.println("hahhaha"+sdf.format(date)); try { Thread.sleep(1000); } catch (InterruptedException e) { e.printStackTrace(); }finally { run(); } } public static void main(String[] args) { run(); }
这两种方式的区别就在于:
(1)第一种方式:程序被阻塞后,依然会一秒执行一次该方法。
(2)第二种方式:程序被阻塞后,程序会等待执行结束之后在每隔一秒执行下一次。
所以使用长连接的方式能解决的阻塞的问题
相关推荐
yangkang 2020-11-09
lbyd0 2020-11-17
sushuanglei 2020-11-12
85477104 2020-11-17
KANSYOUKYOU 2020-11-16
wushengyong 2020-10-28
lizhengjava 2020-11-13
星月情缘 2020-11-13
huangxiaoyun00 2020-11-13
luyong0 2020-11-08
腾讯soso团队 2020-11-06
Apsaravod 2020-11-05
PeterChangyb 2020-11-05
gaobudong 2020-11-04
wwwjun 2020-11-02
gyunwh 2020-11-02
EchoYY 2020-10-31
dingyahui 2020-10-30