Проблема сериализации с узлом Corda как докер - PullRequest
1 голос
/ 29 марта 2019

Я пытаюсь запустить узел корды как докер, как контейнер.Код докера:

    docker run -ti \
    --memory=2048m \
    --cpus=2 \
    -v /home/dlt-acc-admin/corda/docker-images/node-notary/Notary/config:/etc/corda \
    -v /home/dlt-acc-admin/corda/docker-images/node-notary/Notary/certificates:/opt/corda/certificates \
    -v /home/dlt-acc-admin/corda/docker-images/node-notary/Notary:/opt/corda/persistence \
    -v /home/dlt-acc-admin/corda/docker-images/node-notary/Notary/logs:/opt/corda/logs \
    -v /home/dlt-acc-admin/corda/docker-images/node-notary/Notary/cordapps:/opt/corda/cordapps \
    -v /home/dlt-acc-admin/corda/docker-images/node-notary/Notary/node-infos:/opt/corda/additional-node-infos \
    -v /home/dlt-acc-admin/corda/docker-images/node-notary/Notary/network-parameters:/opt/corda/network-parameters \
    -v /home/dlt-acc-admin/corda/docker-images/node-notary/Notary/node.conf:/etc/corda/node.conf \
    -p 10002:10002 \
    -p 10004:10004 \
    -p 10045:10045 \
    -p 9002:9002 \
    corda/corda-zulu-4.0

Когда я пытаюсь создать RPC-соединение, я получаю сообщение об ошибке ниже:

a_2==$shiro1$SHA-256$500000$4WdM0Gi63LSSHqiM543f4Q==$NOYlBrHAQBwdeWtEpYRcznRUR02o2jor/OhRvn9/tnc=
[http-nio-8080-exec-1] INFO com.dlt.accelerator.serviceImpl.UserLoginServiceImpl - UserLoginServiceImpl >> createCordaRPCConnection params ==>>172.16.239.103==10008
[Thread-0 (ActiveMQ-client-global-threads)] WARN net.corda.nodeapi.internal.serialization.SerializationFactoryImpl - Cannot find serialization scheme for: ([636F726461010000], RPCClient), registeredSchemes are: [net.corda.client.rpc.internal.KryoClientSerializationScheme@22a6a670, net.corda.nodeapi.internal.serialization.amqp.AMQPClientSerializationScheme@3a06fb64]
E 05:28:57 56 client.run - AMQ214000: Failed to call onMessage
 java.lang.UnsupportedOperationException: Serialization scheme not supported.
        at net.corda.nodeapi.internal.serialization.NotSupportedSerializationScheme.doThrow(SerializationScheme.kt:19) ~[corda-node-api-3.3-corda.jar:?]
        at net.corda.nodeapi.internal.serialization.NotSupportedSerializationScheme.deserialize(SerializationScheme.kt:23) ~[corda-node-api-3.3-corda.jar:?]
        at net.corda.nodeapi.internal.serialization.SerializationFactoryImpl$deserialize$1$1.invoke(SerializationScheme.kt:111) ~[corda-node-api-3.3-corda.jar:?]
        at net.corda.core.serialization.SerializationFactory.withCurrentContext(SerializationAPI.kt:66) ~[corda-core-3.3-corda.jar:?]
        at net.corda.nodeapi.internal.serialization.SerializationFactoryImpl$deserialize$1.invoke(SerializationScheme.kt:111) ~[corda-node-api-3.3-corda.jar:?]
        at net.corda.nodeapi.internal.serialization.SerializationFactoryImpl$deserialize$1.invoke(SerializationScheme.kt:86) ~[corda-node-api-3.3-corda.jar:?]

Я использую Corda 3.3, но изображение coda-zulu отсутствует, кромеCorda 4.0.

Я думал, что Corda 4.0 обратно совместим с 3.x.Это не?Обновление не соответствует текущим требованиям, поэтому не могли бы вы помочь мне здесь?

1 Ответ

0 голосов
/ 07 июня 2019

Вам нужно будет перестроить свой клиент против Corda4.0

Механизм сериализации был изменен при обновлении Corda до 4.0. Вот это документы о сериализации Corda4.0: https://docs.corda.net/serialization-index.html

И последний механизм сериализации Corda4.0 не имеет обратной совместимости с 3.3.

...