The release team leader role is responsible for coordinating release activities, assembling the release team, taking ultimate accountability for all release tasks to be completed on time, and ensuring that a retrospective happens. The lead is also responsible for ensuring a successor is selected and trained for future release cycles.
- Authority and Responsibility
- Prerequisites
- Skills and Experience Required
- Time Commitments
- Choosing a Release Team
- Standards
- Release Milestone Activities
- Release Halfway Point
- Release Day
The Release Team Lead should be an arbiter of decisions, and not the primary decision-maker. A lead should constantly search for the best-qualified people or SIGs to guide the decision, not "go it alone", unless it is a very specific concern within the release process itself. When decisions are made they must be weighted in favor of community concerns over those of individuals or specific companies. Leads must also relinquish any favoritism for the company they work for. If there is a conflict of interest, the lead must recuse themselves from that decision. Above all, the release lead is a servant leader to the team and the community.
Before we can grant access to new Release Team Leads, a Release Team Lead onboarding issue MUST be opened in this repo. Please take a moment to do that before executing the tasks contained in this handbook.
This role requires a tremendous amount of experience with the Kubernetes community, code layout, ecosystem projects, organizational norms, governance, SIG structure, architecture, and release process.
In addition to the Release Team Lead selection criteria you are required to fulfill, there are some additional aspirations we have for a Release Team Lead.
- The Release Team is a global volunteer group, as is the Kubernetes project, so the Lead must be prepared to schedule and attend meetings that may be very late or very early in their time zone, in order to include as many of the team as possible.
- Project management experience is highly desirable
- Strong written and verbal communications skills are required
- As the public face of the community during release time, you must do so with a very high level of professionalism
- Prior experience in release management is extremely helpful
Release Lead is a very time-consuming role, especially towards the end of the release cycle. Before you volunteer to be Release Lead, please make certain that your employer and your family are okay with you spending a lot of time on the release for the next four months. Here's a rough estimate of the time requirements by week:
- Weeks 1-4: 4-8 hours a week
- Weeks 5-10: 6-12 hours a week
- Weeks 11-15: 10 to 25 hours a week
- Release Day: Prepare to spend all day on release-related activities. Given the choice between working after-hours or weekends, and having the release be later than the initial target, delaying the release is preferred.
Among the specific time commitments you have are:
- SIG Release and Release Team meetings once a week during weeks 1-10.
- Burndown meetings three to five times a week during weeks 11-15.
In addition to the absolute time commitment you make, you must also consider the relative burdens on yourself and your team when establishing meetings. This means scheduling meetings and release events compatible with global working hours and coordinating with a global set of team leads and shadows. A few ways to accomplish this goal are as follows (but please feel free to implement and add your own solution):
- Create a poll amongst your Leads as to their preferred meeting time
- Schedule duplicate meetings at alternate times (these can be run by Shadows in those time zones)
- Encourage delegation of reports and meetings to Shadows
- Vary the final weeks' burndown meeting times
- Work to maximize asynchronous communications and reduce face to face meetings to where absolutely required.
- Time sacrifices may be necessary at times and the Release Team Lead should endeavor to spread this so as not to focus any inconvenience on specific individuals or specific geographies, for example considering major global holidays and KubeCons when planning the release timeline while also making sure the project is correctly moving forward.
Please lead by example and encourage everyone to work within their working hours as much as possible.
One of your first and definitely most important duties as Release Lead is to ensure a Release Team is in place.
Release Team selection should happen in accordance with the Release Team selection process.
- The GitHub repository layout is:
- kubernetes/sig-release
- releases/release-x.y
- README.md (release schedule)
- release-notes-draft.md (consumed by the automated release process)
- release_team.md
- releases/release-x.y
- kubernetes/sig-release
- Short links are handled with http://bit.ly. Each release should have the following documents (replacing XYY with the release version number minus dots):
- Retro doc:
http://bit.ly/k8sXYYretro
- Release Schedule overview:
http://bit.ly/k8sXYY-release-info
- Zoom link:
http://bit.ly/k8sXYY-zoom
- Burndown/Meeting Minutes:
http://bit.ly/k8sXYY-burndown
- Enhancements tracking spreadsheet:
http://bit.ly/k8sXYY-enhancement-tracking
- Merged PRs with release notes:
http://bit.ly/k8sXYY-relnotes
- Use the same conventions for additional documents
- Retro doc:
- Burndown meetings happen at 10AM Pacific Time, and you invite the community calendar (
[email protected]
) and the Kubernetes Release calendar ([email protected]
) to them. - Burndown communications happen on the kubernetes-sig-release mailing list.
- Enhancement exceptions are to be reviewed by the owning SIG and brought to the Release Team for assessment of risk, especially across the project
- General notification regarding the release should go to the kubernetes-dev and kubernetes-sig-leads lists, and this should automatically be captured into the Kubernetes Discourse site.
- All issues and PRs in the milestone are considered release-blocking until proven otherwise by the owning SIG.
- Issues and PRs are added to the milestone by members of the milestone-maintainers GitHub team, which primarily includes SIG leads. Review the milestone-maintainers page for full criteria for membership to that team. The Release Team Lead is responsible for adding certain members of the Release Team to the group, and should check with and prune prior Release Team members who are no longer active.
- Members of the Release Team should not be the primary contributors making the choice whether issues and PRs are in a milestone. This is the job of SIG Leads. However, the Release Team may apply milestones when doing housekeeping on tracked issues and PRs where the milestone label has clearly been forgotten.
- The Release Team Lead is responsible for updating the [burndown template] ahead of the release (changing the milestone in links and anything else requested during the retrospective)
- Release theme: There is no particular reason for this other than to have fun, and possibly provide a theme for Release Team gifts. As Release Team Lead, you get to pick a theme for the release.
- Kubernetes 1.8 to 1.10, had unofficial food-based code names.
- 1.8 - "Burrito"
- 1.9 - "Pumpkin"
- 1.10 - "Kiwi"
- Kubernetes 1.10 had a late change to "Left Shark".
- Kubernetes 1.11 had a Tolkien theme of "Eleventy-One: A Long-Expected Release"
- Kubernetes 1.12: Game of Life
- Kubernetes 1.13: Angel Release
- Kubernetes 1.14: Caturnetes
- Kubernetes 1.15: Game of Release/Thrones
- Kubernetes 1.16: Unlimited Breadsticks For All
- Kubernetes 1.17: The Chillest Release - Capynetes
- Kubernetes 1.8 to 1.10, had unofficial food-based code names.
Important communications and discussions should be posted in the Release Team mailing list kubernetes-release-team.
This list is owned by SIG Release and as such the SIG Release Chairs are owners of it. While SIG Release leads are owners of this list, the Release Team Lead and Release Team Lead shadows will serve as managers of the list for the duration of the cycle.
The Release Team Lead and Release Team Lead shadows should periodically go through the Release Team mailing list and prune members from the last release who are no longer part of the Release Team. This should be done after shadows for the new release cycle have been chosen but before sending invites to the new members.
The membership criteria is as follows:
- All members of the Release Team must be part of the mailing list
- All members of the Branch Management Team must be part of the mailing list
- SIG Release Chairs must be part of the mailing list
You cannot start too early on this!
Once you have a release theme, there is a budget for you to create a release team gift as a thank you for each of your hard working team members. This gift can be a T-shirt, or a badge, but can be anything customizable within the budget, with a fun design of your choice and creation that relates to the release theme. Coordinate with SIG-Release Chairs (who have access to the CNCF Service Desk as well as know the budget) to put in an order, and make sure everyone gets their release swag gift.
- Attend previous release retro to capture feedback and incorporate it into next release cycle
- Plan release schedule and milestones. Gather feedback as needed.
- Schedule three (3) retrospective dates:
- The first retrospective is held during the cycle in the first week of M, W, F burndown meetings -- typically mid-week.
- The second and third retrospectives are traditionally scheduled a week after the release.
- The third retrospective may not be needed and is scheduled if necessary.
- Schedule three (3) retrospective dates:
- Make sure you have your shadows confirmed and schedule an initial group meeting to onboard and establish timeline and responsibilities.
- Make sure everyone joining the team reads the release team onboarding document.
- Complete the CNCF Inclusive Speaker Orientation.
- Complete a Release Team Lead onboarding issue for the Lead and RT Lead Shadows
- Send a "Release Sneak Peak" email to introduce yourself, lead shadows, role leads, and branch manager to k-dev, SIG Leads, SIG Release, Release Team
While the Release Team Lead has always been a stakeholder in getting security fixes out the door, the Kubernetes security disclosures and response policy has evolved into something more formal. The documents linked below are required reading for an incoming Release Team Lead, who must understand and abide by the embargo policy.
- Ensure the release team is fully filled, with members subscribed to the kubernetes-release-team and kubernetes-sig-release groups and to the kubernetes-release-calendar.
- Create an internal contact sheet and corresponding bit.ly link. Make sure to only give access to the kubernetes-release-team. Communicate with section leads to add their shadows so that you and your shadows can add them to the kubernetes-release-team.
- Ensure SIG Release co-chairs replace the outgoing Emeritus Advisor with the new Emeritus Advisor as an owner of the kubernetes-release-team-shadows Google Group.
- Ensure top-level OWNERS_ALIASES only includes Release Team personnel from four (4) releases, including the current one.
- Create and finalize the release schedule, blocking test gates, and role assignments as a pull request in: kubernetes/sig-release/releases/release-x.y/README.md Note: Do not schedule any deadlines or milestones on a Monday or Friday, aim for Tuesday, Wednesday, or Thursday Note: Do not ship the release on a Monday, to avoid preparing for the release on a weekend. Aim for Tuesday.
- Send an update to kubernetes-dev and kubernetes-sig-leads mailing list to announce the start of the release cycle, including any notable changes in the release process, key dates, and links to important documents
- Create the retrospective document and corresponding bit.ly link. Insert this link in the list of retrospectives in the header of the kubernetes-community-meeting(Kubernetes Community Meeting Topics) document.
- Begin meeting with SIGs to introduce yourself
- Begin paying attention to CI signal, as it may begin degrading soon after the prior release is cut and any slips must be caught and rectified promptly.
- Request, in coordination with CI Signal Lead, a representative from SIG Scalability to give a weekly update on the release meeting notes. Prepare to have a release team representative attend SIG Scalability's meeting two or three times throughout the release.
- 48 hours before the weekly Release Team meeting, ping the Scalability oncall person listed on go.k8s.io/oncall on the #release-ci-signal Slack channel to add the scalability tests status on the Release Team meeting notes under SIG Scalability
- Meet your Shadows and create a communication channel with them. Establish expectations and share out work - delegate!
- Request review of this document by the Release Team Lead shadow(s). The shadow(s) should also take all actions in this document around joining groups and requesting access permissions.
- Update the SIG Release groups in the k/k8s.io/groups/sig-release/groups.yaml with the following:
- Add Lead and Lead shadows to members of
k8s-infra-release-viewers
- Add EA, Lead, Lead shadows, comms lead, comms shadows to members of
release-comms
- Add EA, Lead and Lead shadows to members of
release-managers
- Add EA, Lead and Lead shadows to managers of
release-team
- Add Role Leads and Role shadows to members of
release-team
- Add Role shadows and Lead shadows to members of
release-team-shadows
- Add EA to manager of
release-team-shadows
, if EA is owner ofrelease-team-shadows
already then add Lead to manager ofrelease-team-shadows
- Add Bug Triage Lead and shadows to
k8s-infra-rbac-triageparty-release
- Add Lead and Lead shadows to members of
- Request access to the Kubernetes Release Calendar from a SIG Release Tech Lead or the EA
- At the end of each Release Team meeting, end the meeting recording and provide time for team members to be open with comments or questions
- Create the release notes directory in the release directory
- Prepare for x.y.0-alpha.1 release, specifically that there is a Branch Manager available to support the team, and that
master-blocking tests are all green. The alpha.0 artifacts were created already as a part of the prior release. This synthetic notation is a point to review process with the Branch Manager.
- x.y.0-alpha.1 may be released before the release cycle begins.
- Assist the Enhancements Lead in collecting planned work from SIGs
- Schedule weekly Release Team meetings on a day that is most acceptable to the team. These will eventually turn into burndown meetings and occur daily. Invite the kubernetes-sig-release group.
- Poll Release Team membership and schedule a weekly alternate meeting to better enable more attendance outside of the Americas.
- Add key event dates to the Kubernetes Release Calendar during the cycle.
- Ensure major calendar events are set to send an email reminder one week in advance.
- Invite the K8s Contributor Calendar ([email protected]) to major calendar events.
- e.g. Enhancements Freeze, Code Freeze, etc
- Add a calendar entry for the time period before Enhancements Freeze with the title [1.xx] Enhancements Freeze coming on HH:mm PDT Month Day, Year
- When creating Google calendar entries, delete the Google Meet link which is created by default
- Be aware of the time zone when creating Google calendar entries as it will default to the last time zone used to create the last calendar entry
- Continue meeting with SIGs for introductions
- Prepare for x.y.0-alpha.2 release and that master-blocking tests are all green.
- Identify any other dependent ecosystem projects that need release coordination
- Announce/email that the following week is Enhancements Freeze and what that means
- Assist the Enhancements Lead with anything required for Enhancements Freeze
- Remind the community about Enhancements Freeze
- Make sure everything is in synch between the enhancements repo and the enhancements tracking spreadsheet
- If there are enhancements with questions or concerns, help coordinate those conversations between the team and the SIG/owners
- Start collecting SIG release themes in the release notes draft, outlining what they are delivering this release milestone, and how it aligns with their mission statements - start with SIGs identifying enhancements in the enhancements repo, and focus on those since not every SIG will be delivering something
- Bring exceptions to the #sig-release Slack channel and to Release Team meetings, and make sure SIG representatives for the exception(s) know to attend and discuss if necessary.
- Begin casual observation of issues, CI signal, test flakes, and critical PRs
- Prepare for x.y.0-alpha.3 release and that master-blocking tests are all green.
- Continue reviewing enhancement exceptions as needed
- Prepare for x.y.0-alpha.4 release and that master-blocking tests are all green.
- Check in with Release Notes team on release notes progress after the release notes for x.y.0-alpha.4 is generated.
- The burndown templates should be useful at this point since it starts asking about status relevant to each area now tracking (e.g. branch health, docs, communications, issues, etc.)
- Most enhancement-oriented tasks should be completed at the end of this week
- SIGs that have not completed release themes should be contacted again, with a focus on explaining why this matters to the community
- Send a "Release Update / State of the Release" email with the number of enhancements tracked, retro dates, upcoming deadlines and solicit exceptions for Enhancements Freeze, feature blogs for the release, Doc PRs for new or updated docs associated with tracked enhancements, and release themes.
- Exception requests for Enhancements Freeze should be almost zero
- Check in with SIGs on their enhancement work to make sure they know Code Freeze is 3 weeks away, as well as emailing the kubernetes-dev list, and notifying the community at the weekly meeting
- Verify with SIGs if there are any planned deprecations or removals targeting the release.
- Adjust the enhancements repo/tracking spreadsheet as necessary (this may also require modifying themes that can’t be delivered)
- If there are any deprecations or removals, the Release Team should publish a Deprecations and Removals blog.
- The Enhancements team starts to communicate with the Comms team bout deprecations and removals targeting the release.
- A Release Team representative (ideally from Comms) should attend the SIG Docs meeting to raise awareness about the Deprecations and Removals blog for reviews.
- Ping role leads reminding them to start considering succession plans. If they are handing the role off to a successor, identifying them early gives more time for the committed volunteer to get targeted mentoring.
- The once-weekly release meeting schedule now shifts to M, W, F and becomes burndown-specific (the template should be used from here forward and will need to be updated ahead of the meeting, which takes about 10 minutes for the lead, and less for the other team members)
- The first retrospective meeting is scheduled for the first week of M, W, F burndown meetings, typically mid-week. Confirm the Emeritus Adviser can serve as facilitator. If Emeritus Adviser is unavailable then defer the responsibility as appropriate.
- Make sure everyone knows the Docs deadline (PRs ready for review) is coming the following week.
- The Deprecations and Removals blog is scheduled for next week shortly after Code Freeze. A draft of the blog should be started as reviews and iterations will be needed before publication next week.
- Follow up with SIGs on release themes.
Code Freeze will typically fall around Weeks 12 or 13 depending on the length or release cycle. As Code Freeze approaches here are some good practices
- Monitor the enhancements spreadsheet to get an idea of how many PRs are still outstanding leading up to Code Freeze
- Send a reminder email to kubernetes-dev
- Monitor Testgrid and Prow to understand the stability of the release and PRs getting ready to merge. If Prow and Test grid are not in a good state consult folks from SIG Testing on delaying code freeze by a day if needed.
- LGTM / Approve and remove the hold on the PR for enabling code freeze. Example from 1.15 here
- As needed, assist the Bug Triage Lead and Enhancements Lead removing PRs and enhancements from the milestone that aren't merged in time
- Begin daily burndown meetings
- Code Freeze begins, and it’s now the home stretch of the release. SIGs will need to ensure all work moving forward is carefully curated with required merge labels.
- The code exception process is now in effect, meaning you will likely have to assemble decision makers on specific pending PRs to assess whether the risk of inclusion is acceptable or not. Remember this is not you making a decision, it’s you helping SIGs follow the process, and ensuring there’s consensus. In the event of a contentious PR, you should err on the side of risk aversion. In extreme cases, you can defer to the steering committee, but that is extremely unlikely.
- If the release branch is not healthy, stable, and passing tests consistently, notify community through standard channels of need to rectify or code freeze will come early to force focus on stabilization.
- Coordinate x.y.0-beta.0 release (~week 12, shortly after Code Freeze), ensuring master-blocking are 100% green if possible (this release is not an official beta, just an artifact of the release process), and any flakes are being actively worked by SIGs since this is a chance to look at CI signal.
- Shortly after Code Freeze, publish the Deprecations and Removals blog after appropriate reviews and
lgtm
, andapprove
labels from SIG Docs. - Remind Branch Manager that branch CI jobs will be needed next week.
- Test Freeze begins
- The release-x.y branch is created automatically at the start of Test Freeze.
- PRs targeting the release must be cherry-picked into the release-x.y branch from master.
- Branch Manager has release branch CI created and added to Testgrid
- Branch Manager ensures automation is ready to enforce labeling and other release policies
- Prepare for x.y.0-rc.0 release (shortly after Test Freeze), ensuring x.y-blocking, master-blocking are 100% green, or all failures have issues filed and are being actively worked.
- Release themes should be completed by now
- Branch Manager ensures automation is actively enforcing merge blocking labeling and other release policies
- The Release Team needs to look at any in-flight PRs and ensure nothing is being jammed in at the last minute without proper tests, review, etc. This is something to watch extremely closely because it happens every release. Just watch what gets merged closely after Code Freeze. Incorrectly merged items need assessed and perhaps reverted. GitHub has a query comparing a release branch and master.
- Assist the Documentation Leads in collecting missing docs PRs.
- Schedule burndown meetings starting next week for every weekday until the Friday after release day. Make sure to invite the community calendar (
[email protected]
) and the Kubernetes Release calendar ([email protected]
). - Release notes and themes should be close to done if not completed. There is a script that gathers notes from PRs but it’s still in progress. As the lead, you may need to help assemble the notes.
- Identify potential vacancies on the incoming Release Team and begin asking team shadows and former team shadows to serve as Lead in the upcoming cycle. Continue to improve and uphold the Release Team Selection process.
- The task is now to ensure the release branch is ready to go. This means there are zero pending PRs, no failing x.y-blocking tests, no open issues in the milestone. This will continue until release day.
- Final documentation PRs are reviewed and ready to be merged. Likely, this is not true and some are outstanding, so you need to help convince SIG doc writers to get these in with urgency.
- The release notes draft needs to be completely done and ready to consume by anago. Have SIG volunteers do a final proofread of their sections. Make sure people actually do this. You need to avoid having the release notes volunteers pull “all nighters” before the release.
- Work with the CNCF, SIG Docs, and Communications Lead to start the Release Blog post pulling from SIG Themes, the enhancements repo, SIG members, and possibly release notes in specific PRs.
- Work with the incoming Release Team Lead to establish incoming Release Team.
- Release Day is coming up! Make the day as fun as you can for the team. Plan ahead for this and do something nice.
- Note that release day can and should be postponed if any of the conditions outlined in week 11 are not satisfied.
- Every issue in the milestone is considered release blocking.
- If you have to push the release date back, try to avoid Friday since it makes release publicity extremely difficult. Also, people seem to have patience with delay as long as the reasons are clear and openly communicated. This is your duty. You must over-communicate and ensure the team is also talking to their stakeholders (CNCF, community, press, etc.)
- Confirm a facilitator for the Release Retrospective
- The following final actions must occur in order, with successful completion of each being the entry criteria to the next.
- Release day morning:
- Go / No-Go: should generally be clear a day or three ahead of release, but the day's burndown provides a final opportunity for the team to affirm things are ready.
- Release Notes Lead PRs final draft release notes to sig-release, with Release Team Lead approving merge.
- Branch Manager does mock release build.
- Branch Manager does mock publication. Validates with Release Team lead and broader team the mock announcement email content.
- Branch Manager does nomock release build.
- Starting when ready:
- Communications Lead begins staging blog post.
- Branch Manager Lead does nomock publication.
- Branch Manager coordinates the building and publishing of rpm/deb packages with Build Admins.
- Build Admins affirms build is complete.
- Docs Lead publishes release docs to website.
- Branch Manager does release-notify.
- Approximately 5pm Pacific: all work is complete and the release team lead announces release to k-dev, SIG Leads, and discuss.k8s.io.
- Release day morning:
- After the release, it’s time to lift code freeze. The bot will need to be updated.
- Thaw k/k, master branch is then opened for new pull requests.
- The Docs lead thaws k/website
- Use all of the appropriate communications channels to announce the lifting of Code Freeze and thawing of k/website, this can part of the release announcement.
-
Release Retrospective participation
- Make sure to confirm that the Emeritus Adviser can serve as facilitator. If Emeritus Adviser is unavailable then defer the responsibility as appropiate
- Make sure that the Release Retrospective invite shows up in the Kubernetes community calendar and invite the following teams as attendees
-
Follow-up interviews with the media, the media roundtable
-
Contact the Release Managers Google Group to complete the Release Team Lead & Lead Shadows offboarding tasks from the previously-opened onboarding issue
-
Help fill any open positions for the next release milestone