Skip to main content
Version: v2.0

Downloads

Seata

GitHub: https://github.com/seata/seata

Release Notes: https://github.com/seata/seata/releases

2.0.0 (2023-11-24)

source | binary

Release notes

Seata 2.0.0

Seata 2.0.0 Released

Seata is an easy-to-use, high-performance, open source distributed transaction solution.

The version is updated as follows:

feature:

  • [#5165] optimize TCC structure, supporting API access. add integration layer module(seata-integration-tx-api) for transaction process definition and proxy enhancement.
  • [#5352] add jackson json parser and gson json parser for tcc business action context
  • [#5377] make AbstractHttpExecutor.class support http put
  • [#5396] TC log appender metric
  • [#5118] support two-stage concurrent notification execution
  • [#5529] docker image supports JVM parameter injection
  • [#3887] add SQL Server database support in AT mode
  • [#4033] add SQLServer support for Server DB storage mode
  • [#5600] feature: support trace the transaction link according to the XID
  • [#5357] feature: console integration saga-statemachine-designer
  • [#5717] compatible with file.conf and registry.conf configurations in version 1.4.2 and below
  • [#5842] adding metainfo to docker image
  • [#5902] support IPv6
  • [#5907] support polardb-x 2.0 in AT mode
  • [#5932] support Dameng database
  • [#5946] add sqlserver's adaptation to the console paging interface
  • [#5226] support raft cluster and store mode

bugfix:

  • [#5677] fix saga mode serviceTask inputParams json autoType convert exception
  • [#5277] fix server console has queried the released lock
  • [#5282] parallel request handle throw IndexOutOfBoundsException
  • [#5294] fix auto-increment of pk columns in PostgreSQL/Oracle in AT mode
  • [#5298] don't remove GlobalSession when retry rollback or retry commit timeout
  • [#5304] remove RollbackRetryTimeout sessions during in file storage recover
  • [#5310] fix that keywords don't add escaped characters
  • [#5318] fix G1 jvm parameter in jdk8
  • [#5330] fix bugs found in unit tests
  • [#5337] fix bugs found in feature#5165 about sorting problem of multiple interceptor under the spring used environment, by the way fix the BeforeTransaction(AfterTransaction) transaction ordering problem when the order is consistent
  • [#5347] Fix console print unauthorized error
  • [#5355] fix bug when customizing context-path
  • [#5362] fix When the rollback logic on the TC side returns RollbackFailed, the custom FailureHandler is not executed
  • [#5373] fix transaction timeout on client side not execute hook and failureHandler
  • [#5395] check if table meta cache should be refreshed in AT mode
  • [#5426] fix the GlobalTransactional annotation npe issue.
  • [#5464] fix global session is always begin in saga mode
  • [#5478] fix finished transaction swallows exception when committing
  • [#5490] fix method name not print in logs
  • [#5449] fix Oracle XA transaction reentrant issues
  • [#5462] fix if using @GlobalTransactional in RM, ShouldNeverHappenException will be thrown
  • [#5498] bugfix: fix the full table scan issue with 'setDate' condition in Oracle 10g
  • [#5531] fix the log file path was loaded incorrectly
  • [#5523] fix GlobalStatus=9 can't be cleared in DB storage mode
  • [#5558] fix mariadb rollback failed
  • [#5556] fix oracle insert undolog failed
  • [#5579] fix RM_CHANNELS get npe when resourceId is empty
  • [#5577] fix grpc interceptor xid unbinding problem
  • [#5594] fix log in participant transaction role
  • [#5604] fix the asyncCommit and queueToRetryCommit always failed in db mode
  • [#5658] bugfix: fix escaped characters for upper and lower case column names
  • [#5661] bugfix: the timeout is null when the connectionProxyXA connection is reused
  • [#5679] bugfix: fix compatibility between xxx.grouplist and grouplist.xxx configuration items
  • [#5715] fix get configuration item contains underlined error
  • [#5748] case of the pk col-name in the business sql is inconsistent with the case in the table metadata, resulting in a rollback failure
  • [#5745] fix the problem that the parameter prefix requirement of the setAttachment method in sofa-rpc is not met
  • [#5772] change some fields type of TableMetaCache to avoid integer overflow
  • [#5787] Solution cluster cannot be customized when redis serves as the registry
  • [#5810] fix XA transaction start exception and rollback failure caused by druid dependency conflict
  • [#5821] fix insert executor keywords unescape
  • [#5835] bugfix: fix TC retry rollback wrongly, after the XA transaction fail and rollback
  • [#5881] fix delete branch table unlock failed
  • [#5930] fix the issue of missing sentinel password in store redis mode
  • [#5958] required to be unlocked when a re-election occurs in a commit state
  • [#5971] fix some configurations that are not deprecated show "Deprecated"
  • [#5977] fix that rpcserver is not closed when raftServer is closed
  • [#5954] fix the issue of saved branch session status does not match the actual branch session status
  • [#5990] fix the issue that the Lua script is not synchronized when the redis sentinel master node is down
  • [#5997] fix global transaction hook repeat execute
  • [#6018] fix incorrect metric report
  • [#6024] fix the white screen after click the "View Global Lock" button on the transaction info page in the console
  • [#6015] fix can't integrate dubbo with spring
  • [#6049] fix registry type for raft under the network interruption did not carry out the sleep 1s
  • [#6050] change RaftServer#destroy to wait all shutdown procedures
  • [#6033] fix the isReference judgment logic in HSFRemotingParser, remove unnecessary judgment about FactoryBean

optimize:

  • [#5966] decouple saga expression handling and remove evaluator package
  • [#5928] add Saga statelang semantic validation
  • [#4858] reorganize the usage of task session manager
  • [#4881] reorganize the usage of Sessionmanager and listener
  • [#5273] Optimize the compilation configuration of the protobuf-maven-plugin plug-in to solve the problem of too long command lines in higher versions.
  • [#5278] clean multi-sessionmanager-instance pattern
  • [#5302] remove startup script the -Xmn configuration
  • [#4880] optimize logs when commit/rollback catch an exception
  • [#5322] optimize the log of SPI
  • [#5326] add time info for global transaction timeout log
  • [#5328] add corresponding lua implementation for Redis mode of global transaction and transaction storage
  • [#5341] optimize gRPC Interceptor for TCC mode
  • [#5342] optimize the check of the delay value of the TCC fence log clean task
  • [#5344] add store mode,config type and registry type log info
  • [#5351] optimize RPC filter for TCC mode
  • [#5354] reconstruct the RPC integration module
  • [#5370] optimize transaction fail handler
  • [#5431] optimize github workflow
  • [#5461] optimize license workflow
  • [#5456] refactor ColumnUtils and EscapeHandler
  • [#5438] optimize code style properties
  • [#5471] optimize transaction log on client side
  • [#5485] optimize server log output
  • [#4907] optimize thread scheduling and code
  • [#5487] mark the lockholder of branchsession as final
  • [#5519] optimize FenceHandler for oracle
  • [#5501] support updating transaction state with optimistic locking
  • [#5419] optimize images based on java 8/17 and support maven-3.9.0
  • [#5549] update expire gpg key and publish workflow
  • [#5576] The common fence clean task is only initiated when useTCCFence is set to true
  • [#5623] optimize possible conflict between asyncCommitting thread and retryCommitting thread
  • [#5553] support case-sensitive attributes for table and column metadata
  • [#5563] optimize: optimize channel availability thread log output
  • [#5644] optimize server logs print
  • [#5680] optimize escape character for case of columnNames
  • [#5686] optimize: optimize license check actions
  • [#5714] optimize distributed lock log
  • [#5723] optimize docker default timezone
  • [#5779] remove unnecessary log outputs and unify the log output path.
  • [#5802] set server's transaction level to READ_COMMITTED
  • [#5783] support the nacos application name property
  • [#5524] support for more operational commands in seata-server.sh
  • [#5836] separate MySQL from Mariadb implementations
  • [#5869] some minor syntax optimization
  • [#5885] optimize log in ConnectionProxyXA
  • [#5894] remove dependency without license
  • [#5895] remove 7z format compression support
  • [#5896] remove mariadb.jdbc dependency
  • [#5384] unified project version
  • [#5419] publish images based on java 8/17 and support maven-3.9.0
  • [#5829] fix codecov chart not display
  • [#5878] optimize httpcore and httpclient dependencies
  • [#5917] upgrade native-lib-loader version
  • [#5926] optimize some scripts related to Apollo
  • [#5938] support jmx port in seata
  • [#5944] optimize: fix build action warning
  • [#5951] remove un support config in jdk17
  • [#5959] modify code style and remove unused import
  • [#6002] remove fst serialization
  • [#6045] optimize derivative product check base on mysql

security:

  • [#5642] add Hessian Serializer WhiteDenyList
  • [#5694] fix several node.js security vulnerabilities
  • [#5801] fix some dependencies vulnerability
  • [#5805] fix some serializer vulnerabilities
  • [#5868] fix npm package vulnerabilities
  • [#5916] upgrade nodejs dependency
  • [#5942] upgrade dependencies version
  • [#5987] upgrade some dependencies version
  • [#6013] upgrade seata-server spring version

test:

  • [#5308] add unit test [FileLoader, ObjectHolder, StringUtils]
  • [#5309] add unit test [ArrayUtils, ConfigTools, MapUtil]
  • [#5335] add unit test [EnhancedServiceLoader,ExtensionDefinition,SizeUtilTest,ReflectionUtil,LowerCaseLinkHashMap,FileLoader,ObjectHolder]
  • [#5367] fix UpdateExecutorTest failed
  • [#5383] fix multi spring version test failed
  • [#5391] add unit test for config module
  • [#5428] fix FileTransactionStoreManagerTest failed
  • [#5622] add unit test [ExporterType, RegistryType]
  • [#5637] add unit test [BatchResultMessage, HeartbeatMessage, RegisterRMResponse, ResultCode, RegisterTMResponse, MergeResultMessage, MergedWarpMessage, Version]
  • [#5893] remove sofa test cases
  • [#5845] upgrade druid and add test-druid.yml
  • [#5863] fix unit test in java 21
  • [#5986] fix zookeeper UT failed
  • [#5995] add test cases for RaftClusterMetadataMsg
  • [#6001] add test cases for RaftMsgExecute under branch package
  • [#5996] add test cases for RaftMsgExecute under global package
  • [#6003] add test cases for RaftMsgExecute under lock package
  • [#6005] fix saga async tests undefined behavior
  • [#6009] add test cases for RaftServerFactory
  • [#6052] upgrade springboot and spring version for server for test

Contributors:

Thanks to these contributors for their code commits. Please report an unintended omission.

Also, we receive many valuable issues, questions and advices from our community. Thanks for you all.