Есть сценарий, когда клиент запускает cordapp через RPC и ждет результата.
rpcConnection.proxy
.startFlow(::ImportAssetFlow, importDto)
.returnValue
.get(importTimeout /* 30000 ms */, TimeUnit.MILLISECONDS)
Поток срабатывает правильно и возвращает ответ, но проблема с медленным откликом после обработки потока. В конце кодового блока FlowLogic.call () ответ должен быть возвращен клиенту через сообщение Artemis. Результат возвращается клиенту через будущее Corda через 12 секунд.
На стороне клиента в журнале lvl отладки RPCClientProxyHandler, чтобы проверить, как работает процесс:
2020-01-08 12:12:45.982 DEBUG [,,,] 78798 --- [global-threads)] n.c.c.r.internal.RPCClientProxyHandler : Got message from RPC server RpcReply(id=fc317c4a-3de4-4936-b4c3-768b8b727245, timestamp: 2020-01-08T10:12:44.237Z, entityType: Invocation, result=Success(FlowHandleImpl(id=[16566124-f7d2-41cf-b3a4-f86846073632], returnValue=net.corda.core.internal.concurrent.CordaFutureImpl@58f8aa01)), deduplicationIdentity=e3f6d696-dea4-45b0-95b8-f9c0fe363a9f)
2020-01-08 12:12:45.986 DEBUG [,,,] 78798 --- [global-threads)] n.c.c.r.internal.RPCClientProxyHandler : Got message from RPC server Observation(id=b3f0b064-6d82-4900-85e6-e70b7d00926a, timestamp: 2020-01-08T10:11:26.411Z, entityType: Invocation, content=[rx.Notification@b461fac0 OnNext Added(stateMachineInfo=StateMachineInfo([16566124-f7d2-41cf-b3a4-f86846073632], ***.workflow.asset.flow.ImportAssetFlow))], deduplicationIdentity=e3f6d696-dea4-45b0-95b8-f9c0fe363a9f)
2020-01-08 12:12:45.987 DEBUG [,,,] 78798 --- [global-threads)] n.c.c.r.internal.RPCClientProxyHandler : Got message from RPC server Observation(id=12887a04-f22c-422d-b684-c679f137d66b, timestamp: 2020-01-08T10:12:45.979Z, entityType: Invocation, content=[rx.Notification@4c59250 OnNext Starting], deduplicationIdentity=e3f6d696-dea4-45b0-95b8-f9c0fe363a9f)
2020-01-08 12:12:58.603 DEBUG [,,,] 78798 --- [global-threads)] n.c.c.r.internal.RPCClientProxyHandler : Got message from RPC server Observation(id=b83c15ca-9047-4958-a106-65165e5abfbd, timestamp: 2020-01-08T10:12:45.975Z, entityType: Invocation, content=[rx.Notification@e03cfa2d OnNext [B@2dceac3d], deduplicationIdentity=e3f6d696-dea4-45b0-95b8-f9c0fe363a9f)
2020-01-08 12:12:58.605 DEBUG [,,,] 78798 --- [global-threads)] n.c.c.r.internal.RPCClientProxyHandler : Got message from RPC server Observation(id=b83c15ca-9047-4958-a106-65165e5abfbd, timestamp: 2020-01-08T10:12:45.975Z, entityType: Invocation, content=[rx.Notification@15895539 OnCompleted], deduplicationIdentity=e3f6d696-dea4-45b0-95b8-f9c0fe363a9f)
Между событиями большой разрыв
12:12:45.987 OnNext Starting
- начало потока, потребляющего 1к объектов12:12:58.603 OnNext [B@2dceac3d]
- фактический результат операции. Таким образом, время возврата ответа составляет ~ 12,5 с.
Согласно Jprofiler, Corda обработала поток за ~ 1,3 секунды и отправила результат обратно.
Что может быть причиной такого поведения, медленного ведения журнала сообщений Artemis?
UPD: обнаружено, что Corda имеет механизм приостановки / возобновления (контрольные точки), чтобы сохранить состояние потока на Диск и в будущем прочитать его снова и возобновить этот поток. net.corda.node.services.statemachine.FlowStateMachineImpl # запускает запуск co.paralleluniverse.fibers.Fiber # parkAndSerialize. Кажется, это один из потребителей времени.
Заранее большое спасибо