The PIP is a "Pulsar Improvement Proposal" and it's the mechanism used to propose changes to the Apache Pulsar codebases.
The changes might be in terms of new features, large code refactoring, changes to APIs.
In practical terms, the PIP defines a process in which developers can submit a design doc, receive feedback and get the "go ahead" to execute.
There are several goals for the PIP process:
-
Ensure community technical discussion of major changes to the Apache Pulsar codebase.
-
Provide clear and thorough design documentation of the proposed changes. Make sure every Pulsar developer will have enough context to effectively perform a code review of the Pull Requests.
-
Use the PIP document to serve as the baseline on which to create the documentation for the new feature.
-
Have greater scrutiny to changes are affecting the public APIs (as defined below) to reduce chances of introducing breaking changes or APIs that are not expressing an ideal semantic.
It is not a goal for PIP to add undue process or slow-down the development.
- Any new feature for Pulsar brokers or client
- Any change to the public APIs (Client APIs, REST APIs, Plugin APIs)
- Any change to the wire protocol APIs
- Any change to the API of Pulsar CLI tools (eg: new options)
- Any change to the semantic of existing functionality, even when current behavior is incorrect.
- Any large code change that will touch multiple components
- Any changes to the metrics (metrics endpoint, topic stats, topics internal stats, broker stats, etc.)
- Any change to the configuration
- Bug-fixes
- Simple enhancements that won't affect the APIs or the semantic
- Small documentation changes
- Small website changes
- Build scripts changes (except: a complete rewrite)
Any person willing to contribute to the Apache Pulsar project is welcome to create a PIP.
A PIP proposal can be in these states:
-
DRAFT: (Optional) This might be used for contributors to collaborate and to seek feedback on an incomplete version of the proposal.
-
DISCUSSION: The proposal has been submitted to the community for feedback and approval.
-
ACCEPTED: The proposal has been accepted by the Pulsar project.
-
REJECTED: The proposal has not been accepted by the Pulsar project.
-
IMPLEMENTED: The implementation of the proposed changes have been completed and everything has been merged.
-
RELEASED: The proposed changes have been included in an official Apache Pulsar release.
The process works in the following way:
- Fork https://github.com/apache/pulsar repository (Using the fork button on GitHub).
- Clone the repository, and on it, copy the file
pip/TEMPLATE.md
and name itpip-xxx.md
. The numberxxx
should be the next sequential number after the last contributed PIP. You view the list of contributed PIPs (at any status) as a list of Pull Requests having a "PIP" label. Use the link here as shortcut. - Write the proposal following the section outlined by the template and the explanation for each section in the comment it contains (you can delete the comment once done).
- If you need diagrams, avoid attaching large files. You can use MermaidJS as simple language to describe many types of diagrams.
- Create GitHub Pull request (PR). The PR title should be
[improve][pip] PIP-xxx: {title}
, where thexxx
match the number given in previous step (file-name). Replace{title}
with a short title to your proposal. Validate again that your number does not collide, by step (2) numbering check. - The author(s) will email the [email protected] mailing list to kick off a discussion, using subject prefix
[DISCUSS] PIP-xxx: {PIP TITLE}
. The discussion will happen in broader context either on the mailing list or as general comments on the PR. Many of the discussion items will be on particular aspect of the proposal, hence they should be as comments in the PR to specific lines in the proposal file. - Update file with a link to the discussion on the mailing. You can obtain it from Apache Pony Mail.
- Based on the discussion and feedback, some changes might be applied by authors to the text of the proposal. They will be applied as extra commits, making it easier to track the changes.
- Once some consensus is reached, there will be a vote to formally approve the proposal. The vote will be held on the [email protected] mailing list, by
sending a message using subject
[VOTE] PIP-xxx: {PIP TITLE}
. Make sure to include a link to the PIP PR in the body of the message. Make sure to update the PIP with a link to the vote. You can obtain it from Apache Pony Mail. Everyone is welcome to vote on the proposal, though only the vote of the PMC members will be considered binding. It is required to have a lazy majority of at least 3 binding +1s votes. The vote should stay open for at least 48 hours. - When the vote is closed, if the outcome is positive, ask a PMC member (using voting thread on mailing list) to merge the PR.
- If the outcome is negative, please close the PR (with a small comment that the close is a result of a vote).
All the future implementation Pull Requests that will be created, should always reference the PIP-XXX in the commit log message and the PR title. It is advised to create a master GitHub issue to formulate the execution plan and track its progress.
- Eve ran into some issues with the client metrics - she needed a metric which was missing.
- She read the code a bit, and has an idea what metrics she wishes to add.
- She summarized her idea and direction in an email to the DEV mailing list (she located it on Discussions section on the website.
- She didn't get any response from the community, so she joined the next community meeting. There Matteo Merli and Asaf helped setup a channel in Slack to brainstorm the idea and meet on Zoom with a few Pulsar contributors (e.g. Lari and Tison).
- Once Eve had a good enough context, and good design outline, she opened a new branch in her Pulsar repository, duplicated TEMPLATE.md and created pip-xxx.MD (the number she will take later).
- She followed the template and submitted the pip as a new PR to pulsar repository.
- Once the PR was created, she modified the version to match the rules described at step 2, both for PR title and file name.
- She sent an email to the DEV mailing list, titled "[DISCUSS] PIP-123: Adding metrics for ..." , described shortly in the email what the PIP was about and gave a link.
- She got no response for anyone for 2 weeks, so she nudged the people that helped her brainstorm (e.g. Lary and Tison) and pinged in #dev that she needs more reviewers.
- Once she got 3 reviews from PMC members and the community had at least a few days from the moment the PR was announceed on DEV, she sent a vote email to the DEV mailing list titled "[VOTE] PIP-123: Adding metrics for ...".
- She nudged the reviewers to reply with a binding vote, waited for 2-3 days, and then concluded the vote by sending a reply tallying up the binding and non-binding votes.
- She updated the PIP with links to discuss and vote emails, and then asked a PMC member who voted +1, to merge (using GitHub mentionon the PR).
You can the view list of PIPs previously managed by GitHub wiki or GitHub issues here
- You can view all PIPs (besides the historical ones) as the list of Pull Requests having title starting with
[improve][pip] PIP-
. Here is the link for it.- Merged PR means the PIP was accepted.
- Closed PR means the PIP was rejected.
- Open PR means the PIP was submitted and is in the process of discussion.
- You can also take a look at the file in the
pip
folder. Each one is an approved PIP.