Project
Hyperledger Besu
Project Health
Hyperledger Besu remains a strong project with a growing community network of contributors. This quarter the team has focused on fostering its community as well as many performance improvements, included in the Hyperledger Besu 1.5 Release, which was launched on July 15th. The team is currently building towards its 1.6 Release.
Questions/Issues for the TSC
There are no issues at this point. The Hyperledger Besu team does have a question for the TSC:
- Release Versioning: Our Hyperledger Besu team is currently proposing switching from Semantic Versioning for Releases to CalVer. Instead of using Major.Minor.Patch, Besu would use Year.Quarter.PatchNumber or Year.Month.PatchNumber. For example, instead of 1.5.2 and 1.6.0 we would have something like 20.3.2 and 20.4.0 or 20.8.2 and 20.10.0. We would like to gain the TSC’s feedback on this change.
Releases
Hyperledger Besu has completed eight bi-weekly patch releases (1.4.6 on 10 Jun, 1.5RC1 on 17 Jun, 1.5-RC2 on 30 Jun, 1.5 on July 15, 1.5.1 RC on 22 Jul, 1.5.1 on 29 Jul, 1.5.2 on 13 Aug, and 1.5.3 on 27 Aug)
Some functional improvements include:
Production-Ready Features:
Privacy: The most recent set of privacy enhancements include:
- Ability to add and remove members from privacy groups.
- Filters and subscriptions for private contracts.
- Web3j and web3js support for private transactions and filters.
Performance
- Added native encryption libraries to provide optimization optionality
- EVM execution improvements
- Improved logs querying performance
- Improved transactions per second (TPS) performance by 33%
- Parity Tracing APIs: Performed additional testing
Early Access Features:
- EIP-1559 Support: Hyperledger Besu has been one of the clients leading the implementation of EIP-1559, a major upgrade to Ethereum’s transaction fee market.
- Ephemeral Testnet YOLO: In preparation for the next network upgrade, Berlin, an ephemeral testnet called YOLO was launched with two new EIPs enabled: EIP-2315, which adds subroutines to the EVM, and EIP-2537, which introduces a new precompile for the BLS12-381 curve.
- DNS Support
- State back-up and restore option
Go to the Changelog for more details.
Overall Activity in the Past Quarter
A few high-level activities include:
- The Hyperledger Besu 1.5 Release Overview blog was published here.
- Hyperledger Besu 1.5. Performance Blog was published here. This gives a detailed look at the performance upgrades and metrics to Besu in the past quarter.
- Continue to run our bi-weekly contributor calls and grow the attendance.
- We have been using the Hyperledger tools consistently and with continued success.
As a part of participating in the Hyperledger community, the Besu team has participated in the community by:
- Continuing to work on Besu’s support of Caliper.
- Presented Hyperledger webinar on Hyperledger Besu on August 4th.
- Mark Wagner led the Hyperledger mentorship project to have Besu run on OpenShift with Josh Fernandes' help. The mentorship proejct was completed last week with the work completed.
Current Plans
- The project team remains currently working towards its 1.6 Release, scheduled for mid-October. The 1.6 Release is expected to include the following features:
- Berlin network upgrade preparation
- P2P improvements
- Performance improvements and testing for privacy groups
- Bonsai Tries
- Similar to last quarter, Besu is also continuing to engage with its community and grow the diversity of its maintainer and contributor base. The team is also looking forward to participating at the Hyperledger Member Summit.
Maintainer Diversity
Our maintainer diversity remained fairly consistent from the prior quarter. We continue to have maintainers from four different organizations.
The four organizations include:
- ConsenSys (PegaSys)
- Web3Labs
- Chainsafe
- Splunk (maintainer was formerly at Machine Consultancy)
The new maintainers this quarter include:
- Stefan Pingel (ConsenSys)
- David Mechler (ConsenSys)
We had a one maintainer transition to Emeritus in the last quarter.
The maintainers breakdown is currently:
- 16% non-ConsenSys - This is a slight decrase from 21% in the prior quarter
Contributor Diversity
Commits from 2020-06-08 to 2020-08-28 : 216
Committers from 2020-06-08 to 2020-08-28 : 26 (9 non-PegaSys)
Identified Orgs 2020-06-08 to 2020-08-28 : 5 + 4 independent
Additional Information
Reviewed by
- Angelo De Caro
- Arnaud J Le Hors
- Christopher Ferris
- Dan Middleton
- Gari Singh
- Hart Montgomery
- Mark Wagner
- Nathan George
- Swetha Repakula
- Tracy Kuhrt
- Troy Ronda
2 Comments
Tracy Kuhrt
Regarding the question, the Release Taxonomy specifies that releases within Hyperledger are done according to semvar. I assume that in order to change this, we would need to make this a formal decision. Can you provide information on the benefits of moving away from semvar?
Danno Ferrin
Yes, we expect it would take TSC approval. Would a stand alone pitch be better?
SemVer is great for libraries, especially where multiple release streams are maintained for compatibility. But because Besu is committed to Ethereum Mainnet compatibility there is only one release stream that matters: does it sync to mainnet? We think that a CalVer versioning for the main DLT release itself would better signal how aligned we are to the continually moving target of mainnet compatibility. We think it will also more clearly communicate multiple release streams should not be expected.
If Besu independently controlled what mainnet looked like we could better align chain versions to SemVer, but while some Besu maintainers participate in Ethereum mainnet co-ordination we don't control the composition of the mainnet.