Corda Enterprise Edition 4.11ã§ã¢ãŒã«ã€ããµãŒãã¹ã䜿çšããŠããå Žåã¯ãã¢ãŒã«ã€ããµãŒãã¹ã®ãªãªãŒã¹1.0.xã¹ããªãŒã ã䜿çšããå¿ èŠããããŸãã詳现ã¯ãã¢ãŒã«ã€ããµãŒãã¹ããåç §ãã ããã
Corda Enterprise 4.11.5
Corda Enterprise Edition 4.11.5 ã¯ãåé¡ã®è§£æ±ºã«çŠç¹ãåœãŠã Corda Enterprise Edition ã®ããããªãªãŒã¹ã§ãã
ä¿®æ£ãããåé¡
- DriverDSLã䜿çšããŠTest Nodeããããã€ããéã
NoSuchMethodError
ãšããäŸå€ãçºçããããšãªããNodeãæ£åžžã«èµ·åããããã«ãªããŸããã - DriverDSLã䜿çšããŠãã¹ããè¡ãéãX.500åã®
O
ãã£ãŒã«ãå€ãåäžãã€OU
å€ãç°ãªã2ã€ã®Nodeãäœæã§ããããã«ãªããŸããã ReceiveTransactionFlow
ãæ¹åãããnetwork parametersãåŠçããéã®æœåšçãªåé¡ã«å¯ŸåŠã§ããããã«ãªããŸããã以åã¯ãResolveTransactionFlow
ãå®è¡ããåã«ããã©ã³ã¶ã¯ã·ã§ã³äžã®network parametersã®ååšãæ€èšŒãããŠããŸããããã®ããã移è¡ããããããã¯ãŒã¯ã®æ°ããNodeã«ãããã¬ãã«ã®ãã©ã³ã¶ã¯ã·ã§ã³ãéä¿¡ãããããªã·ããªãªã§ã¯ãæ°ããNodeã«å€ãnetwork parametersãå©çšã§ãããåé¡ãçºçããå¯èœæ§ããããŸããããã®åäœã¯çŸåšä¿®æ£ãããŠããŸãã- ããŒãã£ã®ç¹å®ã§ã
wellKnownPartyFromAnonymous
ã®ç¹å®ã®ã³ãŒããã¹ã§X.500åã®ç¹å®ãè©Šã¿ãéã«ãnetwork parametersã§æå®ãããNotaryãèæ ®ãããŠããŸããã§ããããã®åé¡ã¯ãæè¿ç§»è¡ãããããã¯ãŒã¯ã«æ°ããNodeãå°å ¥ããéã«çºçããå¯èœæ§ããããŸãããæ°ããNodeã«ã¯ãnetwork mapã«èšèŒãããŠããå€ãNotaryãå«ãŸããŠããªãå¯èœæ§ãããããã§ãããã®åé¡ã¯ä¿®æ£ãããwellKnownPartyFromAnonymous
ã§ã¯ãnetwork parametersã®Nodeããã§ãã¯ã«æ£ããå«ãŸããŠããŸãã - ãã¹ãã®ããã«äžé£ã®mock networksãäœæããéã«ãã¡ã¢ãªãªãŒã¯ãçºçããªããªããŸããã
- ãã©ã³ã¶ã¯ã·ã§ã³ãªã«ããªããµããŒãããããã«CordaããŒãžã§ã³4.11ã§å°å ¥ããããin-flight transactionããšããç¶æ ãæã€ãã©ã³ã¶ã¯ã·ã§ã³ã¯ãLedger Graph CorDappããã©ã³ã¶ã¯ã·ã§ã³ã°ã©ããæ§ç¯ããéã«å«ãŸããªããªããŸãããCorDappã¯çŸåšãin-flightã®ç¶æ ãæã€ãã¹ãŠã®ãã©ã³ã¶ã¯ã·ã§ã³ãç¡èŠããŸãã
æ°æ©èœãæ©èœåŒ·åãããã³å¶éäºé
- R3ãæäŸããCorDappsã®Contract JAR signing keyã®ããŒããŒã·ã§ã³ãããã®ããããªãªãŒã¹ã«å«ãŸããŠããŸãã
- Docker imageã¯çŸåšãJava 8 build 432ãããŒã¹ãšããŠããŸãã
ãµãŒãããŒãã£ã³ã³ããŒãã³ãã®ã¢ããã°ã¬ãŒã
次ã®è¡šã¯ã4.11.4ãš4.11.5éã®äŸåé¢ä¿ããŒãžã§ã³ã®å€æŽç¹ã瀺ããŠããŸãã
Dependency | Name | Version 4.9.10 Enterprise | Version 4.9.11 Enterprise |
org.eclipse.jetty:* | Jetty | 9.4.53.v20231009 | 9.4.56.v20240826 |
commons-io:commons-io | commons IO | 2.6 | 2.17.0 |
com.fasterxml.jackson.*:* | Jackson | 2.17.2 | 2.14.0 |
com.zaxxer:HikariCP | Hikari | 3.3.1 | 4.0.3 |
org.apache.sshd:sshd-common | sshd | 2.9.2 | 2.13.2 |
Corda Enterprise 4.11.4
Corda Enterprise Edition 4.11.4 ã¯ãåé¡ã®è§£æ±ºã«çŠç¹ãåœãŠã Corda Enterprise Edition ã®ããããªãªãŒã¹ã§ãã
ä¿®æ£ãããåé¡
ReceiveFinalityFlow
ã¯ãNotaryã®çœ²åã®ãªãååŒãè¿ããŠããŸãããããã¯çŸåšä¿®æ£ãããè¿ãããååŒã«ã¯Notaryã®çœ²åãå«ãŸããŠããŸãã- ãããŸã§
ReceiveTransactionFlow
ã¯ãResolveTransactionFlow
ã®å®è¡åã«ããã©ã³ã¶ã¯ã·ã§ã³äžã®network parametersãååšããããšã確èªããŠããŸãããããã¯ãç¹å®ã®ã·ããªãªã§åé¡ãåŒãèµ·ããå¯èœæ§ããããŸãããäŸãã°ã移è¡ããããããã¯ãŒã¯ã®æ°ããNodeã«ãããã¬ãã«ã®ãã©ã³ã¶ã¯ã·ã§ã³ãéä¿¡ããå Žåãå€ãnetwork parametersã¯æ°ããNodeã«ã¯ååšããªãããã§ãã ãã®åé¡ã¯çŸåšä¿®æ£ãããŠããŸãã - ããã³ãŒããã¹ã§ã®ããŒãã£ç¹å®ã«ãããŠã
wellKnownPartyFromAnonymous
ã¯ãX.500åã®ç¹å®ãè©Šã¿ãéã«ãnetwork parametersããNotaryãèæ ®ããŠããŸããã§ããããã®ã·ããªãªã¯ãæ°ãã移è¡ããããããã¯ãŒã¯ã«æ°ããNodeãå°å ¥ããéãæ°ããNodeã®network mapã«å€ãNotaryãå«ãŸããŠããªãããã«çºçããå¯èœæ§ããããŸããã ãã®åé¡ã¯çŸåšä¿®æ£ãããŠããŸããçŸåšããã§ãã¯æã«network parametersããNotaryãèæ ®ãããŸãã
Corda Enterprise Edition 4.11.3
Corda Enterprise Edition 4.11.2ã¯ãCorda Enterprise Editionã®åé¡è§£æ±ºã«ãã©ãŒã«ã¹ããããããªãªãŒã¹ã§ãã
ä¿®æ£ãããåé¡
4.11以åã®ããŒãããã¢ããã°ã¬ãŒãããå ŽåãããŒã¿ããŒã¹ã«æ°ã¹ã¿ã€ã«ã®æ©å¯IDïŒèšŒææžã®ãªãIDïŒãå«ãŸããŠãããšãããŒã¿ããŒã¹ã®ã¢ããã°ã¬ãŒãã«å€±æããåé¡ãä¿®æ£ããŸããã
Corda Enterprise Edition 4.11.2
Corda Enterprise Edition 4.11.2ã¯ãCorda Enterprise Editionã®åé¡è§£æ±ºã«ãã©ãŒã«ã¹ããããããªãªãŒã¹ã§ãã
ä¿®æ£ãããåé¡
- ããã©ã«ãã® log4j2.xml ãã¡ã€ã«ã§ã
diagnostic-*
ãŸãã¯checkpoints_agent-*
ã§å§ãŸããã°ãã¡ã€ã«ã® DefaultRolloverStrategy ããªã·ãŒã® Delete ã¢ã¯ã·ã§ã³ãééã£ãŠããŸããããã®ããã誀ã£ããã¡ã€ã«åãšæ¯èŒãããŠããŸããããã®åé¡ã¯ä¿®æ£ããããã¡ã€ã«ãããªã·ãŒã«åŸã£ãŠåé€ãããããã«ãªããŸããã - TLS ç§å¯éµã®ä¿åã« HSM ã䜿çšããå Žåã® TLS æ¥ç¶ã«é¢ããåé¡ã解決ãããŸããã
- RPCã®
getFlowsMatchingV2
æ¡åŒµæäœã®ãªã°ã¬ãã·ã§ã³ãä¿®æ£ããã以åã®CordaãªãªãŒã¹ãšäºææ§ããªããªããŸããããã®åé¡ã¯CordaãããŒç®¡çGUIã§çºçãã以åã®CordaãªãªãŒã¹ã®ãããŒã»ã¹ããŒã¿ã¹ã衚瀺ã§ããŸããã§ããããã®ä¿®æ£ã«ããã4.11.1ãŸãã¯4.11ã䜿çšããŠRPCã¯ã©ã€ã¢ã³ããäœæããå Žåã¯ã4.11.2ã䜿çšããŠã¯ã©ã€ã¢ã³ããåæ§ç¯ããå¿ èŠããããŸãã - 以åã¯ãå®éã«ã¯æ¥ç¶ãããŠããªãã«ãããããããããŒãããã¢ãšã®æå¹ãªæ¥ç¶ã誀ã£ãŠèªèãããšããçšãªãšã©ãŒã·ããªãªãçºçããããšããããŸããããã®åé¡ã¯éåžžããã¢ããŒããåæ/æ¥ç¶ããŠãããšãã«çºçããŸãããã®åé¡ã¯çŸåšè§£æ±ºãããŠããŸãã
ãµãŒãããŒãã£ã³ã³ããŒãã³ãã®ã¢ããã°ã¬ãŒã
- Jetty ã®ããŒãžã§ã³ã 9.4.51.v20230217 ãã 9.4.53.v20231009 ã«ã¢ããã°ã¬ãŒããããŸããã
- Apache Tomcat ã®ããŒã管çãã©ã°ã€ã³ã®ããŒãžã§ã³ã 9.0.82 ãã 9.0.83 ã«ã¢ããã°ã¬ãŒããããŸããã
Corda Enterprise Edition 4.11.1
Corda Enterprise Edition 4.11.1ã¯ãCorda Enterprise Editionã®åé¡è§£æ±ºã«ãã©ãŒã«ã¹ããããããªãªãŒã¹ã§ãã
ä¿®æ£ãããåé¡
4.11ãš4.11以åã®ããŒãéã§ãæ°ããããŒã¿åïŒTRANSACTION_RECOVERY
ã®ãã©ã³ã¶ã¯ã·ã§ã³ãéä¿¡/ãã§ããããéã®çžäºéçšæ§ãä¿®æ£ããŸãã.
Corda Enterprise Edition 4.11
Corda Enterprise Edition 4.11 ã«ã¯ãããã€ãã®æ°æ©èœãæ¹åç¹ãããã³ä¿®æ£ãå«ãŸããŠããŸãã
ãã©ãããã©ãŒã ããŒãžã§ã³å€æŽ
Corda 4.11 ã¯ãã©ãããã©ãŒã ããŒãžã§ã³13ã䜿çšããŠããŸãã
ãã©ãããã©ãŒã ããŒãžã§ã³ã«é¢ãã詳现ã¯ãVersioningãåç §ããŠãã ããã
æ°æ©èœãšæ¹åç¹
JDK Azul ããã³ Oracle JDK ã¢ããã°ã¬ãŒã
Corda ã¯çŸåšãJDK Azul 8u382 ããã³ Oracle JDK 8u381 ããµããŒãããŠããŸãã
Ledger Recovery
Corda 4.11 ãªãªãŒã¹ã®äžç°ãšããŠãLedger Recoveryãå°å ¥ãããŸãããããã¯ãæšæºåããã Corda ãããã¯ãŒã¯ã®éçšããã¯ã¢ããããã³ãªã«ããªããã»ã¹ãè£å®ããŸãã
詳现ã«ã€ããŠã¯ãLedger Recovery ãåç §ããŠãã ããã
Two Phase Finality
Two Phase Finality ãããã³ã«ïŒFinalityFlow
ããã³ ReceiveFinalityFlow
ãµããããŒïŒãè¿œå ãããFinality ã䜿çšãã CorDapps ã®èé害æ§ãšå埩æ§ãåäžãããŸãããæ¢åã® CorDapps ã§ã¯ããã®æ°ããæ¹è¯ããããããã³ã«ãå©çšããããã®å€æŽã¯å¿
èŠãããŸããã
詳现ã«ã€ããŠã¯ãTwo Phase Finalityãåç §ããŠãã ããã
Finality Recovery Tooling
ã€ãã·ãšãŒã¿ããã³ã¬ã·ãŒããŒã®äž¡æ¹ã Finality Flow ã®ãªã«ããªãè¡ãããã® RPC æ¡åŒµæäœïŒFlowRPCOps ã€ã³ã¿ãŒãã§ãŒã¹ãžã®è¿œå ïŒãè¿œå ãããŸããããŸããããŒãã·ã§ã«ã³ãã³ãã䜿çšããŠãªãã¬ãŒã·ã§ã³ããŒã ã Finality Flow ãªã«ããªãå®è¡ã§ããããã«ãªããŸããã
詳现ã«ã€ããŠã¯ãFinality Flow Recovery ãåç §ããŠãã ããã
Ledger Recovery flow
æ°ããLedger RecoveryãããŒïŒLedgerRecoveryFlow
ïŒã¯ãããŒããèªèº«ã®å°åž³ã«ååšããªãããã€åœäºè
ïŒã€ãã·ãšãŒã¿ãŸãã¯ã¬ã·ãŒããŒïŒã§ãã£ããã¢ãªã«ããªããŒããããã©ã³ã¶ã¯ã·ã§ã³ãèå¥ããã³å埩ã§ããããã«ããŸãã
詳现ã«ã€ããŠã¯ãLedger Recovery flow parameters ãåç §ããŠãã ããã
ã³ã³ãã£ãã³ã·ã£ã«ã¢ã€ãã³ãã£ãã£ã®ããŒãã¢ãžã§ãã¬ãŒã¿
æ°ãããµãŒãã¹ãè¿œå ããããã©ã³ã¶ã¯ã·ã§ã³ã§ CIïŒæ©å¯æ§ã®ããã¢ã€ãã³ãã£ãã£ïŒã䜿çšããéã«äºåã« CI ããŒãçæããŸãããããã®äºåçæããã CI ã¯ãããã¯ã¢ãããªã«ããªã®ç®çã§åŸã§äœ¿çšãããŸãã
è¿œå ã®ãããã¯ãŒã¯ãã©ã¡ãŒã¿
次ã®ãããã¯ãŒã¯ãã©ã¡ãŒã¿ãšé¢é£ããããŒãæ§æãã©ã¡ãŒã¿ãè¿œå ãããŸããïŒ
confidentialIdentityMinimumBackupInterval
recoveryMaximumBackupInterval
ãããã®ãããã¯ãŒã¯ãã©ã¡ãŒã¿ã«ã¯ CENM 1.6 以éãå¿ èŠã§ãã
詳现ã«ã€ããŠã¯ãAvailable Network Parameters ãåç §ããŠãã ããã
é åžã¬ã³ãŒãã®ã¯ãªãŒã³ã¢ãã
æ°ããã¡ã³ããã³ã¹ãžã§ã DistributionRecordCleanupTask
ãè¿œå ãããŸãããããã«ãããrecoveryMaximumBackupInterval
ãããã¯ãŒã¯ãã©ã¡ãŒã¿ãããå€ãledger recoveryé
åžã¬ã³ãŒããåé€ãããŸãã
ãããã¯ãŒã¯ãã©ã¡ãŒã¿ recoveryMaximumBackupInterval
ãå®çŸ©ãããŠããªãå Žåãnode ãã©ã¡ãŒã¿ enterpriseConfiguration.ledgerRecoveryConfiguration.recoveryMaximumBackupInterval
ãå®çŸ©ãããŠããã°ããã®ä»£ããã«äœ¿çšãããŸãã
ã©ã¡ãã®ãã©ã¡ãŒã¿ãå®çŸ©ãããŠããªãå Žåãé åžã¬ã³ãŒãã®ã¡ã³ããã³ã¹ãžã§ãã¯ç¡å¹ã«ãªããŸãã
詳现ã«ã€ããŠã¯ãLedger Recovery distribution record cleanup ãåç §ããŠãã ããã
äºéæ¯æãäŸå€åŠçã®æ¹å
Two Phase Finality ã¯ãFinalityFlow
ã®åæåæã«éè€æ¯æããæ€åºãããå Žåãæªç¢ºèªã®ãã©ã³ã¶ã¯ã·ã§ã³ã DBTransaction
ããŒãã«ããèªåçã«åé€ããŸãã
ããã«ãæ°ãããªãã·ã§ã³ã® ReceiveFinalityFlow
handlePropagatedNotaryError
ã³ã³ã¹ãã©ã¯ã¿ãã©ã¡ãŒã¿ã true
ã«èšå®ãããŠããå ŽåïŒããã©ã«ãïŒfalse
ïŒãäºéæ¯æããšã©ãŒïŒNotaryError.Conflict
ïŒã 2PF ã€ãã·ãšãŒã¿ã«äŒæããŸããããã«ãããã€ãã·ãšãŒã¿ã¯é¢é£ããæªç¢ºèªã®ãã©ã³ã¶ã¯ã·ã§ã³ãèªèº«ã® DBTransaction
ããŒãã«ããèªåçã«åé€ã§ããŸãã
CorDapp ã Corda 4.11 ã«ã³ã³ãã€ã«ãããŠããå ŽåïŒã€ãŸãããã®å¯Ÿè±¡ãã©ãããã©ãŒã ããŒãžã§ã³ã 13 ã§ããå ŽåïŒãããã©ã«ãã§äºéæ¯æãåŠçãæå¹ã«ãªããŸãã詳现ã«ã€ããŠã¯ãVersioning ãåç §ããŠãã ããã
AMQPããŒã¿ã®ãã·ãªã¢ã©ã€ãºæ§èœåäž
ãã®ãªãªãŒã¹ã§ã¯ãAMQPããŒã¿ã®ãã·ãªã¢ã©ã€ãºã®ããã©ãŒãã³ã¹ãåäžããŠãããLedgerGraphãArchivingãããã³ä»ã®CorDappsã®ããã©ãŒãã³ã¹ãåäžããå¯èœæ§ããããŸãã
Vaultã¯ãšãªããŒãžã®èªã¿èŸŒã¿äžã«å€æŽãæ€åºãã
Vault.Page
ã«æ°ããããããã£previousPageAnchor
ãè¿œå ãããŸãããããã¯ãVaultã¯ãšãªã®ããŒãžãèªã¿èŸŒãŸããŠããéã«Vaultãå€æŽããããã©ãããæ€åºããããã«äœ¿çšãããŸãããã®ã·ããªãªãæ€åºããããšãéèŠãªå Žåãããããã£ã䜿çšããŠã¯ãšãªãåéããããšãã§ããŸãã
ãã®ããããã£ã®äœ¿çšäŸã¯ãVault Queries
ã§ç¢ºèªã§ããŸãã
äŸåé¢ä¿ã®ã¢ããã°ã¬ãŒã
以äžã®äŸåé¢ä¿ãã¢ããã°ã¬ãŒããããé倧ãªã»ãã¥ãªãã£ã®è匱æ§ã«å¯ŸåŠããŠããŸãã
Hibernateã5.4.32.Finalãã5.6.14.Finalã«ã¢ããã°ã¬ãŒããããŸããã
H2ã1.4.197ãã2.2.214ã«ã¢ããã°ã¬ãŒããããŸããã
H2ããŒã¿ããŒã¹ã¯ãæ¢ç¥ã®è匱æ§ã«å¯ŸåŠããããã«ãããŒãžã§ã³2.2.224ã«ã¢ããã°ã¬ãŒããããŸãããH2ã¯ãµããŒããããŠããªãæ¬çªããŒã¿ããŒã¹ã§ãããéçºããã³ãã¹ãç®çã§ã®ã¿äœ¿çšããå¿ èŠããããŸããH2ããŒãžã§ã³1.4.197ïŒCordaã®ä»¥åã®ããŒãžã§ã³ã§äœ¿çšãããŠããããŒãžã§ã³ïŒãšã4.11ã§å®è£ ãããæ°ããH2ããŒãžã§ã³2.2.224ã®éãã«é¢ãã詳现ã¯ãH2ããã¥ã¡ã³ããåç §ããŠãã ãããæãéèŠãªéãã¯æ¬¡ã®ãšããã§ãã
- ãšã³ãã£ãã£ã®åœå H2ããŒãžã§ã³2.2.224ã¯ãããŒã¿ããŒã¹å ã®ããŒãã«ãšåã®åœåã«é¢ããå³æ Œãªã«ãŒã«ãå®è£ ããŠããŸããSQLã®ããŒã¯ãŒãã®äœ¿çšã¯ãã¯ãèš±å¯ãããŠããŸãããCorDappã¹ããŒããããŒãã«ãŸãã¯åã«äºçŽãããååã䜿çšããŠããå ŽåãCorDappã®ãããŒã¯ããŒãã«ãšå¯Ÿè©±ããããšãããšãã«å€±æããé¢é£ããSQLäŸå€ãçºçããŸãã
- åŸæ¹äºææ§
ãã®åé¡ã®è§£æ±ºçã¯ãåé¡ã®ããããŒãã«ãŸãã¯åã®ååãäºçŽãããŠããªãååã«å€æŽããããšã§ãããã®ååå€æŽããã»ã¹ã¯ãCorDappã®ç§»è¡ã¹ã¯ãªãããšCorDappã³ãŒãå ã®JPAãšã³ãã£ãã£å®çŸ©ã§å®è£ ããå¿ èŠããããŸãã
H2ããŒãžã§ã³2.xã¯ãå€ãããŒãžã§ã³ãšåŸæ¹äºææ§ããããŸãããH2ããŒã¿ããŒã¹URLã«MODE=LEGACY
ãè¿œå ããããšã§ãéãããåŸæ¹äºææ§ãå®çŸã§ããŸãã詳现ã«ã€ããŠã¯ãH2 FeaturesããŒãžã®LEGACY Compatibility Modeã»ã¯ã·ã§ã³ãåç
§ããŠãã ããã
H2 2.xã¯ãå€ãH2ããŒãžã§ã³ã§äœæãããããŒã¿ããŒã¹ãã¡ã€ã«ãèªã¿åãããšãã§ããŸãããå€ãããŒã¿ããŒã¹ãã¢ããã°ã¬ãŒãããããã®æšå¥šãããã¢ãããŒãã¯ãããŒã¿ããšã¯ã¹ããŒãããŠãããæ°ããããŒãžã§ã³2.xããŒã¿ããŒã¹ã«åã€ã³ããŒãããããšã§ãããã®ããã»ã¹ã®è©³çŽ°ã«ã€ããŠã¯ãH2 Migration to 2.0ããŒãžã«èšèŒãããŠããŸãã
Liquibaseã3.6.3ãã4.20.0ã«ã¢ããã°ã¬ãŒããããŸããã
- API
- ãã° ãã®Liquibaseã®ããŒãžã§ã³ã§ã¯ããã¹ãŠã®INFOã¬ãã«ã®ãã°ãSTDERRã«åããããSTDOUTã¯SQLã¯ãšãªã®ãã°ã«äœ¿çšãããŸããLiquibaseã䜿çšããç¬èªã®ããŒã¿ããŒã¹ãã€ã°ã¬ãŒã·ã§ã³ã³ãŒããå®è£ ããŠãããŠãŒãã£ãªãã£ã¯ãã«ã¹ã¿ã ãã¬ãŒã確ç«ããŠLiquibaseã®æ å ±ãã°ããã£ããã£ã§ããŸããLiquibase APIã¯ãã«ã¹ã¿ã ãã¬ãŒãçµ±åããããã«äœ¿çšã§ããã¯ã©ã¹ãæäŸããŠããŸãã
ãã®Liquibaseã®ããŒãžã§ã³ã«ã¯ãåã®ããŒãžã§ã³ãšã¯ãããã«ç°ãªãAPIããããŸããLiquibaseã䜿çšããç¬èªã®ããŒã¿ããŒã¹ãã€ã°ã¬ãŒã·ã§ã³ã³ãŒããå®è£ ããŠããCorDappsã¯ãæ°ããAPIã«åãããŠæŽæ°ããå¿ èŠããããŸãã
vault_stateããŒãã«ã«è¿œå ãããæ¶è²»ãã©ã³ã¶ã¯ã·ã§ã³ID
Stateããã©ã³ã¶ã¯ã·ã§ã³ã«ãã£ãŠæ¶è²»ããããšãCordaã¯vault_state
ããŒãã«ã®consuming_tx_id
åã«æ¶è²»ãã©ã³ã¶ã¯ã·ã§ã³ã®IDãè¿œå ããŸããCordaã¯æ°ãããã©ã³ã¶ã¯ã·ã§ã³ã®ããã«ã®ã¿ãã®ããŒã¿ããŒã¹åãæŽæ°ããŸãããã§ã«å°åž³ã«ååšããæ¶è²»ãããStateã«å¯ŸããŠã¯ãconsuming_tx_id
ã®å€ã¯nullã§ãã
ããã©ãŒãã³ã¹åäžã®ããã®ããŒãæ§æå€æŽ
ãããŒã®åŸ ã¡æéãççž®ããã¹ã«ãŒããããåäžãããããã«ãããŒãæ§æã®ä»¥äžã®ããã©ã«ãå€ãå€æŽãããŸããã
enterpriseConfiguration.tuning.brokerConnectionTtlCheckIntervalMs
ã¯20ãã1ããªç§ã«å€æŽãããŸãããenterpriseConfiguration.tuning.journalBufferTimeout
ã¯3333333ããç§ãã1000000ããç§ã«å€æŽãããŸãããnotary.extraConfig.batchTimeoutMs
ã¯200ãã1ã«å€æŽãããŸããã
DJVMã®åé€
DJVMã®ããŒã¿æ©èœãåé€ãããŸãããDJVMã®åé€ã®çµæãDriverParameters
ã¯ã©ã¹ããdjvmBootstrapSource
ããã³djvmCordaSource
ã®2ã€ã®ã³ã³ã¹ãã©ã¯ã¿ãã©ã¡ãŒã¿ãåé€ãããŸãããDriverParameters
ã䜿çšããã¯ã©ã€ã¢ã³ãã³ãŒãã¯ãåã³ã³ãã€ã«ãå¿
èŠã§ãã
è¿œå ã®çœ²åæ€èšŒ
recordTransactions()
é¢æ°ã¯ãå
ŽServiceHub
APIã䜿çšããå Žåã«ãããå³æ Œãªçœ²åæ€èšŒãå®è¡ããŸãã詳现ã«ã€ããŠã¯ãDBTransactionStorageãåç
§ããŠãã ããã
解æ¶ãããåé¡
ãã®ãªãªãŒã¹ã«ã¯ã4.10.3以éã®æ¬¡ã®ä¿®æ£ãå«ãŸããŠããŸãã
- PostgreSQL 9.6ããã³10.10ã¯ãPostgreSQLèªäœã«ãã£ãŠãµããŒããããªããªã£ãããããµããŒããããªãã¯ã¹ããåé€ãããŸããã
- log4j2.xmlã¯ãããŒã«ãªãŒããŒæŠç¥ã®æ§æã§èšºæããã³ãã§ãã¯ãã€ã³ããã°çšã®æ£ãããã¡ã€ã«ãåé€ããŸãã
- åã®ããããªãªãŒã¹ã§ã¯ãSSL蚌ææžã®åŠçã匷åããäžç°ãšããŠã倱æããSSLãã³ãã·ã§ã€ã¯ã«é¢é£ããç¹å®ã®ãã°ã¡ãã»ãŒãžãæå³ããè¿œå ãããŸããããããã®ã¡ãã»ãŒãžã¯ããã©ãã£ãã¯ããŒããã©ã³ãµãŒãã·ã¹ãã ã¢ãã¿ãªã³ã°ã®æ¥ç¶æ§ãã¹ãäžã«ãã°ã«é »ç¹ã«è¡šç€ºãããŸããããã°ã®ãã€ãºãæžå°ãããããã«ããããã®ç¹å®ã®ãã°ã¡ãã»ãŒãžãç¡å¹ã«ããŸããã
ããŒã¿ããŒã¹ã¹ããŒãã®å€æŽ
ãã¹ãŠã®ããŒã¿ããŒã¹ããŒãã«ã®è©³çŽ°ãªèª¬æã«ã€ããŠã¯ãããŒã¿ããŒã¹ããŒãã«ãåç §ããŠãã ããã
以äžã®ããŒã¿ããŒã¹å€æŽãé©çšãããŸããïŒ
vault_state
ããŒãã«ã«ã¯ãæ°ããconsuming_tx_id
åãè¿œå ãããŸããããã®æ°ããåã¯ã次ã®ãã€ã°ã¬ãŒã·ã§ã³ã¹ã¯ãªããã§è¿œå ãããŸããïŒvault-schema.changelog-v14.xml
ã- Two Phase Finalityã¯ãã¡ã€ã³ã®DbTransactionããŒãã«å ã«è¿œå ã®ããŒã¿ãã£ãŒã«ããå°å ¥ããŸããã
@Column(name = "signatures")
val signatures: ByteArray?
Two Phase Finality ã¯ãå埩ã¡ã¿ããŒã¿ã®é åžã¬ã³ãŒããæ ŒçŽããããã®æ°ããããŒã¿ããŒã¹ããŒãã«ã2ã€å°å ¥ããŸã:
@Entity
@Table(name = "${NODE_DATABASE_PREFIX}sender_distr_recs")
data class DBSenderDistributionRecord(
@EmbeddedId
var compositeKey: PersistentKey,
/** states to record: NONE, ALL_VISIBLE, ONLY_RELEVANT */
@Column(name = "sender_states_to_record", nullable = false)
var senderStatesToRecord: StatesToRecord,
/** states to record: NONE, ALL_VISIBLE, ONLY_RELEVANT */
@Column(name = "receiver_states_to_record", nullable = false)
var receiverStatesToRecord: StatesToRecord
)
@Entity
@Table(name = "${NODE_DATABASE_PREFIX}receiver_distr_recs")
data class DBReceiverDistributionRecord(
@EmbeddedId
var compositeKey: PersistentKey,
/** Encrypted recovery information for sole use by Sender **/
@Lob
@Column(name = "distribution_list", nullable = false)
val distributionList: ByteArray,
/** states to record: NONE, ALL_VISIBLE, ONLY_RELEVANT */
@Column(name = "receiver_states_to_record", nullable = false)
val receiverStatesToRecord: StatesToRecord
)
äžèšã®ããŒãã«ã¯åãæ°žç¶çãªè€åããŒã¿ã€ãã䜿çšããŸã:
@Embeddable
@Immutable
data class PersistentKey(
@Column(name = "transaction_id", length = 144, nullable = false)
var txId: String,
@Column(name = "peer_party_id", nullable = false)
var peerPartyId: Long,
@Column(name = "timestamp", nullable = false)
var timestamp: Instant,
@Column(name = "timestamp_discriminator", nullable = false)
var timestampDiscriminator: Int
)
é åžãªã¹ãã®ãã©ã€ãã·ãŒæ å ±ïŒæå·ããŒãå«ãïŒãä¿æããããã®2ã€ã®è¿œå ã®ããŒãã«ããããŸã:
@Entity
@Table(name = "${NODE_DATABASE_PREFIX}recovery_party_info")
data class DBRecoveryPartyInfo(
@Id
/** CordaX500Name hashCode() **/
@Column(name = "party_id", nullable = false)
var partyId: Long,
/** CordaX500Name of party **/
@Column(name = "party_name", nullable = false)
val partyName: String
)
@Entity
@Table(name = "${NODE_DATABASE_PREFIX}aes_encryption_keys")
class EncryptionKeyRecord(
@Id
@Type(type = "uuid-char")
@Column(name = "key_id", nullable = false)
val keyId: UUID,
@Column(name = "key_material", nullable = false)
val keyMaterial: ByteArray
)
Ledger Recoveryã®ããã®Confidential Identityã®äºåçæã«ãããnode_our_key_pairs
ããŒãã«å
ã«4ã€ã®æ°ãããã£ãŒã«ããå°å
¥ãããŸã:
@Entity
@Table(name = "${NODE_DATABASE_PREFIX}our_key_pairs")
class PersistentKey(
<.... existing fields not shown .... >
@Enumerated(EnumType.ORDINAL)
@Column(name = "key_type", nullable = false)
var keyType: KeyType = CI,
@Column(name = "crypto_config_hash", length = MAX_HASH_HEX_SIZE, nullable = true)
var cryptoConfigHash: String? = null,
@Enumerated(EnumType.ORDINAL)
@Column(name = "status", nullable = false)
var status: Status = CREATED,
@Column(name = "generate_tm", nullable = false)
var insertionDate: Instant = Instant.now()
)
ãµãŒãããŒãã£ã³ã³ããŒãã³ãã®ã¢ããã°ã¬ãŒã
以äžã®è¡šã¯ã4.10.3ãš4.11 Enterprise Editionsã®éã§ã®äŸåé¢ä¿ã®ããŒãžã§ã³å€æŽããªã¹ãã¢ããããŠããŸã:
äŸåé¢ä¿ | åå | ããŒãžã§ã³ 4.1.2 Enterprise | ããŒãžã§ã³ 4.11 Enterprise |
org.bouncycastle | Bouncy Castle | 1.70 | 1.75 |
co.paralleluniverse:quasar-core | Quasar | 0.7.15_r3 | 0.7.16_r3 |
org.hibernate | Hibernate | 5.4.32.Final | 5.6.14.Final |
com.h2database | H2 | 1.4.197 | 2.2.2241 |
org.liquibase | Liquibase | 3.6.3 | 4.20.0 |
Log4jããã
2021幎12æã®Log4jã®è匱æ§ã«å¯ŸåŠãããã¹ãŠã®ãããã¯ãã¡ããã¯ãªãã¯ããŠãã ããã