java.lang.IllegalStateException
在启动项目时出现java.lang.IllegalStateException: Failed to register dubbo://10.254.9.100:20880/…
查看相关博友的博客和百度后才知道问题的所在,是因为项目中涉及到需要传输的对象没有实现Serializable接口,才导致此问题。
public class IdleUser implements Serializable{
private int id;
private String username;
private String password;
private int gender;
private Date startTime;
private String size;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
在对象中实现此接口后,问题得到解决。
还有一种情况可能是因为Zookeeper的版本过高和客户端版本不一致如下:
将Zookeeper的依赖版本降低就解决了。
为什么需要实现Serializable接口?
序列化就是对实例对象的状态(State 对象属性而不包括对象方法)进行通用编码(如格式化的字节码)并保存,以保证对象的完整性和可传递性。
简而言之:序列化,就是为了在不同时间或不同平台的JVM之间共享实例对象。
如没有 实现Serializable接口,在序列化时,使用ObjectOutputStream的write(object)方法将对象保存时将会出现异常。其实 java.io.Serializable 只是一个没有属性和方法的空接口,但是问题来了。
技术改变世界。