Apache Pulsar 2.7.0
2020-11-25​
The following lists fixes and enhancements in the 2.7.0 release.
Transactions​
- Implement the Transaction Buffer Client #6544
- Support produce messages with transaction and commit transaction #7552
- Support consume transaction messages #7781 #7833
- Message acknowledgment with transaction #7856 #8007
- Support transaction abort on partition #7953
- Support transaction abort on subscription #7979
- Handle pending ack at the client side #8037
- Pending ack state implementation #8426
- Support get reponse for message acknowledge #8161
- Refactor the transaction buffer implementation #8291 #8347
- Transaction marker deletion #8318
- Support produce messages with transaction in batch #8415
- Register transaction metadata before send or ack messages #8493
- Expose transaction interface #8505
- Guarantee transaction metadata handlers connected #8563
- Add the batch size in transaction ack command #8659
- Implement the Transaction Log #8658
Topic policy​
- Support setting message TTL on topic level #7738
- Support setting retention on topic level #7747
- Support setting delayed delivery policy on topic level #7784
- Support setting max unacked message per subscription on topic level #7802
- Support setting persistence policie on topic level #7817
- Support setting max unacked messages per consumer on topic level #7818
- Support setting deduplication policy on topic level #7821
- Support setting message dispatch rate on topic level #7863)
- Support setting compaction threshold on topic level #7881
- Support setting offload policy on topic level #7883
- Support setting max producers for a topic #7914
- Support setting max consumers for a topic #7968
- Support setting publish rate limitation for a topic #7948
- Support setting inactive topic policy on topic level #7986
- Support setting subscribe rate for a topic #7991
- Support setting max consumers per subscription on topic level #8003
- Support setting subscription dispatch rate on topic level #8087
- Support setting deduplication snapshot interval on topic level #8552
Broker​
- Upgrade BookKeeper version to 4.12.0 #8447
- Capture the add entry latency of managed-ledger #4419
- Keep max-concurrent http web-request configurable #7250
- Perform the unload in background after bundle split #7387
- Cleanup already deleted namespace topics when remove cluster #7473
- Support partitioned topics in the Reader #7518
- Support partitioned topic lookup #7605
- Make OrderedExecutor threads number configurable #7765
- Add config to lazily recover cursors when recovering a managed ledger #7858
- Make BookKeeper throttle configurable #7901
- Report compacted topic ledger info when calling get internal stats #7988
- Add broker config to enforce producer to publish encrypted message #8055
- Expose ensemble placement policy in bookkeeper.conf #8210
- Support limit topic publish rate at the broker level #8235
- Support limit the max tenants of the Pulsar cluster #8261
- Support limit the max namespaces per tenant #8267
- Support limit max subscriptions per topic #8289
- Added metrics for topic lookups operations #8272
- Added REST handler for broker ready probe #8303
- Configure namespace anti-affinity in local policies #8349
- Handle hash collision in KeyShared subscription mode #8396
- Configure maxMsgReplDelayInSeconds for each repl-cluster #8409
- Support taking de-duplication snapshots based on time #8474
- Support namespace-level duplication snapshot #8506
- Expose consumer names after the mark delete position for the Key_Shared subscription #8545
- Close topics that remain fenced forcefully #8561
Functions​
- Separate out FunctionMetadata related helper functions #7146
- Attach names for all producers/readers in worker service #7165
- Add support to read compacted topic #7193
- Re-work Function MetaDataManager to make all metadata writes only by the leader #7255
- Fix leader/scheduler assignment processing lag problem #7237
- Set source spec's negativeacktimeout as well as timeout #7337
- Add an endpoint to check whether function worker service is initialized #7350
- Functions metadata compaction #7377
- Implement rebalance mechanism #7388
- Improve security setting #7424
- Allow function rebalance to be run periodically #7449
- Log scheduler stats for Pulsar Functions #7474
- Add BatchPushSource interface #7493
- Rejigger contract between LeaderService and rest of components #7520
- Allow null consume in BatchPushSource #7573
- Add readiness api for the worker leader #7601
- Reduce in the leader init time in Pulsar Functions #7611
- Export Function worker internal stats via Prometheus #7641
- Allow ability to specify retain key ordering in functions #7647
- Added ability to specify runtime for localrunner #7681
- Add additional metrics for Pulsar Function Worker #7685
- Use available cores for io thread processing #7689
- Added ability to specify producer config for functions and sources #7721
- Allow the option to make producers thread local #7764
- Add ability for BatchPushSource to notify errors asynchronously #7865
- Allow ability to specify sub position in functions #7891
- Add hostname to consumer/producer properties in Pulsar Functions #7897
- Allow specifying state storage url for Source/Sink localrun #7930
- Enable function worker JVM metrics to be reported via Prometheus #8097
- Add ability to specify EnvironmentBasedSecretsProvider in LocalRunner #8098
- Added ability to specify secrets class in localrunner builder #8127
- Add access to the current message from the function context #8290
- Enable e2e encryption for Pulsar Function #8432
- Support key_based batch builder for functions and sources #8523
- Refactor Context and State API to allow plugging different state store implementations #8537
IO connectors​
Schema​
- Add java8 date and time type to primitive schemas #7874
- Native protobuf schema support #7874
- Refactor multi-version schema reader #8464
Tiered storage​
- Support Azure BlobStore offload #8436
Clients​
- [cgo] Remove CGO client from repo #8514
Admin​
- [Pulsar Admin] support config request timeout #7698
- [Pulsar Admin] Ensure deleting a partitioned-topic on a non existing namespace returns 404 #7777
- [Pulsar Admin] Added support to force deleting namespace #7993
- [Pulsar Admin] Allow to get ledger metadata along with topic stats-internal #8180
- [Pulsar Admin] Support remove namespace level offload policy #8446
- [Pulsar Admin] Suport get list of bundles under a namespace #8450
- [Pulsar Admin] Add ability to examine specific message by position relative to earliest or latest message #8494
- [Pulsar Admin] Add key-shared consumer range to internal topic stats #8567
Fixes​
- [Broker] Prevent redirection of lookup requests from looping #7200
- [Broker] Ensure that admin operations are gated by super user check #7226
- [Broker] Fix race condition when delete topic forcelly #7356
- [Tiered Storage] Fix NPE when offload data to GCS #7400
- [Function]Fix race condition in which exitFuture in FunctionAssignmentTailer never gets completed even though the tailer thread has exited #7351
- [Function] Various fixes and optimizations for processing assignments in function worker #7338
- [Function] Fix deadlock between create function and leader initialization #7508
- [Pulsar Admin] Fix exceptions being ignored in PulsarAdmin #7510
- [Broker] Fix the nondurable consumer can not specify the initial position #7702
- [Broker] Fixed race condition on deleting topic with active readers #7715
- [Broker] Avoid ConcurrentModificationException of LocalBrokerData #7729
- [Pulsar Proxy] Fix memory leak with debug log-level #7963
- [Broker] Double check from zookeeper if availableBrokers is empty for discovery service #7975
- [Broker] Fix broker-ml bucket stats show high metrics rate #8218
- [Broker] Fix incorrect configuration for zk-cache expire time #8302
- [Function] Fix returned status code for get function state when state does not exist #8437
- [Broker] Fix the residual of inactive partitioned-topic cleaning #8442
- [Pulsar Proxy] Fix request.getContentLength() to return 0 if it is less than 0 #8448
- [Broker] Fix race condition when calling acknowledgementWasProcessed() #8499