Version Support

A list of the support windows provided for language implementations.

Support windows for protoc and the various languages are covered in the tables later in this topic. Version numbers throughout this topic use SemVer conventions; in the version “3.21.7,” we say that “3” is the major version, “21” is the minor version, and “7” is the micro or patch number.

Starting with the v20.x protoc release, we changed our versioning scheme to enable nimbler updates to language-specific parts of Protocol Buffers. In the new scheme, each language has its own major version that can be incremented independently of other languages. The minor and patch versions, however, remain coupled. This allows us to introduce breaking changes into some languages without requiring a bump of the major version in languages that do not experience a breaking change. For example, a single release might include protoc version 24.0, Java runtime version 4.24.0 and C# runtime version 3.24.0.

The first instance of this new versioning scheme was the 4.21.0 version of the Python API, which followed the preceding version, 3.20.1. Other language APIs released at the same time were released as 3.21.0.

Release Cadence

Protobuf strives to release updates quarterly. We may add a release if there is an urgent need such as a security fix that requires new APIs. Skipping a release should be a very rare event.

Major (breaking) releases will be targeted to the Q1 release. We may introduce a major breaking change at any time if there is an urgent need, but this should be very rare.

Our support windows are defined by our library breaking change policy.

Protobuf does not consider enforcement of its documented language, tooling, platform, and library support policies to be a breaking change. For example, a release may drop support for an EOL language version without bumping major versions.

What Changes in a Release?

The binary wire format does not change even in major version updates. You will continue to be able to read old binary wire format proto data from newer versions of Protocol Buffers. Newly generated protobuf bindings serialized to binary wire format will be parseable by older binaries. This is a fundamental design principle of Protocol Buffers. Note that JSON and textproto formats do not offer the same stability guarantees.

The descriptor.proto schema can change. In minor or patch releases, we may add new message, fields, enums, enum values, editions, editions features etc. We may also mark existing elements as deprecated. In a major release, we may remove deprecated options, enums, enum values, messages, fields, etc.

The .proto language grammar can change. In minor or patch releases, we may add new language constructs and alternative syntax for existing features. We may also mark certain features as deprecated. This could result in new warnings that were not previously emitted by protoc. In a major release, we may remove support for obsolete features, syntax, editions in a way that will require updates to client code.

Gencode and runtime APIs can change. In minor or patch releases, changes will either be purely additive for new functionality or source-compatible updates. Simply recompiling code should work. In a major release, the gencode or runtime API can change in incompatible ways that require callsite changes. We try to minimize these. Changes fixing or otherwise affecting undefined behavior are not considered breaking, and do not require a major release.

Operating system, programming language, and tooling version support can change. In a minor or patch release, we may add or drop support for particular versions of an operating system, programming language, or tooling. See foundational support matrices for our supported languages.

In general:

  • Minor or patch releases should only contain purely additive or source-compatible updates per our Cross Version Runtime Guarantee
  • Major releases may remove functionality, features, or change APIs in ways that require updates to callsites.

Support Duration

The most recent release is always supported. Support for earlier minor versions ends when a new minor version under the same major version is released. Support for earlier major versions ends four quarters beyond the quarter that the breaking release is introduced. For example, when Python 4.21.0 was released in May of 2022, that set the end of public support of Python 3.20.1 at the end of 2023 Q2.

The following sections provide a guide to the support for each language.

C++

This table provides specific dates for support duration.

BranchInitial ReleasePublic Support Until
3.21.x25 May 202231 Mar 2024
4.22.x16 Feb 20238 May 2023
4.23.x8 May 20238 Aug 2023
4.24.x8 Aug 20231 Nov 2023
4.25.x1 Nov 202331 Mar 2025
5.26.x13 Mar 202423 May 2024
5.27.x23 May 2024TBD

This table graphically shows support durations.

C++ will target making major version bumps annually in Q1 of each year.

protocC++23Q123Q223Q323Q424Q124Q224Q324Q4
21.x3.21.xPSPSPSPSSE
22.x4.22.xIR
23.x4.23.xIR
24.x4.24.xIR
25.x4.25.xIRPSPSPSPS
26.x5.26.xIR
27.x5.27.xIRPSPS
The cells below are projections of future releases, but are not guarantees
that those releases will happen, or that they will happen on that schedule.
28.xIR
29.xIR
Legend
Initial release (IR)
Public support (PS)
Support ends (SE)

C++ Tooling, Platform, and Library Support

Protobuf is committed to following the tooling, platform, and library support policy described in Foundational C++ Support Policy. For specific versions supported, see Foundational C++ Support Matrix.

C#

This table provides specific dates for support duration.

BranchInitial ReleasePublic Support Until
3.22.x16 Feb 20238 May 2023
3.23.x8 May 20238 Aug 2023
3.24.x8 Aug 20231 Nov 2023
3.25.x1 Nov 202313 Mar 2024
3.26.x13 Mar 202423 May 2024
3.27.x23 May 2024TBD

This table graphically shows support durations.

protocC#23Q123Q223Q323Q424Q124Q224Q324Q4
22.x3.22.xIR
23.x3.23.xIR
24.x3.24.xIR
25.x3.25.xIR
26.x3.26.xIR
27.x3.27.xIRPSPS
The cells below are projections of future releases, but are not guarantees
that those releases will happen, or that they will happen on that schedule.
28.xIR
29.xIR
Legend
Initial release (IR)
Public support (PS)
Support ends (SE)

C# Platform and Library Support

Protobuf is committed to following the platform and library support policy described in .NET Support Policy. For specific versions supported, see Foundational .NET Support Matrix.

Java

This table provides specific dates for support duration.

BranchInitial ReleasePublic Support Until
3.19.x20 Oct 202125 Mar 2022
3.20.x25 Mar 202225 May 2022
3.21.x25 May 202216 Feb 2023
3.22.x16 Feb 20238 May 2023
3.23.x8 May 20238 Aug 2023
3.24.x8 Aug 20231 Nov 2023
3.25.x1 Nov 202331 Mar 2026*
4.26.x13 Mar 202423 May 2024
4.27.x23 May 2024TBD

NOTE: the support window for the Java 3.25.x release will be 24 months rather than the typical 12 months for the final release in a major version line. Future major version updates (5.x+) will adopt an improved “rolling compatibility window” that should allow a return to 12-month support windows.

This table graphically shows support durations.

Java will target making major version bumps annually in Q1 of each year.

protocJava23Q223Q323Q424Q124Q224Q324Q425Q125Q2
22.x3.22.x
23.x3.23.xIR
24.x3.24.xIR
25.x3.25.xIRPSPSPSPSPSPS
26.x4.26.xIR
27.x4.27.xIRPSPSPSPS
The cells below are projections of future releases, but are not guarantees
that those releases will happen, or that they will happen on that schedule.
28.x4.28.xIR
29.x4.29.xIR
30.x5.30.xIR
Legend
Initial release (IR)
Public support (PS)
Support ends (SE)

Java Platform and Library Support

Protobuf is committed to following the platform and library support policy described in Java Support Policy. For specific versions supported, see Foundational Java Support Matrix.

Objective-C

This table provides specific dates for support duration.

BranchInitial ReleasePublic Support Until
3.22.x16 Feb 20238 May 2023
3.23.x8 May 20238 Aug 2023
3.24.x8 Aug 20231 Nov 2023
3.25.x1 Nov 202313 Mar 2024
3.26.x13 Mar 202423 May 2024
3.27.x23 May 2024TBD

This table graphically shows support durations.

protocObjC23Q123Q223Q323Q424Q124Q224Q324Q4
22.x3.22.xIR
23.x3.23.xIR
24.x3.24.xIR
25.x3.25.xIR
26.x3.26.xIR
27.x3.27.xIRPSPS
The cells below are projections of future releases, but are not guarantees
that those releases will happen, or that they will happen on that schedule.
28.xIR
29.xIR
Legend
Initial release (IR)
Public support (PS)
Support ends (SE)

PHP

This table provides specific dates for support duration.

BranchInitial ReleasePublic Support Until
3.22.x16 Feb 20238 May 2023
3.23.x8 May 20238 Aug 2023
3.24.x8 Aug 20231 Nov 2023
3.25.x1 Nov 202331 Mar 2025
4.26.x13 Mar 202423 May 2024
4.27.x23 May 2024TBD

This table graphically shows support durations.

protocPHP23Q123Q223Q323Q424Q124Q224Q324Q425Q125Q2
22.x3.22.xIR
23.x3.23.xIR
24.x3.24.xIR
25.x3.25.xIRPSPSPSPSPSSE
26.x4.26.xIR
27.x4.27.xIRPSPSPSPS
The cells below are projections of future releases, but are not guarantees
that those releases will happen, or that they will happen on that schedule.
28.xIR
29.xIR
Legend
Initial release (IR)
Public support (PS)
Support ends (SE)

PHP Platform and Library Support

Protobuf is committed to following the platform and library support policy described in PHP Support Policy. For specific versions supported, see Foundational PHP Support Matrix.

Python

This table provides specific dates for support duration.

BranchInitial ReleasePublic Support Until
3.20.x25 Mar 202230 Jun 2023
4.21.x25 May 202216 Feb 2023
4.22.x16 Feb 20238 May 2023
4.23.x8 May 20238 Aug 2023
4.24.x8 Aug 20231 Nov 2023
4.25.x1 Nov 202331 Mar 2025
5.26.x13 Mar 202423 May 2024
5.27.x23 May 2024TBD

This table graphically shows support durations.

protocPython22Q322Q423Q123Q223Q323Q424Q124Q224Q324Q425Q125Q2
20.x3.20.xPSPSPSSE
21.x4.21.xPSPS
22.x4.22.xIR
23.x4.23.xIR
24.x4.24.xIR
25.x4.25.xIRPSPSPSPSPSSE
26.x5.26.xIR
27.x5.27.xIRPSPSPSPS
The cells below are projections of future releases, but are not guarantees
that those releases will happen, or that they will happen on that schedule.
28.xIR
29.xIR
Legend
Initial release (IR)
Public support (PS)
Support ends (SE)

Python Platform and Library Support

Protobuf is committed to following the platform and library support policy described in Python Support Policy. For specific versions supported, see Foundational Python Support Matrix.

Ruby

This table provides specific dates for support duration.

BranchInitial ReleasePublic Support Until
3.21.x25 May 202216 Feb 2023
3.22.x16 Feb 20238 May 2023
3.23.x8 May 20238 Aug 2023
3.24.x8 Aug 20231 Nov 2023
3.25.x1 Nov 202331 Mar 2025
4.26.x13 Mar 202423 May 2024
4.27.x23 May 2024TBD

This table graphically shows support durations.

protocRuby23Q123Q223Q323Q424Q124Q224Q324Q425Q125Q2
22.x3.22.xIR
23.x3.23.xIR
24.x3.24.xIR
25.x3.25.xIRPSPSPSPSPSSE
26.x4.26.xIR
27.x4.27.xIRPSPSPSPS
The cells below are projections of future releases, but are not guarantees
that those releases will happen, or that they will happen on that schedule.
28.xIR
29.xIR
Legend
Initial release (IR)
Public support (PS)
Support ends (SE)

Ruby Platform and Library Support

Protobuf is committed to following the platform and library support policy described in Ruby Support Policy. For specific versions supported, see Foundational Ruby Support Matrix.

JRuby is not officially supported, but we provide unofficial support for the latest JRuby version targeting compatibility with our minimum Ruby version or above on a best-effort basis.