dubbo序列化hibernate.LazyInitializationException could not initialize proxy - no Session懒加载异常的解决...

dubbo序列化,hibernate.LazyInitializationException could not initialize proxy - no Session懒加载异常的解决

 

转载声明:请务必保留原文链接

原文连接:http://www.cnblogs.com/sunyl/p/7772260.html

 

版本

1.JDK 1.8

2.Spring Boot ,spring boot jpa 1.5.8

3.dubbo 2.5.6

4.zookeeper 3.4.9

 

异常说明:

使用dubbo作为RPC框架时 发现如果有实体对象有懒加载属性会出现如下异常,我在设 #spring.jpa.open-in-view=true未能解决。

Caused by: org.hibernate.LazyInitializationException: failed to lazily initialize a collection of role: cn.syl.blogmain.pojo.User.roles, could not initialize proxy - no Session
at org.hibernate.collection.internal.AbstractPersistentCollection.throwLazyInitializationException(AbstractPersistentCollection.java:587)
at org.hibernate.collection.internal.AbstractPersistentCollection.withTemporarySessionIfNeeded(AbstractPersistentCollection.java:204)
at org.hibernate.collection.internal.AbstractPersistentCollection.readSize(AbstractPersistentCollection.java:148)
at org.hibernate.collection.internal.PersistentSet.size(PersistentSet.java:143)
at com.alibaba.com.caucho.hessian.io.CollectionSerializer.writeObject(CollectionSerializer.java:92)
at com.alibaba.com.caucho.hessian.io.Hessian2Output.writeObject(Hessian2Output.java:383)
at com.alibaba.com.caucho.hessian.io.JavaSerializer$FieldSerializer.serialize(JavaSerializer.java:294)
... 29 more

 

三种解决方法:

原因是dubbo使用的序列化hessian 对PersistentCollection对象无法识别,有如下三种解决方法:

1.JPA Hibernate禁止懒加载

2.添加自定义dubbo序列化工厂(请参考:http://wzalong.iteye.com/blog/2323787)

3.修改dubbo序列化方式:<dubbo:protocol name="dubbo" port="20880" serialization="java" />

 

由于本人对dubbo研究甚少少 所以目前采用了第三种方式. 

如有高人使用了第二种自定义序列化工厂或其他更好的方式 还请指教,我不太清楚dubbo自定义序列化工厂如何配置.

 

可参考的项目配置(仅包含配置,集成spring boot +dubbo +redis +jpa+shiro): 如果项目对您有帮助请给我一颗star.谢谢~

https://github.com/mmdsyl/BLOG-Microservice/

 

转载于:https://www.cnblogs.com/sunyl/p/7772260.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据您提供的引用内容,配置`dubbo.protocols.dubbo.port=-1`可以开启Dubbo端口的随机分配功能。这样配置后,Dubbo将自动选择一个可用的端口进行通信。 另外,要查看Dubbo进程的端口,可以使用`lsof -i | grep dubbo进程ID | grep LISTEN`命令。该命令会列出所有使用Dubbo协议的进程的信息,包括监听的端口。 关于Dubbo管理平台,您可以下载dubbo-admin.2.5.6.war包并部署自己的服务器上。您提到有一些免积分下载的方法,但是目前最低要求是2个积分。 最后,针对您提到的问题描述`Failed to bind properties under 'spring.dubbo.application' to com.alibaba.dubbo.config.ApplicationConfig: Property: spring.dubbo.application.logger Value: Slf4j Origin: class path resource [application.properties]:17:33 Reason: No such extension com.alibaba.dubbo.common.logger.LoggerAdapter by name Slf4j`,根据这个描述,看起来是在应用配置中使用了`spring.dubbo.application.logger`这个属性,但是`com.alibaba.dubbo.common.logger.LoggerAdapter`扩展中没有名为`Slf4j`的实现[3]。这可能是由于配置文件中的错误或者版本不匹配导致的。您可以检查配置文件中的属性是否正确,或者尝试更新Dubbo的版本来解决问题。 总结起来,配置`dubbo.protocols.dubbo.port=-1`可以开启Dubbo端口的随机分配功能。您可以使用命令`lsof -i | grep dubbo进程ID | grep LISTEN`来查看Dubbo进程的端口。另外,您可以下载dubbo-admin.2.5.6.war包并部署自己的服务器上来使用Dubbo管理平台。对于问题描述中的错误,建议检查配置文件中的属性是否正确或者尝试更新Dubbo的版本。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值