首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

mybaits提供一级缓存,和二级缓存区别

一级缓存是SqlSession级别的缓存。在操作数据库时需要构造 sqlSession对象,在对象中有一个(内存区域)数据结构(HashMap)用于存储缓存数据。不同的sqlSession之间的缓存数据区域(HashMap)是互相不影响的。在同一个sqlSession中两次执行相同的sql语句,第一次执行完毕会将数据库中查询的数据写到缓存(内存),第二次会从缓存中获取数据将不再从数据库查询,从而提高查询效率。当一个sqlSession结束后该sqlSession中的一级缓存也就不存在了。Mybatis默认开启一级缓存。但如果开启了二级缓存,那么在关闭sqlsession后,会把该sqlsession一级缓存中的数据添加到namespace的二级缓存中。   对sqlsession执行commit操作,也就意味着用户执行了update、delete等操作,那么数据库中的数据势必会发生变化,如果用户请求数据仍然使用之前内存中的数据,那么将读到脏数据。所以在执行sqlsession操作后,会清除保存数据的HashMap,用户在发起查询请求时就会重新读取数据并放入一级缓存中了。 如何开启二级缓存:

01

缓存雪崩和缓存穿透解决方案

缓存雪崩和缓存穿透 缓存雪崩:简单的说就是缓存失效,原本该访问缓存的数据直接访问数据库,从而造成数据库和内存压力大,严重的可能导致数据库宕机、服务器崩溃。 解决方案: 1.使用分布式锁或者对列控制读数据库写缓存的线程数,保证这有一个个线程进行操作。缺 点降低了系统的吞吐量 2.redis中的key 失效时间尽量设置分布均匀 3.使用mq来解决缓存雪崩效应。 当大量请求访问redis中没有值,把查询参数投放在消息队列,消费者接收到消息查询数据库得到结果使用同步方式返回给生成者。 消息中间件具有缓存消息的功能 4.设置一级二级缓存。如果一级缓存失效的时候,让访问请求二级缓存,需要注意二级缓存失效时间最好比一级缓存失效时间长一点。 5.如果是某一台redis服务器宕机,可以搭建redis主备 进行高可用。

03

Kubernetes解决Noisy Neighbors场景的探索

"noisy neighbour"问题的存在时间比云要长,这个词是在互联网技术资源共享开始的时候创造的。造成这种情况的原因通常是共同租户对资源施加了太多的压力,特别是在灵活的云计算中。当一个租户的性能由于另一个租户的活动而下降时,就会出现noisy neighbour问题,当下的云原生同样支持多租户应用场景,因此在同一台服务器上运行的业务(如业务应用程序)也会相互干扰。经典的场景是在线和离线业务负载的混部。如果没有隔离,离线应用程序会经常影响在线业务。当非关键业务的离线应用干扰关键的在线业务时,就称为“noisy neighbor”。如何解决这种问题?这就是本文的key。

03

一级缓存、二级缓存、查询缓存

1):Session 级别的缓存,与session邦定。它的生命周期和session相同。 Session消毁,它也同时消毁;管理一级缓存,一级缓存无法取消 2):两个Session 不能共享一级缓存,因它会伴随session的生命周期的创建和消毁; 3):get使用了一级缓存,用get查数据时,首先检查缓存中是否有该数据,如果有直接从缓存中取数据,如果没有再查询数据库,并且将数据放入缓存中。 load也支持一级缓存。load还支持lazy.当load从数据库中查询数据后,也会将数据放入缓存。 unique/list查询不会去查看缓存,但是list查询的实体对象将会放入缓存中。 4):与一级缓存相关方法: session.clear():清除一级缓存中所有的对象。 boolean contains(Object entity):判断一级缓存中是否有给定的对象。 session.evict(Object entity):从一级缓存中清除指定的对象。 session.flush():把一级缓存中的脏数据同步到数据库中。 session.refresh((Objectentity):强制重新查询对象,相当于把数据库中的数据同步到一级缓存中。

03
领券