- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想使用kundera作为apachestorm的dao层,将数据存储在cassandra数据库中。我的拓扑创建没有任何问题,我可以接收消息,但是当我尝试将数据存储在数据库中时,我收到消息:
26240 [main-EventThread] INFO o.a.s.s.o.a.c.f.s.ConnectionStateManager - State change: CONNECTED
26275 [main] INFO o.a.s.d.supervisor - Starting supervisor with id 1db18608-a2df-47e0-8ae6-cc634c90f81d at host 10.0.0.4
26308 [main] ERROR o.a.s.s.o.a.z.s.NIOServerCnxnFactory - Thread Thread[main,5,main] died
java.lang.IllegalStateException: Bolt 'bolt1' contains a non-serializable field of type com.impetus.kundera.persistence.EntityManagerImpl, which was instantiated prior to topology creation. com.impetus.kundera.persistence.EntityManagerImpl should be instantiated within the prepare method of 'bolt1 at the earliest.
at org.apache.storm.topology.TopologyBuilder.createTopology(TopologyBuilder.java:127) ~[storm-core-1.0.0.jar:1.0.0]
at topology.ConnectorTopology.main(ConnectorTopology.java:52) ~[Zorro-0.0.1-SNAPSHOT-jar-with-dependencies.jar:?]
Caused by: java.lang.RuntimeException: java.io.NotSerializableException: com.impetus.kundera.persistence.EntityManagerImpl
at org.apache.storm.utils.Utils.javaSerialize(Utils.java:167) ~[storm-core-1.0.0.jar:1.0.0]
at org.apache.storm.topology.TopologyBuilder.createTopology(TopologyBuilder.java:122) ~[storm-core-1.0.0.jar:1.0.0]
... 1 more
Caused by: java.io.NotSerializableException: com.impetus.kundera.persistence.EntityManagerImpl
at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1183) ~[?:1.7.0_99]
at java.io.ObjectOutputStream.defaultWriteFields(ObjectOutputStream.java:1547) ~[?:1.7.0_99]
at java.io.ObjectOutputStream.writeSerialData(ObjectOutputStream.java:1508) ~[?:1.7.0_99]
at java.io.ObjectOutputStream.writeOrdinaryObject(ObjectOutputStream.java:1431) ~[?:1.7.0_99]
at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1177) ~[?:1.7.0_99]
at java.io.ObjectOutputStream.defaultWriteFields(ObjectOutputStream.java:1547) ~[?:1.7.0_99]
at java.io.ObjectOutputStream.writeSerialData(ObjectOutputStream.java:1508) ~[?:1.7.0_99]
at java.io.ObjectOutputStream.writeOrdinaryObject(ObjectOutputStream.java:1431) ~[?:1.7.0_99]
at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1177) ~[?:1.7.0_99]
at java.io.ObjectOutputStream.defaultWriteFields(ObjectOutputStream.java:1547) ~[?:1.7.0_99]
at java.io.ObjectOutputStream.writeSerialData(ObjectOutputStream.java:1508) ~[?:1.7.0_99]
at java.io.ObjectOutputStream.writeOrdinaryObject(ObjectOutputStream.java:1431) ~[?:1.7.0_99]
at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1177) ~[?:1.7.0_99]
at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:347) ~[?:1.7.0_99]
at org.apache.storm.utils.Utils.javaSerialize(Utils.java:163) ~[storm-core-1.0.0.jar:1.0.0]
at org.apache.storm.topology.TopologyBuilder.createTopology(TopologyBuilder.java:122) ~[storm-core-1.0.0.jar:1.0.0]
... 1 more
在topologybuilder类中我有:
brokerSpout = new BrokerSpout(rabbitMQAMQP);
builder.setSpout("spout1", brokerSpout);
printerbolt = new PrinterBolt();
builder.setBolt("bolt1", printerbolt).shuffleGrouping("spout1");
在我的类 dao 中(它实现了可序列化接口(interface))
private EntityManager em;
@Transient
private EntityManagerFactory emf;
public SensorDAOImpl() {
// TODO Auto-generated constructor stub
emf = Persistence.createEntityManagerFactory("cassandra_pu");
em = emf.createEntityManager();
}
@Override
public void insert(Object entity)
{
em.persist(entity);
}
我的 bolt 代码
private OutputCollector collector;
public PrinterBolt() {
this.index=0;
EntityManagerFactory emf = Persistence.createEntityManagerFactory("cassandra_pu");
EntityManager em= emf.createEntityManager();
database= new DatabaseController(em);
// TODO Auto-generated constructor stub
}
/* (non-Javadoc)
* @see org.apache.storm.task.IBolt#execute(org.apache.storm.tuple.Tuple)
*/
public void prepare(@SuppressWarnings("rawtypes") Map config, TopologyContext context,
OutputCollector collector) {
this.collector = collector;
}
public void execute(Tuple tuple) {
//tuple.getBinaryByField(arg0)
String message = tuple.getStringByField("message");
System.out.println("Receive ["+index+"]"+message);
database.saveEntitie(tuple.getBinaryByField("message"));
index++;
}
那么,我该如何解决这个问题,(我无法触及 com.impetus.kundera.persistence.EntityManagerImpl 类)
最佳答案
在 Bolt 的准备方法中实例化 com.impetus.kundera.persistence.EntityManagerImpl
类型的字段。
public void prepare(@SuppressWarnings("rawtypes") Map config, TopologyContext context,
OutputCollector collector) {
emf = Persistence.createEntityManagerFactory("cassandra_pu");
em = emf.createEntityManager();
database = new DatabaseController(em);
this.collector = collector;
}
关于java.io.NotSerializedException : com. impetus.kundera.persistence.EntityManagerImpl,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37120093/
我现在正把头撞到墙上。 事情是这样的:我创建了一个 BlockList 类,在其中创建 block 列表。这个类是序列化的,Block 类也是序列化的(也是我在 Block 类中使用的 RGB 类)。
我收到以下错误: java.io.NotSerializableException: cscie55.project.AccountInfo 我的 AccountInfo 类未实现 java.io.S
下面的代码抛出 java.io.NotSerializedException。为什么?谢谢! private void test3() { Element3 element3=new Eleme
我尝试在 Spark 中跨 JavaRDD 映射函数,但在 map 调用中不断收到 NotSerializedError 错误。 public class SparkPrunedSet extends
我在 Android 上,尝试将对象列表保存到文件中,但总是遇到此异常:java.io.NotSerializedException: android.app.Application。 p> 我试图找
我有一个实现可序列化的类,但每当我尝试将其写入磁盘时,我都无法找到它抛出此异常的原因。我正在尝试编写 ValueConatiner.class public class ValueContainer
我仅在第一次时在 objStream.writeObject(myobj) 中收到 NotSerializedException。 myobj 内部包含对象列表。同一个 myobj,当它不是第一个时,
所以今天我正在为 Minecraft 服务器开发一个插件。为此,我创建了一个代表赛道的“Track”类。为了存储所有现有轨道及其数据,我想保存整个轨道对象,这使一切对我来说更容易。总之,我在 Trac
我正在构建一个带有服务器和多个客户端的聊天应用程序。当用户连接到服务器时,服务器调用 notify_clients() 并向每个客户端发送在线客户端列表,以显示在客户端“在线列表”中。 serve
我正在使用 Ehcache 试验 XA 事务。目前我正在使用 Spring 事务管理和 Bitronix 作为事务管理器。 我使用以下方法创建、配置和填充缓存: @Transactional publ
我正在使用 primefaces 和 web 2.0 进行 j2ee目前因此错误而卡在此处 java.io.NotSerializableException: org.apache.derby
我正在使用 Javafx,并将对象包装到 ListProperty 中,以便让 TableView 针对列表对象的任何更改进行更新。现在我正在尝试序列化我的项目和对象的 ListProperty,它向
我使用的是quartz 1.5.2 和 spring 3.0.5 版本。当我尝试使用 jdbc 存储类型quartz 获取调度程序上下文时,我面临 NotSerializedException。我已经
我需要将 Cursor 对象从一个 Android 模拟器传递到另一个。但是当我尝试序列化它时,出现“NotSerialableException:android.database.sqlite.SQ
我正在用 Java 编写一个应用程序,它需要做的部分工作是序列化一些对象,以便以后可以导入它们。当我编写序列化代码时,它无法正常工作。经过多次修改,我相信我已经将其范围缩小到只有几个属性,并包含了触发
我在 Android 应用程序中使用 ObjectOutputStream 和 ObjectInputStream 保存和读取保存在文件中的对象时遇到一些问题我有两个类(class)“锻炼”和“锻炼”
这个问题已经有答案了: java.io.WriteAbortedException: writing aborted; java.io.NotSerializableException (2 个回答)
我正在尝试使用 ObjectInputStream 从 .dat 文件读取对象数组(称为 PWlist)。该数组包含两个不同的对象:LongPW 和 PinPW。当我尝试执行读取时,我收到此异常...
我正在评估在 JTextPane(textpane) 中用作编辑器套件的 StyledEditorKit 的可用性。一旦用户在编辑器中键入任何内容并关闭编辑器,程序就会获取 Document(text
我正在尝试将行集的内容打印到文件中,但出现 java.io.NotSerializedException: 这是我的程序.. package k564; import java.io.*; impor
我是一名优秀的程序员,十分优秀!