本小白程序员是写 java 的,但是工作了多年,用到真正的面向对象技术的机会比较少,所以去年自己做了一个面向对象的简单 demo 项目。
zhuanlan.zhihu.com/p/605481077
用的 Spring data JPA ,比较能够符合面向对象的风格。所谓 JPA ,java persistence architecture ,这个 persistence 就很有面向对象的味道,对象活在内存中,但是也需要在合适的时候持久化到数据库。
不过 Spring data JPA 的二级缓存才是活在内存中的对象,如果要分布式集群部署服务,一般怎么实现二级缓存的对象共享呢?

为什么要上二级缓存?

jetcache

没有二级缓存的话,每次查询操作都是查库重新创建对象,而不是直接查内存中的对象,感觉不是真正的面向对象

感谢感谢,我学习下

加不加缓存跟是不是面向对象又有什么关系。

看你的描述是感觉对 jpa 、hibernate 并不熟悉。建议是没经验还是别折腾这个,把控不好,缓存事务一致性可以让你喝一壶的,往严重说了就是生产事故了。二级缓存你可以在服务层或者展示层实现。

我理解的面向对象,对象都是活在内存里的,只是在必要时候才持久化到数据库

缓存就用 redis 吧,多实例也能生效

6666

不明白你为什么会这么理解

完全错误的面向对象理解

面向对象是要有一个类图,形成对象模型的嘛,对象模型是可运行的,就需要对象存活在内存里面啊

你是不是把面向对象的“对象”和 Java 虚拟机中堆内存中的“对象”给搞混了,二者并不是一个概念

java 的对象不就是面向对象的实现嘛

请求过来然后从数据库里查询出来不就进到内存里了?

不要执着于 面向对象 还是 非面向对象。想想自己要处理什么问题。如果要做分布式集群部署。那么就是需要一个统一的缓存中心。redis 支持集群部署并且与应用实例无关。你使用二级缓存相当于每台机器都部署一个 redis 。这些缓存无法保持同步的更新,无法保持同步销毁。除非你手写代码进行支持哈。

每次都查库,如果还有 等多级关联查询,性能是个问题QQ 群里有老哥说级联查询不会走二级缓存,不知道是不是真的 [少侠] 精通所有技术的马总监(568662344) 17:29:14级联操作 不走缓存 findById 索引操作 没有必要走缓存 [少侠] 精通所有技术的马总监(568662344) 17:29:33结论 使用 springDataJPA 不需要关注自身的缓存

工作中没有用过 Spring Data JPA ,只是学习下

你想要对象一直活着?

OP 似乎是需要映射数据库表实体的( tableInfo )对象一直存活

qq 号起码删了吧

完了,没想到,现在删不了了。。。

是的,我是这样希望的,对象创建出来之后,除非被删掉,期望它一直活着

“我理解的面向对象,对象都是活在内存里的,只是在必要时候才持久化到数据库”看到你对面向对象的理解,我瞬间不知道怎么跟你解释。

缓存一致性又如何解决?

个人建议不要使用二级缓存,而是使用 Spring cache ,当然过期处理复杂一些。


1.建议重新理解一下面向对象的概念2.缓存一致性是更大的问题

面向对象是对标面向过程的,不是你说的这个意思

二级缓存处理起来坑爹,要优化性能显然是找到瓶颈去优化,将高频性能损耗点手动加上 redis 缓存即可大大优化性能,而且往往这种优化点不会特别多,封装好了方法后使用起来非常方便、易于理解、支持分布式。

 可以讲讲一致性吗?我也很头疼一致性

别用,缓存只用来计算结果跟文件处理。你顶多用上 hibernate 的 es 跟 env 两个特性。

orm 要什么缓存, 缓存在你接口处实现

 #23 回收机制了解下,单例模式了解下,OOM 了解下,查询缓存了解下,你再回来看看你在说啥内容

 面向对象是面向对象,缓存是缓存,二级缓存其实很烦,不建议使用,我现在就是 hibernate 内存飙升,实际上大多数情况都用不到这个缓存,需要缓存的地方说明得引入 redis 等缓存中间件。

 关于你这个级联查询问题,@OneToMany 确实是直接查数据库的,但是我非常不建议你在实体里面做级联,累一点引入一下 Service 维护起来会好很多,在实体里面做级联非常考验你们表结构设计的合理性,而且不易于维护。

 我测试了下,@OneToMany 级联的对象也有二级缓存,不知道 QQ 群的老哥是怎么测试的。实体类里面做级联我认为是实现模型层的一个主要方法,不然你就没有对象模型了

 当然也可以手动查库之后加载构建对象模型,这就可以不用 jpa 了。或者你不要对象模型,那就跟直接查库,查库之后手动放 redis ,其实相当于一个不完整的对象模型放在 redis 内存里面,手动维护对象间的关联关系

性能不够了再说吧, 不是开始该考虑的问题

 Spring data JPA 的二级缓存,就是个坑。少看点培训班的视频那玩意没用,写 demo 知道原理的实现就行了。做 ToB 项目,用 Spring data JPA 。只是约束下面的人用 HQL ,纯粹是为了解决同时支持国产/mysql/sqlserver/oracle 。findbyId 这种方法在我这边一律禁止用。数据库就是用来持久化的保证最后的一致性的。等有了性能问题 二级三级缓存自己用别的中间件去写啊。生产项目上用这些别人的二级缓存后面怎么死的不知道的

 不要用 这些 这些都没用,后面性能和缓存会出大问题,这些都是以前 Hibernate 搞出来的。那玩意是为了让程序员不用了解 sql 和数据库直接写代码,单这种只针对那种很小的项目没多少业务复杂度和并发量。但实际情况是以目前 java 、Spring 的体量,能选型用到 java+Spring 的项目肯定是很重业务且规模较大的项目如果你用了这些什么 jpa 二级缓存 。这些学了要么用不上,要么不能用java 老老实实研究多线程、网络、jvm 、还有相关的中间件生态更有用,数据库就让它老老实实的 CRUD 做好最后的持久化工作就行了。

面写对象是一个编程的方式或者方法论,对标的是面写过程,要学面写对象 这个 去学设计模式。我理解上是,对于哪怕是面向过程的 C ,也有一个结构体,那玩意就是个简单的类。C 也是可以按照面向对象的方法来写代码,但是得不偿失