数据缓存机制-数据同步

Posted excellencesy

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了数据缓存机制-数据同步相关的知识,希望对你有一定的参考价值。

在数据同步方式中,对于一些无法监听数据变更,或者数据变更太频繁的,我采用了定时器定时更新缓存数据的方式,例:

    @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)第二种方式:程序被阻塞后,程序会等待执行结束之后在每隔一秒执行下一次。

所以使用长连接的方式能解决的阻塞的问题

以上是关于数据缓存机制-数据同步的主要内容,如果未能解决你的问题,请参考以下文章

Redis(1.8)Redis与mysql的数据库同步

SpringSpring缓存机制与Redis的结合

redis集群配置,spring整合jedis,缓存同步

如何清理mysql数据库缓存数据?

线程同步之读写锁

Spring Cloud Netflix-Eureka集群数据同步