我一直在Play Framework中使用JPA一段时间了,一切都很顺利 - 但是,我现在遇到了一个错误,我没有看到任何明显的解决方案。仅仅针对某些情况,我想要创建的是一个基本的社交网络。
我有一个Post类:
public class Post extends Model {
private String owner;
private long timestamp;
@ElementCollection
private List<String> viewers;
private String content;
public Post(String owner, List<String> viewers, String content) {
this.timestamp = System.currentTimeMillis();
this.owner = owner;
this.viewers = viewers;
this.content = content;
System.out.println("Saving post by " + owner + " with timestamp:" + this.timestamp);
}
(Getters and setters ignored here)
}
我有一个添加帖子的用户类:
public long addPost(String viewers, String content) {
LinkedList<String> viewersList = new LinkedList(Arrays.asList(viewers.split(",")));
Post newPost = new Post(this.name, viewersList, content);
newPost.save();
return newPost.getTimestamp();
}
我有一个StreamManager处理帖子和帖子检索的通知。
public static void executePost(String content, String viewers) {
System.out.println("Post content: " + content);
String user = session.get("username");
User u = User.connect(user);
if (u == null) {
System.out.println("User is null");
}
/* Add post to local record of posts */
long timestamp = u.addPost(viewers, content);
/* Send notification of post to server */
}
我正在使用3个线程的线程池运行我的应用程序,这意味着系统中存在一定量的并发性。当系统在通知(executePost结束)之后等待来自服务器的响应时,另一个线程正在尝试使用以下代码访问新创建的Post:
public static void retrievePost(String owner, String timestamp) {
byte[] postAndKey = new byte[1024];
byte[] post = null;
byte[] encryptedKey = null;
User u = User.connect(owner);
Post.findAll();
//List<Post> posts = (Post.find("byOwner", owner).fetch());
System.out.println("Looking for post by " + owner + " at timestamp: " + timestamp);
//System.out.println("Looking through: " + posts.size() + " posts");
在Post.findAll()
,框架会抛出一个令人讨厌的错误,告诉我有一个Timeout trying to lock table "POST"
。我怀疑这是因为一个帖子仍然在executePost()
,而另一个线程正在尝试访问retrievePost()
中的帖子。然而,考虑到邮政已被“保存”,锁定是否应该被释放?这真的是原因,是否有任何解决错误的方法?
感谢。
答案 0 :(得分:1)
仅供参考,如果其他人遇到类似的问题:我通过使用await()
显式地休眠调用线程来修复它,这意味着它放弃了所有锁,允许{{1}中的线程进入桌子。