我正在保留一个包含与其他几个实体的关系的节点实体。当我一次做一个时,这种持久性很好,但是如果我同时运行它,我会在 org.neo4j.ogm.mapper.EntityGraphMapper 获得 NPE
java.lang.NullPointerException: null
at org.neo4j.ogm.mapper.EntityGraphMapper.updateRelationship(EntityGraphMapper.java:618) ~[neo4j-ogm-1.1.2.jar:na]
at org.neo4j.ogm.mapper.EntityGraphMapper.mapRelationshipEntity(EntityGraphMapper.java:481) ~[neo4j-ogm-1.1.2.jar:na]
at org.neo4j.ogm.mapper.EntityGraphMapper.link(EntityGraphMapper.java:330) ~[neo4j-ogm-1.1.2.jar:na]
at org.neo4j.ogm.mapper.EntityGraphMapper.mapEntityReferences(EntityGraphMapper.java:265) ~[neo4j-ogm-1.1.2.jar:na]
at org.neo4j.ogm.mapper.EntityGraphMapper.mapEntity(EntityGraphMapper.java:158) ~[neo4j-ogm-1.1.2.jar:na]
这是我的节点实体的症结所在:
@NodeEntity
public class Post {
@Relationship(type = "POST_BY_USER", direction = Relationship.INCOMING)
User poster;
@Relationship(type = "POST_TO_STORE", direction = Relationship.OUTGOING)
Store toStore;
@Relationship(type = "POST_PRODUCT", direction = Relationship.INCOMING)
Product product;
@Relationship(type = "POST_INSPIRATION", direction = Relationship.INCOMING)
Product_Inspiration productInspiration;
}
我尝试同时使用带有 (@Transactional) 的 GraphRepository 以及使用带有事务的会话,在这两种情况下,我都遇到了同样的并发问题。
有人可以让我知道如何解决这个问题吗?由于我在轰炸并发请求时遇到了这个问题,所以我不确定这是否与代码流本身有关。
根据 Vince 关于如何发送并发请求的代码的要求,我正在使用带有 Play 的 axon cqrs 框架,并向我的 Play 应用程序的 rest API 发送多个并发请求,该 API 通过 axon 通过 postProduct 方法调用对 Neo4j 的并发写入。这是我编写代码的样子。
def postProduct(productId: ProductId, product2Post: Product2Post): Post = workNLogOnFail(
doPost(productId, product2Post),
"postProduct"
)
private def doPost(productId: ProductId, product2Post: Product2Post): Post = {
val product: Product = configureDomainEntity(productId, product2Post)
val storeId: StoreId = storeService1.findOrCreateStore(product2Post.host)
val post: Post = commonService.configurePost(product2Post.commonData2Post.relationInfo, isProduct = true) { (x: Post) =>
x.setToStore(storeService1.updateStoreForProductPost(x, storeId))
x.setProduct(product)
}
val persistedPost = xtPostProduct(product, post)
commonService.addUrlMapping(product2Post.commonData2Post, productId.identifier)
persistedPost
}
private def xtPostProduct(product: Product, post: Post): Post = {
Try {
val tx: Transaction = session.beginTransaction()
logger.debug(s"saving product")
// session.save(product)
logger.debug(s"updating user")
// session.save(post.getPoster)
logger.debug(s"posting product")
session.save(post)
tx.commit()
post
}.get
}
我在 xtPostProduct 方法中尝试了 @Transanctional 和 GraphRepository 以及会话。