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 Protobuf Python 5.26.0 was released in Q1 of 2024, that set the end of support of Protobuf Python 4.25.x at the end of Q1 2025.

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

C++

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

The protoc version can be inferred from the Protobuf C++ minor version number. Example: Protobuf C++ version 4.25.x uses protoc version 25.x.

Future plans are shown in italics and are subject to change.

Release support dates

Protobuf C++Release dateEnd of support
3.x25 May 202231 Mar 2024
4.x16 Feb 202331 Mar 2025
5.x13 Mar 202431 Mar 2026
6.xQ1 202531 Mar 2027

Release support chart

Protobuf C++protoc23Q123Q223Q323Q424Q124Q224Q324Q425Q125Q225Q325Q4
3.x21.x3.213.213.213.213.21
4.x22.x-25.x4.224.234.244.254.254.254.254.254.25
5.x26.x-29.x5.265.275.285.295.295.295.295.29
6.x30.x-33.x6.306.316.326.33

Legend

ActiveMinor and patch releases with new features, compatible changes and bug fixes.
MaintenancePatch releases with critical bug fixes.
End of lifeRelease is unsupported. Users should upgrade to a supported release.
FutureProjected release. Shown for planning purposes.

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#

The protoc version can be inferred from the Protobuf C# minor version number. Example: Protobuf C# version 3.25.x uses protoc version 25.x.

Future plans are shown in italics and are subject to change.

Release support dates

Protobuf C#Release dateEnd of support
3.x16 Feb 2023TBD

Release support chart

Protobuf C#protoc23Q123Q223Q323Q424Q124Q224Q324Q425Q125Q225Q325Q4
3.x22.x-33.x3.223.233.243.253.263.273.283.293.303.313.323.33

Legend

ActiveMinor and patch releases with new features, compatible changes and bug fixes.
MaintenancePatch releases with critical bug fixes.
End of lifeRelease is unsupported. Users should upgrade to a supported release.
FutureProjected release. Shown for planning purposes.

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

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

The protoc version can be inferred from the Protobuf Java minor version number. Example: Protobuf Java version 3.25.x uses protoc version 25.x.

Future plans are shown in italics and are subject to change.

Release support dates

Protobuf JavaRelease dateEnd of support
3.x16 Feb 202331 Mar 2026*
4.x13 Mar 202431 Mar 2027
5.xQ1 2026*31 Mar 2028

NOTE: The maintenance support window for the Protobuf Java 3.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, planned for Q1 2026) will adopt an improved “rolling compatibility window” that should allow a return to 12-month support windows. There will be no major version bump in Q1 2025.

Release support chart

Protobuf Javaprotoc23Q123Q223Q323Q424Q124Q224Q324Q425Q125Q225Q325Q4
3.x22.x-25.x3.223.233.243.253.253.253.253.253.253.253.253.25
4.x26.x-33.x4.264.274.284.294.304.314.324.33

Legend

ActiveMinor and patch releases with new features, compatible changes and bug fixes.
MaintenancePatch releases with critical bug fixes.
End of lifeRelease is unsupported. Users should upgrade to a supported release.
FutureProjected release. Shown for planning purposes.

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.

On Android, Protobuf supports the minimum SDK version that is supported by Google Play services and is the default in Jetpack. If both versions differ, the lower version is supported.

Objective-C

The protoc version can be inferred from the Protobuf Objective-C minor version number. Example: Protobuf Objective-C version 3.25.x uses protoc version 25.x.

Future plans are shown in italics and are subject to change.

Release support dates

Protobuf Objective-CRelease dateEnd of support
3.x16 Feb 202331 Mar 2026
4.xQ1 2025TBD

Release support chart

Protobuf Objective-Cprotoc23Q123Q223Q323Q424Q124Q224Q324Q425Q125Q225Q325Q4
3.x22.x-29.x3.223.233.243.253.263.273.283.293.293.293.293.29
4.x30.x+4.304.314.324.33

Legend

ActiveMinor and patch releases with new features, compatible changes and bug fixes.
MaintenancePatch releases with critical bug fixes.
End of lifeRelease is unsupported. Users should upgrade to a supported release.
FutureProjected release. Shown for planning purposes.

PHP

The protoc version can be inferred from the Protobuf PHP minor version number. Example: Protobuf PHP version 3.25.x uses protoc version 25.x.

Future plans are shown in italics and are subject to change.

Release support dates

Protobuf PHPRelease dateEnd of support
3.x16 Feb 202331 Mar 2025
4.x13 Mar 2024TBD

Release support chart

Protobuf PHPprotoc23Q123Q223Q323Q424Q124Q224Q324Q425Q125Q225Q325Q4
3.x22.x-25.x3.223.233.243.253.253.253.253.253.25
4.x26.x+4.264.274.284.294.304.314.324.33

Legend

ActiveMinor and patch releases with new features, compatible changes and bug fixes.
MaintenancePatch releases with critical bug fixes.
End of lifeRelease is unsupported. Users should upgrade to a supported release.
FutureProjected release. Shown for planning purposes.

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

The protoc version can be inferred from the Protobuf Python minor version number. Example: Protobuf Python version 4.25.x uses protoc version 25.x.

Future plans are shown in italics and are subject to change.

Release support dates

Protobuf PythonRelease dateEnd of support
4.x16 Feb 202331 Mar 2025
5.x13 Mar 202431 Mar 2026
6.xQ1 2025TBD

Release support chart

Protobuf Pythonprotoc23Q123Q223Q323Q424Q124Q224Q324Q425Q125Q225Q325Q4
4.x22.x-25.x4.224.234.244.254.254.254.254.254.25
5.x26.x-29.x5.265.275.285.295.295.295.295.29
6.x30.x+6.306.316.326.33

Legend

ActiveMinor and patch releases with new features, compatible changes and bug fixes.
MaintenancePatch releases with critical bug fixes.
End of lifeRelease is unsupported. Users should upgrade to a supported release.
FutureProjected release. Shown for planning purposes.

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

The protoc version can be inferred from the Protobuf Ruby minor version number. Example: Protobuf Ruby version 3.25.x uses protoc version 25.x.

Future plans are shown in italics and are subject to change.

Release support dates

Protobuf RubyRelease dateEnd of support
3.x16 Feb 202331 Mar 2025
4.x13 Mar 2024TBD

Release support chart

Protobuf Rubyprotoc23Q123Q223Q323Q424Q124Q224Q324Q425Q125Q225Q325Q4
3.x22.x-25.x3.223.233.243.253.253.253.253.253.25
4.x26.x+4.264.274.284.294.304.314.324.33

Legend

ActiveMinor and patch releases with new features, compatible changes and bug fixes.
MaintenancePatch releases with critical bug fixes.
End of lifeRelease is unsupported. Users should upgrade to a supported release.
FutureProjected release. Shown for planning purposes.

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.