- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我在分布式环境中使用orientdb 2.22,当我使用并发线程写入数据并且发生此类异常时
错误:
com.orientechnologies.orient.server.distributed.task.ODistributedRecordLockedException: Timeout (5000ms) on acquiring lock on record #46:0 on server 'node75'. It is locked by request 0.324309
DB name="graphics"
DB name="graphics"
OrientGraph graph = getOrientGraphTx();
graph.command(new OCommandScript(sql)).execute();
BEGIN <br/>
LET a0 = CREATE EDGE tic FROM #17:0 TO #52:0<br/>
LET a1 = CREATE EDGE trip FROM #17:0 TO #28:0<br/>
LET a2 = CREATE EDGE tmtel FROM #17:0 TO #59:0<br/>
COMMIT RETRY 0<br/>
RETURN [$a0, $a1, $a2]<br/>
最佳答案
如何复制它:
方案1:
我将复制配置为a同步模式。在我的应用程序中,我仅指向群集中的一个节点,例如remote:192.168.2.3/graphics,当我关闭该节点时,它会引发异常:
ODistributedRecordLockedException:获取服务器'node75'上的记录#46:0的锁定时超时(5000ms)。
在服务器端,精细日志显示:
2017-08-24 10:17:28:965 FINE [mac15]分布式事务0.1312:已取消(锁定= [] undo = 0 startsOn = Thu Aug 24 10:16:55 CST 2017线程= 12)[ODistributedTxContextImpl]
2017-08-24 10:17:28:965 FINE [mac15]分布式事务0.1312:在数据库'graphics'上回滚事务(undo = 0 tx = false)[ODistributedTxContextImpl]
2017-08-24 10:17:28:965 FINE [mac15]数据库“图形”上的分布式事务0.1322在32111ms后过期[ODistributedDatabaseImpl $ 8]
2017-08-24 10:17:28:965 FINE [mac15]分布式事务0.1322:已取消(锁定= [] undo = 0 startsOn = Thu Aug 24 10:16:56 CST 2017线程= 12)[ODistributedTxContextImpl]
2017-08-24 10:17:28:965 FINE [mac15]分布式事务0.1322:回滚数据库'graphics'上的事务(undo = 0 tx = false)[ODistributedTxContextImpl]
2017-08-24 10:17:28:965 FINE [mac15]数据库“图形”上的分布式事务0.1327在31518ms后过期[ODistributedDatabaseImpl $ 8]
2017-08-24 10:17:28:965 FINE [mac15]分布式事务0.1327:已取消(锁定= [] undo = 0 startsOn = Thu Aug 24 10:16:57 CST 2017线程= 12)[ODistributedTxContextImpl]
2017-08-24 10:17:28:965 FINE [mac15]分布式事务0.1327:回滚数据库'graphics'上的事务(undo = 0 tx = false)[ODistributedTxContextImpl]
2017-08-24 10:17:28:965 FINE [mac15]数据库“图形”上的分布式事务0.1337在30206ms后过期[ODistributedDatabaseImpl $ 8]
2017-08-24 10:17:28:965 FINE [mac15]分布式事务0.1337:已取消(锁定= [] undo = 0 startsOn = Thu Aug 24 10:16:58 CST 2017线程= 12)[ODistributedTxContextImpl]
2017-08-24 10:17:28:965 FINE [mac15]分布式事务0.1337:回滚数据库'graphics'上的事务(undo = 0 tx = false)[ODistributedTxContextImpl]
2017-08-24 10:17:28:965 FINE [mac15]数据库“图形”上的分布式事务0.1332在30967ms后过期[ODistributedDatabaseImpl $ 8]
2017-08-24 10:17:28:965 FINE [mac15]分布式事务0.1332:已取消(锁定= [] undo = 0 startsOn = Thu Aug 24 10:16:57 CST 2017线程= 12)[ODistributedTxContextImpl]
2017-08-24 10:17:28:965 FINE [mac15]分布式事务0.1332:在数据库'graphics'上回滚事务(undo = 0 tx = false)[ODistributedTxContextImpl]
2017-08-24 10:17:28:970 FINE [mac15]分布式事务:0.1562无法锁定记录[#20:-2,#26:0,#43:0,#53:0,#104:-5 ,#116:-4,#120:-3],因为归0.1563拥有(重试5/10,线程= 110)[ODistributedTransactionManager]
2017-08-24 10:17:28:971 FINE [mac15]分布式事务:0.1563无法锁定记录[#20:-2,#26:0,#43:0,#53:0,#104:-5 ,#116:-4,#120:-3],因为归0.1447所有(重试5/10,线程= 105)[ODistributedTransactionManager]
2017-08-24 10:17:28:971 FINE [mac15]在数据库“图形”上启动分布式事务...(reqId = 0.1565线程= 109)[ODistributedTransactionManager]
2017-08-24 10:17:28:971 FINE [mac15]分布式事务:数据库'graphics'中注册的请求0.1565(thread = 109)[ODistributedDatabaseImpl]
2017-08-24 10:17:28:976 FINE [mac15]分布式事务:0.1558无法锁定记录[#19:-2,#26:0,#43:0,#53:0,#101:-5 ,#114:-4,#117:-3],因为归其所有0.1560(重试9/10,线程= 113)[ODistributedTransactionManager]
2017-08-24 10:17:28:977 FINE [mac15]分布式事务:0.1564无法锁定记录[#19:-2,#26:0,#43:0,#53:0,#101:-5 ,#114:-4,#117:-3],因为归0.1560拥有(重试1/10,线程= 112)[ODistributedTransactionManager]
2017-08-24 10:17:28:977 FINE [mac15]分布式事务:0.1560无法锁定记录[#19:-2,#26:0,#43:0,#53:0,#101:-5 ,#114:-4,#117:-3],因为归0.1447所有(重试6/10,线程= 115)[ODistributedTransactionManager]
2017-08-24 10:17:29:025 FINE [mac15]分布式事务:0.1561无法锁定记录[#20:-2,#26:0,#43:0,#53:0,#104:-5 ,#116:-4,#120:-3],因为归0.1447所有(重试6/10,线程= 114)[ODistributedTransactionManager]
2017-08-24 10:17:29:030 FINE [mac15]分布式事务:0.1559无法锁定记录[#19:-2,#26:0,#43:0,#53:0,#101:-5 ,#114:-4,#117:-3],因为归0.1447所有(重试7/10,线程= 111)[ODistributedTransactionManager]
2017-08-24 10:17:29:067 FINE [mac15]分布式事务:0.1558无法锁定记录[#19:-2,#26:0,#43:0,#53:0,#101:-5 ,#114:-4,#117:-3],因为归0.1447所有(重试10/10,线程= 113)[ODistributedTransactionManager]
2017-08-24 10:17:29:067 FINE [mac15]分布式事务无法完成,请等待12ms然后重试(1/10)[ODistributedStorage]
关于java - Orientdb并发问题-获取服务器'node75'上的记录#46:0的锁定时超时(5000ms)。已被请求锁定0.324309,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45821426/
我对 OrientDB 中的多重继承很好奇...假设我创建了以下顶点类: CREATE CLASS A EXTENDS V CREATE PROPERTY A.label STRING CREATE
generic 类和vertex 或edge 类有什么区别?你为什么要用一个而不是另一个? 最佳答案 OrientDB 是一个多模型数据库。文档中介绍了数据建模: http://orientdb.co
如何在 Orientdb 中使 Edge 独一无二。 我想出的解决方案: 删除边 重新创建 但这并不好。 Edge 没有任何属性。 示例: create edge is_friend from #12
这是我现在使用的查询: INSERT INTO details SET name = "INITIALIZE",actionMap ={"1":12:1,"2":12:2}; 这里 12:1,12:2
考虑我们有 Vertex User 和 Edge FriendsWith。FriendsWith 可以在两个方向上进出(通常是在 2 个用户之间或在 2 个用户之间)。 重复是指从一个用户到另一个用户
是否可以删除 OrientDB 文档中嵌入列表中的一项?我有一个“个人数据”文档,其中包含“查询”列表。例如 { name: "Marco", inquiries: [{date: 2014-11-2
我想查询具有特定属性的文档。 我尝试了以下方法: select * from Foo where not bar is null 但这会返回我的文档,即使它们没有该属性。即使它可以工作,但如果存在以
我的问题是,我如何查询“聊天”表以检索个人资料表中的人员详细信息。 ParticipatinIn edge 从 Person 开始聊天。HasProfile Edge 开始了个人资料。 请帮我解决这个
我想查询具有特定属性的文档。 我尝试了以下方法: select * from Foo where not bar is null 但这会返回我的文档,即使它们没有该属性。即使它可以工作,但如果存在以
是否有可能得到一个例子来在 orientdb 中插入一条边。如果它不存在,有没有办法检查边是否存在,如果存在则只更新边,否则创建新边。我使用的是 Orientdb 2.1.13 版本。谢谢 最佳答案
我试图让 OrientDB Studio 显示一个字符串作为每个节点的标签,就像 Susheel Kumar 的这个截图一样 但是,当我运行 Susheel 的代码(为后代发布在下面)时,节点全部显示
我有一个相当复杂的查询 SELECT FROM ( SELECT EXPAND(INV()) FROM ( SELECT FROM ( SELECT EXPAND(OUTE('
我猜这是一个令人尴尬的初学者问题,无论如何... 在“服务器安全”下的 OrientDB 文档中,我们发现: While OrientDB Server can function as a regul
我有一个 CSV 文件,有 Id1 和 Id2。 Id1 和 Id2 是两个不同类的顶点。我想在 Id1 和 Id2 之间取得优势。这可以通过ETL实现吗? 我们可以在变压器的边缘配置中添加一些东西来
我正在研究 OrientDB 进行学术研究。我们应该关注的一个重要部分是 ACID 范式。 OrienDB 手册说: OrientDB is an ACID compliant DBMS. 它还说:
我正在使用 OrientDB 2.1.9 并创建了名为“TimespentEvents”的 plocal 图数据库。 当尝试在同一台机器上使用 JDBC 驱动程序从 Java 连接 URL 'jdbc
我想在 OrientDB 中使用蓝图和管道。 方法是什么?还有 TinkerPop3 或 TinkerPop2?哪个更适合我的学习体验? 最佳答案 OrientDB 的最新版本在本地实现了 Bluep
我一直在尝试使用 OrientDB 提供的“工作室”将 gremlin 与 OrientDB (V 3.0.30) 一起使用,但每次我尝试运行 gremlin 查询,例如 g.V我收到错误:com.o
昨天我们的 nexus 存储库实例由于磁盘已满事件而横盘整理。释放一些空间并尝试重新启动后,nexus 不再可用。结果,数据库损坏(大概)并且无法连接。当我运行 nexus-orient-consol
我正在使用带有 OrientDb Studio 2.2.8 的车辆历史数据库,并且我想要投影 automobile 类由 起亚。 数据库的架构如下所示: (汽车)--isModel-->(型号)--i
我是一名优秀的程序员,十分优秀!