SDK Release Notes
- reference
Release notes for the Couchbase PHP Client.
These pages cover the 4.x versions of the Couchbase PHP SDK.
For download instructions, see the installation page.
PHP SDK 4.4 Releases
We always recommend using the latest version of the SDK — it contains all of the latest security patches and support for new and upcoming features. All patch releases for each dot minor release should be API compatible, and safe to upgrade; any changes to expected behavior are noted in the release notes that follow.
PHP SDK 4.4 is written to version 3.8 of the SDK API specification (and matching the features available in Couchbase 8.0.0 and earlier).
Version 4.4.0 (29 September 2024)
Download Links
| Checksum | ||||
| Source | ||||
| Linux | x86_64 | PHP 8.1 | NTS | |
| Linux | x86_64 | PHP 8.1 | ZTS | |
| Linux | x86_64 | PHP 8.2 | NTS | |
| Linux | x86_64 | PHP 8.2 | ZTS | |
| Linux | x86_64 | PHP 8.3 | NTS | |
| Linux | x86_64 | PHP 8.3 | ZTS | |
| Linux | x86_64 | PHP 8.4 | NTS | |
| Linux | x86_64 | PHP 8.4 | ZTS | |
| Linux | x86_64 (musl) | PHP 8.1 | NTS | |
| Linux | x86_64 (musl) | PHP 8.2 | NTS | |
| Linux | x86_64 (musl) | PHP 8.3 | NTS | |
| Linux | x86_64 (musl) | PHP 8.4 | NTS | |
| MacOS | x86_64 | PHP 8.1 | NTS | |
| MacOS | x86_64 | PHP 8.1 | ZTS | |
| MacOS | x86_64 | PHP 8.2 | NTS | |
| MacOS | x86_64 | PHP 8.2 | ZTS | |
| MacOS | x86_64 | PHP 8.3 | NTS | |
| MacOS | x86_64 | PHP 8.3 | ZTS | |
| MacOS | x86_64 | PHP 8.4 | NTS | |
| MacOS | x86_64 | PHP 8.4 | ZTS | |
| MacOS | arm64 | PHP 8.1 | NTS | |
| MacOS | arm64 | PHP 8.1 | ZTS | |
| MacOS | arm64 | PHP 8.2 | NTS | |
| MacOS | arm64 | PHP 8.2 | ZTS | |
| MacOS | arm64 | PHP 8.3 | NTS | |
| MacOS | arm64 | PHP 8.3 | ZTS | |
| MacOS | arm64 | PHP 8.4 | NTS | |
| MacOS | arm64 | PHP 8.4 | ZTS | |
| Windows | x86_64 | PHP 8.1 | NTS | |
| Windows | x86_64 | PHP 8.1 | ZTS | |
| Windows | x86_64 | PHP 8.2 | NTS | |
| Windows | x86_64 | PHP 8.2 | ZTS | |
| Windows | x86_64 | PHP 8.3 | NTS | |
| Windows | x86_64 | PHP 8.3 | ZTS | |
| Windows | x86_64 | PHP 8.4 | NTS | |
| Windows | x86_64 | PHP 8.4 | ZTS | 
ABI-safe binaries that expose all internal APIs as \Couchbase\Extension_4_4_0,
which allows the loading of different versions of the library at the same time.
The extension file is named couchbase_4_4_0.so (couchbase_4_4_0.dll).
| Linux | x86_64 | PHP 8.1 | NTS | |
| Linux | x86_64 | PHP 8.1 | ZTS | |
| Linux | x86_64 | PHP 8.2 | NTS | |
| Linux | x86_64 | PHP 8.2 | ZTS | |
| Linux | x86_64 | PHP 8.3 | NTS | |
| Linux | x86_64 | PHP 8.3 | ZTS | |
| Linux | x86_64 | PHP 8.4 | NTS | |
| Linux | x86_64 | PHP 8.4 | ZTS | |
| Linux | x86_64 (musl) | PHP 8.1 | NTS | |
| Linux | x86_64 (musl) | PHP 8.2 | NTS | |
| Linux | x86_64 (musl) | PHP 8.3 | NTS | |
| Linux | x86_64 (musl) | PHP 8.4 | NTS | |
| MacOS | x86_64 | PHP 8.1 | NTS | |
| MacOS | x86_64 | PHP 8.1 | ZTS | |
| MacOS | x86_64 | PHP 8.2 | NTS | |
| MacOS | x86_64 | PHP 8.2 | ZTS | |
| MacOS | x86_64 | PHP 8.3 | NTS | |
| MacOS | x86_64 | PHP 8.3 | ZTS | |
| MacOS | x86_64 | PHP 8.4 | NTS | |
| MacOS | x86_64 | PHP 8.4 | ZTS | |
| MacOS | arm64 | PHP 8.1 | NTS | |
| MacOS | arm64 | PHP 8.1 | ZTS | |
| MacOS | arm64 | PHP 8.2 | NTS | |
| MacOS | arm64 | PHP 8.2 | ZTS | |
| MacOS | arm64 | PHP 8.3 | NTS | |
| MacOS | arm64 | PHP 8.3 | ZTS | |
| MacOS | arm64 | PHP 8.4 | NTS | |
| MacOS | arm64 | PHP 8.4 | ZTS | |
| Windows | x86_64 | PHP 8.1 | NTS | |
| Windows | x86_64 | PHP 8.1 | ZTS | |
| Windows | x86_64 | PHP 8.2 | NTS | |
| Windows | x86_64 | PHP 8.2 | ZTS | |
| Windows | x86_64 | PHP 8.3 | NTS | |
| Windows | x86_64 | PHP 8.3 | ZTS | |
| Windows | x86_64 | PHP 8.4 | NTS | |
| Windows | x86_64 | PHP 8.4 | ZTS | 
PHP SDK 4.3 Releases
Version 4.3.0 (12 June 2024)
Download Links
| Checksum | ||||
| Source | ||||
| Linux | x86_64 | PHP 8.1 | NTS | |
| Linux | x86_64 | PHP 8.1 | ZTS | |
| Linux | x86_64 | PHP 8.2 | NTS | |
| Linux | x86_64 | PHP 8.2 | ZTS | |
| Linux | x86_64 | PHP 8.3 | NTS | |
| Linux | x86_64 | PHP 8.3 | ZTS | |
| Linux | x86_64 | PHP 8.4 | NTS | |
| Linux | x86_64 | PHP 8.4 | ZTS | |
| Linux | x86_64 (musl) | PHP 8.1 | NTS | |
| Linux | x86_64 (musl) | PHP 8.2 | NTS | |
| Linux | x86_64 (musl) | PHP 8.3 | NTS | |
| Linux | x86_64 (musl) | PHP 8.4 | NTS | |
| MacOS | x86_64 | PHP 8.1 | NTS | |
| MacOS | x86_64 | PHP 8.1 | ZTS | |
| MacOS | x86_64 | PHP 8.2 | NTS | |
| MacOS | x86_64 | PHP 8.2 | ZTS | |
| MacOS | x86_64 | PHP 8.3 | NTS | |
| MacOS | x86_64 | PHP 8.3 | ZTS | |
| MacOS | x86_64 | PHP 8.4 | NTS | |
| MacOS | x86_64 | PHP 8.4 | ZTS | |
| MacOS | arm64 | PHP 8.1 | NTS | |
| MacOS | arm64 | PHP 8.1 | ZTS | |
| MacOS | arm64 | PHP 8.2 | NTS | |
| MacOS | arm64 | PHP 8.2 | ZTS | |
| MacOS | arm64 | PHP 8.3 | NTS | |
| MacOS | arm64 | PHP 8.3 | ZTS | |
| MacOS | arm64 | PHP 8.4 | NTS | |
| MacOS | arm64 | PHP 8.4 | ZTS | |
| Windows | x86_64 | PHP 8.1 | NTS | |
| Windows | x86_64 | PHP 8.1 | ZTS | |
| Windows | x86_64 | PHP 8.2 | NTS | |
| Windows | x86_64 | PHP 8.2 | ZTS | |
| Windows | x86_64 | PHP 8.3 | NTS | |
| Windows | x86_64 | PHP 8.3 | ZTS | |
| Windows | x86_64 | PHP 8.4 | NTS | |
| Windows | x86_64 | PHP 8.4 | ZTS | 
ABI-safe binaries that expose all internal APIs as \Couchbase\Extension_4_3_0,
which allows the loading of different versions of the library at the same time.
The extension file is named couchbase_4_3_0.so (couchbase_4_3_0.dll).
| Linux | x86_64 | PHP 8.1 | NTS | |
| Linux | x86_64 | PHP 8.1 | ZTS | |
| Linux | x86_64 | PHP 8.2 | NTS | |
| Linux | x86_64 | PHP 8.2 | ZTS | |
| Linux | x86_64 | PHP 8.3 | NTS | |
| Linux | x86_64 | PHP 8.3 | ZTS | |
| Linux | x86_64 | PHP 8.4 | NTS | |
| Linux | x86_64 | PHP 8.4 | ZTS | |
| Linux | x86_64 (musl) | PHP 8.1 | NTS | |
| Linux | x86_64 (musl) | PHP 8.2 | NTS | |
| Linux | x86_64 (musl) | PHP 8.3 | NTS | |
| Linux | x86_64 (musl) | PHP 8.4 | NTS | |
| MacOS | x86_64 | PHP 8.1 | NTS | |
| MacOS | x86_64 | PHP 8.1 | ZTS | |
| MacOS | x86_64 | PHP 8.2 | NTS | |
| MacOS | x86_64 | PHP 8.2 | ZTS | |
| MacOS | x86_64 | PHP 8.3 | NTS | |
| MacOS | x86_64 | PHP 8.3 | ZTS | |
| MacOS | x86_64 | PHP 8.4 | NTS | |
| MacOS | x86_64 | PHP 8.4 | ZTS | |
| MacOS | arm64 | PHP 8.1 | NTS | |
| MacOS | arm64 | PHP 8.1 | ZTS | |
| MacOS | arm64 | PHP 8.2 | NTS | |
| MacOS | arm64 | PHP 8.2 | ZTS | |
| MacOS | arm64 | PHP 8.3 | NTS | |
| MacOS | arm64 | PHP 8.3 | ZTS | |
| MacOS | arm64 | PHP 8.4 | NTS | |
| MacOS | arm64 | PHP 8.4 | ZTS | |
| Windows | x86_64 | PHP 8.1 | NTS | |
| Windows | x86_64 | PHP 8.1 | ZTS | |
| Windows | x86_64 | PHP 8.2 | NTS | |
| Windows | x86_64 | PHP 8.2 | ZTS | |
| Windows | x86_64 | PHP 8.3 | NTS | |
| Windows | x86_64 | PHP 8.3 | ZTS | |
| Windows | x86_64 | PHP 8.4 | NTS | |
| Windows | x86_64 | PHP 8.4 | ZTS | 
PHP SDK 4.2 Releases
Version 4.2.7 (18 March 2025)
Fixes
- 
Updated core to 1.0.6 (#206). Release notes: C++ SDK 1.0.6. 
Download Links
| Checksum | ||||
| Source | ||||
| Linux | x86_64 | PHP 8.1 | NTS | |
| Linux | x86_64 | PHP 8.1 | ZTS | |
| Linux | x86_64 | PHP 8.2 | NTS | |
| Linux | x86_64 | PHP 8.2 | ZTS | |
| Linux | x86_64 | PHP 8.3 | NTS | |
| Linux | x86_64 | PHP 8.3 | ZTS | |
| Linux | x86_64 | PHP 8.4 | NTS | |
| Linux | x86_64 | PHP 8.4 | ZTS | |
| Linux | x86_64 (musl) | PHP 8.1 | NTS | |
| Linux | x86_64 (musl) | PHP 8.2 | NTS | |
| Linux | x86_64 (musl) | PHP 8.3 | NTS | |
| Linux | x86_64 (musl) | PHP 8.4 | NTS | |
| MacOS | x86_64 | PHP 8.1 | NTS | |
| MacOS | x86_64 | PHP 8.1 | ZTS | |
| MacOS | x86_64 | PHP 8.2 | NTS | |
| MacOS | x86_64 | PHP 8.2 | ZTS | |
| MacOS | x86_64 | PHP 8.3 | NTS | |
| MacOS | x86_64 | PHP 8.3 | ZTS | |
| MacOS | x86_64 | PHP 8.4 | NTS | |
| MacOS | x86_64 | PHP 8.4 | ZTS | |
| MacOS | arm64 | PHP 8.1 | NTS | |
| MacOS | arm64 | PHP 8.1 | ZTS | |
| MacOS | arm64 | PHP 8.2 | NTS | |
| MacOS | arm64 | PHP 8.2 | ZTS | |
| MacOS | arm64 | PHP 8.3 | NTS | |
| MacOS | arm64 | PHP 8.3 | ZTS | |
| MacOS | arm64 | PHP 8.4 | NTS | |
| MacOS | arm64 | PHP 8.4 | ZTS | |
| Windows | x86_64 | PHP 8.1 | NTS | |
| Windows | x86_64 | PHP 8.1 | ZTS | |
| Windows | x86_64 | PHP 8.2 | NTS | |
| Windows | x86_64 | PHP 8.2 | ZTS | |
| Windows | x86_64 | PHP 8.3 | NTS | |
| Windows | x86_64 | PHP 8.3 | ZTS | |
| Windows | x86_64 | PHP 8.4 | NTS | |
| Windows | x86_64 | PHP 8.4 | ZTS | 
ABI-safe binaries that expose all internal APIs as \Couchbase\Extension_4_2_7,
which allows the loading of different versions of the library at the same time.
The extension file is named couchbase_4_2_7.so (couchbase_4_2_7.dll).
| Linux | x86_64 | PHP 8.1 | NTS | |
| Linux | x86_64 | PHP 8.1 | ZTS | |
| Linux | x86_64 | PHP 8.2 | NTS | |
| Linux | x86_64 | PHP 8.2 | ZTS | |
| Linux | x86_64 | PHP 8.3 | NTS | |
| Linux | x86_64 | PHP 8.3 | ZTS | |
| Linux | x86_64 | PHP 8.4 | NTS | |
| Linux | x86_64 | PHP 8.4 | ZTS | |
| Linux | x86_64 (musl) | PHP 8.1 | NTS | |
| Linux | x86_64 (musl) | PHP 8.2 | NTS | |
| Linux | x86_64 (musl) | PHP 8.3 | NTS | |
| Linux | x86_64 (musl) | PHP 8.4 | NTS | |
| MacOS | x86_64 | PHP 8.1 | NTS | |
| MacOS | x86_64 | PHP 8.1 | ZTS | |
| MacOS | x86_64 | PHP 8.2 | NTS | |
| MacOS | x86_64 | PHP 8.2 | ZTS | |
| MacOS | x86_64 | PHP 8.3 | NTS | |
| MacOS | x86_64 | PHP 8.3 | ZTS | |
| MacOS | x86_64 | PHP 8.4 | NTS | |
| MacOS | x86_64 | PHP 8.4 | ZTS | |
| MacOS | arm64 | PHP 8.1 | NTS | |
| MacOS | arm64 | PHP 8.1 | ZTS | |
| MacOS | arm64 | PHP 8.2 | NTS | |
| MacOS | arm64 | PHP 8.2 | ZTS | |
| MacOS | arm64 | PHP 8.3 | NTS | |
| MacOS | arm64 | PHP 8.3 | ZTS | |
| MacOS | arm64 | PHP 8.4 | NTS | |
| MacOS | arm64 | PHP 8.4 | ZTS | |
| Windows | x86_64 | PHP 8.1 | NTS | |
| Windows | x86_64 | PHP 8.1 | ZTS | |
| Windows | x86_64 | PHP 8.2 | NTS | |
| Windows | x86_64 | PHP 8.2 | ZTS | |
| Windows | x86_64 | PHP 8.3 | NTS | |
| Windows | x86_64 | PHP 8.3 | ZTS | |
| Windows | x86_64 | PHP 8.4 | NTS | |
| Windows | x86_64 | PHP 8.4 | ZTS | 
Version 4.2.6 (29 January 2025)
Enhancements
- 
PCBC-992: New APIs added to allow getting KV documents from a preferred server group. This feature allows the implementation of network optimization when traffic cost between server groups is higher than in the local group. In this case the application might select preferred server group in the connection options, and later opt-in for local operations during replica reads (#201). 
Fixes
- 
PCBC-1018: In some cases, when the extension was configured aggressively close persistent connections (e.g. with couchbase.max_persistent=0andcouchbase.persistent_timeout=0), the connections might be considered expired and scheduled for destruction even if the application has references to them. This patch changes this behavior to skip such actions and destroy them later, when the reference counter reaches zero (#200).
- 
PCBC-1016: Fixed trustCertificateoption that was ignored previously (#195).
- 
Updated core to 1.0.5 (#203). Release notes: C++ SDK 1.0.5. 
- 
Fixed PHP 8.4 deprecation warnings (#198). 
- 
Fixed Undefined constant error (#196). 
Download Links
| Checksum | ||||
| Source | ||||
| Linux | x86_64 | PHP 8.1 | NTS | |
| Linux | x86_64 | PHP 8.1 | ZTS | |
| Linux | x86_64 | PHP 8.2 | NTS | |
| Linux | x86_64 | PHP 8.2 | ZTS | |
| Linux | x86_64 | PHP 8.3 | NTS | |
| Linux | x86_64 | PHP 8.3 | ZTS | |
| Linux | x86_64 | PHP 8.4 | NTS | |
| Linux | x86_64 | PHP 8.4 | ZTS | |
| Linux | x86_64 (musl) | PHP 8.1 | NTS | |
| Linux | x86_64 (musl) | PHP 8.2 | NTS | |
| Linux | x86_64 (musl) | PHP 8.3 | NTS | |
| Linux | x86_64 (musl) | PHP 8.4 | NTS | |
| MacOS | x86_64 | PHP 8.1 | NTS | |
| MacOS | x86_64 | PHP 8.1 | ZTS | |
| MacOS | x86_64 | PHP 8.2 | NTS | |
| MacOS | x86_64 | PHP 8.2 | ZTS | |
| MacOS | x86_64 | PHP 8.3 | NTS | |
| MacOS | x86_64 | PHP 8.3 | ZTS | |
| MacOS | x86_64 | PHP 8.4 | NTS | |
| MacOS | x86_64 | PHP 8.4 | ZTS | |
| MacOS | arm64 | PHP 8.1 | NTS | |
| MacOS | arm64 | PHP 8.1 | ZTS | |
| MacOS | arm64 | PHP 8.2 | NTS | |
| MacOS | arm64 | PHP 8.2 | ZTS | |
| MacOS | arm64 | PHP 8.3 | NTS | |
| MacOS | arm64 | PHP 8.3 | ZTS | |
| MacOS | arm64 | PHP 8.4 | NTS | |
| MacOS | arm64 | PHP 8.4 | ZTS | |
| Windows | x86_64 | PHP 8.1 | NTS | |
| Windows | x86_64 | PHP 8.1 | ZTS | |
| Windows | x86_64 | PHP 8.2 | NTS | |
| Windows | x86_64 | PHP 8.2 | ZTS | |
| Windows | x86_64 | PHP 8.3 | NTS | |
| Windows | x86_64 | PHP 8.3 | ZTS | |
| Windows | x86_64 | PHP 8.4 | NTS | |
| Windows | x86_64 | PHP 8.4 | ZTS | 
ABI-safe binaries that expose all internal APIs as \Couchbase\Extension_4_2_6,
which allows the loading of different versions of the library at the same time.
The extension file is named couchbase_4_2_6.so (couchbase_4_2_6.dll).
| Linux | x86_64 | PHP 8.1 | NTS | |
| Linux | x86_64 | PHP 8.1 | ZTS | |
| Linux | x86_64 | PHP 8.2 | NTS | |
| Linux | x86_64 | PHP 8.2 | ZTS | |
| Linux | x86_64 | PHP 8.3 | NTS | |
| Linux | x86_64 | PHP 8.3 | ZTS | |
| Linux | x86_64 | PHP 8.4 | NTS | |
| Linux | x86_64 | PHP 8.4 | ZTS | |
| Linux | x86_64 (musl) | PHP 8.1 | NTS | |
| Linux | x86_64 (musl) | PHP 8.2 | NTS | |
| Linux | x86_64 (musl) | PHP 8.3 | NTS | |
| Linux | x86_64 (musl) | PHP 8.4 | NTS | |
| MacOS | x86_64 | PHP 8.1 | NTS | |
| MacOS | x86_64 | PHP 8.1 | ZTS | |
| MacOS | x86_64 | PHP 8.2 | NTS | |
| MacOS | x86_64 | PHP 8.2 | ZTS | |
| MacOS | x86_64 | PHP 8.3 | NTS | |
| MacOS | x86_64 | PHP 8.3 | ZTS | |
| MacOS | x86_64 | PHP 8.4 | NTS | |
| MacOS | x86_64 | PHP 8.4 | ZTS | |
| MacOS | arm64 | PHP 8.1 | NTS | |
| MacOS | arm64 | PHP 8.1 | ZTS | |
| MacOS | arm64 | PHP 8.2 | NTS | |
| MacOS | arm64 | PHP 8.2 | ZTS | |
| MacOS | arm64 | PHP 8.3 | NTS | |
| MacOS | arm64 | PHP 8.3 | ZTS | |
| MacOS | arm64 | PHP 8.4 | NTS | |
| MacOS | arm64 | PHP 8.4 | ZTS | |
| Windows | x86_64 | PHP 8.1 | NTS | |
| Windows | x86_64 | PHP 8.1 | ZTS | |
| Windows | x86_64 | PHP 8.2 | NTS | |
| Windows | x86_64 | PHP 8.2 | ZTS | |
| Windows | x86_64 | PHP 8.3 | NTS | |
| Windows | x86_64 | PHP 8.3 | ZTS | |
| Windows | x86_64 | PHP 8.4 | NTS | |
| Windows | x86_64 | PHP 8.4 | ZTS | 
Version 4.2.5 (22 November 2024)
Enhancements
- 
Core updated to 1.0.4. Release notes: C++ SDK 1.0.4. 
- 
PCBC-1004: Insert ABI version tag into PHP extension namespace (#187). At this moment this feature is optional and does not break existing ABI. The extension namespace will become versioned by default from 4.3.0. Prebuild binaries with -abisuffix have version tag in the extension name, and in the namespaces of the visible API, as is shown with the following demo:$ wget \ https://packages.couchbase.com/clients/php/couchbase-4.2.5-php8.3-nts-linux-x86_64.tgz \ https://packages.couchbase.com/clients/php/couchbase-4.2.5-php8.3-nts-linux-x86_64-abi.tgz $ for t in *.tgz; do tar zxf $t; done $ php \ -d extension=$(realpath couchbase-4.2.5-php8.3-nts-linux-x86_64-abi/couchbase_4_2_5.so) \ -d extension=$(realpath couchbase-4.2.5-php8.3-nts-linux-x86_64/couchbase.so) \ -i \ | grep couchbase couchbase couchbase => enabled couchbase_extension_abi => unspecified couchbase_extension_version => 4.2.5 couchbase_extension_revision => c9704a8aa5ca50475c5fe8ee64166fa164cbd43e couchbase_client_revision => 5355b0fdc221d87f0d6adbbf7e7f8826d819ea22 couchbase_4_2_5 couchbase => enabled couchbase_extension_abi => 4_2_5 couchbase_extension_version => 4.2.5 couchbase_extension_revision => c9704a8aa5ca50475c5fe8ee64166fa164cbd43e couchbase_client_revision => 5355b0fdc221d87f0d6adbbf7e7f8826d819ea22 ... $ php \ -d extension=$(realpath couchbase-4.2.5-php8.3-nts-linux-x86_64-abi/couchbase_4_2_5.so) \ --re couchbase_4_2_5 \ | grep createConnection Function [ <internal:couchbase_4_2_5> function Couchbase\Extension_4_2_5\createConnection ] { $ php \ -d extension=$(realpath couchbase-4.2.5-php8.3-nts-linux-x86_64/couchbase.so) \ --re couchbase \ | grep createConnection Function [ <internal:couchbase> function Couchbase\Extension\createConnection ] {
Download Links
| Checksum | ||||
| Source | ||||
| Linux | x86_64 | PHP 8.1 | NTS | |
| Linux | x86_64 | PHP 8.1 | ZTS | |
| Linux | x86_64 | PHP 8.2 | NTS | |
| Linux | x86_64 | PHP 8.2 | ZTS | |
| Linux | x86_64 | PHP 8.3 | NTS | |
| Linux | x86_64 | PHP 8.3 | ZTS | |
| Linux | x86_64 | PHP 8.4 | NTS | |
| Linux | x86_64 | PHP 8.4 | ZTS | |
| Linux | x86_64 (musl) | PHP 8.1 | NTS | |
| Linux | x86_64 (musl) | PHP 8.2 | NTS | |
| Linux | x86_64 (musl) | PHP 8.3 | NTS | |
| MacOS | x86_64 | PHP 8.1 | NTS | |
| MacOS | x86_64 | PHP 8.1 | ZTS | |
| MacOS | x86_64 | PHP 8.2 | NTS | |
| MacOS | x86_64 | PHP 8.2 | ZTS | |
| MacOS | x86_64 | PHP 8.3 | NTS | |
| MacOS | x86_64 | PHP 8.3 | ZTS | |
| MacOS | x86_64 | PHP 8.4 | NTS | |
| MacOS | x86_64 | PHP 8.4 | ZTS | |
| MacOS | arm64 | PHP 8.1 | NTS | |
| MacOS | arm64 | PHP 8.1 | ZTS | |
| MacOS | arm64 | PHP 8.2 | NTS | |
| MacOS | arm64 | PHP 8.2 | ZTS | |
| MacOS | arm64 | PHP 8.3 | NTS | |
| MacOS | arm64 | PHP 8.3 | ZTS | |
| MacOS | arm64 | PHP 8.4 | NTS | |
| MacOS | arm64 | PHP 8.4 | ZTS | |
| Windows | x86_64 | PHP 8.1 | NTS | |
| Windows | x86_64 | PHP 8.1 | ZTS | |
| Windows | x86_64 | PHP 8.2 | NTS | |
| Windows | x86_64 | PHP 8.2 | ZTS | |
| Windows | x86_64 | PHP 8.3 | NTS | |
| Windows | x86_64 | PHP 8.3 | ZTS | |
| Windows | x86_64 | PHP 8.4 | NTS | |
| Windows | x86_64 | PHP 8.4 | ZTS | 
As noted above, from this release we also publish ABI-safe binaries that expose all internal APIs as \Couchbase\Extension_4_2_5,
which allows the loading of different versions of the library at the same time.
The extension file is also renamed to couchbase_4_2_5.so
(couchbase_4_2_5.dll).
| Linux | x86_64 | PHP 8.1 | NTS | |
| Linux | x86_64 | PHP 8.1 | ZTS | |
| Linux | x86_64 | PHP 8.2 | NTS | |
| Linux | x86_64 | PHP 8.2 | ZTS | |
| Linux | x86_64 | PHP 8.3 | NTS | |
| Linux | x86_64 | PHP 8.3 | ZTS | |
| Linux | x86_64 | PHP 8.4 | NTS | |
| Linux | x86_64 | PHP 8.4 | ZTS | |
| Linux | x86_64 (musl) | PHP 8.1 | NTS | |
| Linux | x86_64 (musl) | PHP 8.2 | NTS | |
| Linux | x86_64 (musl) | PHP 8.3 | NTS | |
| MacOS | x86_64 | PHP 8.1 | NTS | |
| MacOS | x86_64 | PHP 8.1 | ZTS | |
| MacOS | x86_64 | PHP 8.2 | NTS | |
| MacOS | x86_64 | PHP 8.2 | ZTS | |
| MacOS | x86_64 | PHP 8.3 | NTS | |
| MacOS | x86_64 | PHP 8.3 | ZTS | |
| MacOS | x86_64 | PHP 8.4 | NTS | |
| MacOS | x86_64 | PHP 8.4 | ZTS | |
| MacOS | arm64 | PHP 8.1 | NTS | |
| MacOS | arm64 | PHP 8.1 | ZTS | |
| MacOS | arm64 | PHP 8.2 | NTS | |
| MacOS | arm64 | PHP 8.2 | ZTS | |
| MacOS | arm64 | PHP 8.3 | NTS | |
| MacOS | arm64 | PHP 8.3 | ZTS | |
| MacOS | arm64 | PHP 8.4 | NTS | |
| MacOS | arm64 | PHP 8.4 | ZTS | |
| Windows | x86_64 | PHP 8.1 | NTS | |
| Windows | x86_64 | PHP 8.1 | ZTS | |
| Windows | x86_64 | PHP 8.2 | NTS | |
| Windows | x86_64 | PHP 8.2 | ZTS | |
| Windows | x86_64 | PHP 8.3 | NTS | |
| Windows | x86_64 | PHP 8.3 | ZTS | |
| Windows | x86_64 | PHP 8.4 | NTS | |
| Windows | x86_64 | PHP 8.4 | ZTS | 
Version 4.2.4 (22 October 2024)
Enhancements
- 
PCBC-832: Management API - Analytics Management (#177). 
- 
Core updated to 1.0.3. Release notes: C++ SDK 1.0.3. 
Fixes
- 
PCBC-1009: IS_RESOURCEhas been removed from function signatures of the extension, so that they compile with 8.4.
- 
PCBC-1010: implicit marking of certain parameters as nullable has now been deprecated. Use explicit nullable types where applicable to avoid deprecation warning in PHP 8.4. 
- 
Fixed SearchQueryAPI docs link in API reference.
Download Links
| Checksum | ||||
| Source | ||||
| Linux | x86_64 | PHP 8.1 | NTS | |
| Linux | x86_64 | PHP 8.1 | ZTS | |
| Linux | x86_64 | PHP 8.2 | NTS | |
| Linux | x86_64 | PHP 8.2 | ZTS | |
| Linux | x86_64 | PHP 8.3 | NTS | |
| Linux | x86_64 | PHP 8.3 | ZTS | |
| Linux | x86_64 (musl) | PHP 8.1 | NTS | |
| Linux | x86_64 (musl) | PHP 8.2 | NTS | |
| Linux | x86_64 (musl) | PHP 8.3 | NTS | |
| MacOS | x86_64 | PHP 8.1 | NTS | |
| MacOS | x86_64 | PHP 8.1 | ZTS | |
| MacOS | x86_64 | PHP 8.2 | NTS | |
| MacOS | x86_64 | PHP 8.2 | ZTS | |
| MacOS | x86_64 | PHP 8.3 | NTS | |
| MacOS | x86_64 | PHP 8.3 | ZTS | |
| MacOS | arm64 | PHP 8.1 | NTS | |
| MacOS | arm64 | PHP 8.1 | ZTS | |
| MacOS | arm64 | PHP 8.2 | NTS | |
| MacOS | arm64 | PHP 8.2 | ZTS | |
| MacOS | arm64 | PHP 8.3 | NTS | |
| MacOS | arm64 | PHP 8.3 | ZTS | |
| Windows | x86_64 | PHP 8.1 | NTS | |
| Windows | x86_64 | PHP 8.1 | ZTS | |
| Windows | x86_64 | PHP 8.2 | NTS | |
| Windows | x86_64 | PHP 8.2 | ZTS | |
| Windows | x86_64 | PHP 8.3 | NTS | |
| Windows | x86_64 | PHP 8.3 | ZTS | 
Version 4.2.3 (27 August 2024)
Enhancements
- 
Core updated to 1.0.1. Release notes: C++ SDK 1.0.1. 
Download Links
| Checksum | ||||
| Source | ||||
| Linux | x86_64 | PHP 8.1 | NTS | |
| Linux | x86_64 | PHP 8.1 | ZTS | |
| Linux | x86_64 | PHP 8.2 | NTS | |
| Linux | x86_64 | PHP 8.2 | ZTS | |
| Linux | x86_64 | PHP 8.3 | NTS | |
| Linux | x86_64 | PHP 8.3 | ZTS | |
| Linux | x86_64 (musl) | PHP 8.1 | NTS | |
| Linux | x86_64 (musl) | PHP 8.2 | NTS | |
| Linux | x86_64 (musl) | PHP 8.3 | NTS | |
| MacOS | x86_64 | PHP 8.1 | NTS | |
| MacOS | x86_64 | PHP 8.1 | ZTS | |
| MacOS | x86_64 | PHP 8.2 | NTS | |
| MacOS | x86_64 | PHP 8.2 | ZTS | |
| MacOS | x86_64 | PHP 8.3 | NTS | |
| MacOS | x86_64 | PHP 8.3 | ZTS | |
| MacOS | arm64 | PHP 8.1 | NTS | |
| MacOS | arm64 | PHP 8.1 | ZTS | |
| MacOS | arm64 | PHP 8.2 | NTS | |
| MacOS | arm64 | PHP 8.2 | ZTS | |
| MacOS | arm64 | PHP 8.3 | NTS | |
| MacOS | arm64 | PHP 8.3 | ZTS | |
| Windows | x86_64 | PHP 8.1 | NTS | |
| Windows | x86_64 | PHP 8.1 | ZTS | |
| Windows | x86_64 | PHP 8.2 | NTS | |
| Windows | x86_64 | PHP 8.2 | ZTS | |
| Windows | x86_64 | PHP 8.3 | NTS | |
| Windows | x86_64 | PHP 8.3 | ZTS | 
Version 4.2.2 (24 July 2024)
Fixes
Enhancements
- 
PCBC-994: Support for base64 encoded vector types added (#169, #170). 
- 
Core updated to 1.0.0. Release notes: C++ SDK 1.0.0 
Download Links
| Checksum | ||||
| Source | ||||
| Linux | x86_64 | PHP 8.1 | NTS | |
| Linux | x86_64 | PHP 8.1 | ZTS | |
| Linux | x86_64 | PHP 8.2 | NTS | |
| Linux | x86_64 | PHP 8.2 | ZTS | |
| Linux | x86_64 | PHP 8.3 | NTS | |
| Linux | x86_64 | PHP 8.3 | ZTS | |
| Linux | x86_64 (musl) | PHP 8.1 | NTS | |
| Linux | x86_64 (musl) | PHP 8.2 | NTS | |
| Linux | x86_64 (musl) | PHP 8.3 | NTS | |
| MacOS | x86_64 | PHP 8.1 | NTS | |
| MacOS | x86_64 | PHP 8.1 | ZTS | |
| MacOS | x86_64 | PHP 8.2 | NTS | |
| MacOS | x86_64 | PHP 8.2 | ZTS | |
| MacOS | x86_64 | PHP 8.3 | NTS | |
| MacOS | x86_64 | PHP 8.3 | ZTS | |
| MacOS | arm64 | PHP 8.1 | NTS | |
| MacOS | arm64 | PHP 8.1 | ZTS | |
| MacOS | arm64 | PHP 8.2 | NTS | |
| MacOS | arm64 | PHP 8.2 | ZTS | |
| MacOS | arm64 | PHP 8.3 | NTS | |
| MacOS | arm64 | PHP 8.3 | ZTS | |
| Windows | x86_64 | PHP 8.1 | NTS | |
| Windows | x86_64 | PHP 8.1 | ZTS | |
| Windows | x86_64 | PHP 8.2 | NTS | |
| Windows | x86_64 | PHP 8.2 | ZTS | |
| Windows | x86_64 | PHP 8.3 | NTS | |
| Windows | x86_64 | PHP 8.3 | ZTS | 
>>>>>>> ddeee36208e40a12e338c5eaba15ffad262cf27e
Version 4.2.1 (23 April 2024)
Notable changes in core C++
Enhancements
- 
CXXCBC-489: Added support for scoped eventing functions (#548, #554). 
- 
CXXCBC-470: Distinguish between 'unset' and 'off' query_profile(#551).
Fixes
- 
CXXCBC-487: Added logic during bootstrap to check if alternate addressing is being used (#545). 
- 
CXXCBC-503: Added logic to ignore configuration if it contains an empty vBucket map (#556, #558). 
- 
CXXCBC-30: Fixed inconsistent behaviour when using subdoc opcodes incorrectly (#559). 
- 
CXXCBC-492: Updated collection_component get_collection_id to use retry strategy (#552). 
- 
CXXCBC-494: Fixed memory issue in range scan implementation (#549). 
- 
Always attempt to extract common query code if error has not been set (#561). This fixes quota/rate limit checks for older servers. 
Build and Tests Fixes
- 
CXXCBC-502: Apply /bigobjfor SDK objects only (#550). Avoid using globaladd_definitions()as it might leak to non-C++ languages (likeASM_NASMon Windows).
- 
Add feature check for scoped analyze_document in tests (#555) 
Download Links
| Checksum | ||||
| Source | ||||
| Linux | x86_64 | PHP 8.1 | NTS | |
| Linux | x86_64 | PHP 8.1 | ZTS | |
| Linux | x86_64 | PHP 8.2 | NTS | |
| Linux | x86_64 | PHP 8.2 | ZTS | |
| Linux | x86_64 | PHP 8.3 | NTS | |
| Linux | x86_64 | PHP 8.3 | ZTS | |
| Linux | x86_64 (musl) | PHP 8.1 | NTS | |
| Linux | x86_64 (musl) | PHP 8.2 | NTS | |
| Linux | x86_64 (musl) | PHP 8.3 | NTS | |
| MacOS | x86_64 | PHP 8.1 | NTS | |
| MacOS | x86_64 | PHP 8.1 | ZTS | |
| MacOS | x86_64 | PHP 8.2 | NTS | |
| MacOS | x86_64 | PHP 8.2 | ZTS | |
| MacOS | x86_64 | PHP 8.3 | NTS | |
| MacOS | x86_64 | PHP 8.3 | ZTS | |
| MacOS | arm64 | PHP 8.1 | NTS | |
| MacOS | arm64 | PHP 8.1 | ZTS | |
| MacOS | arm64 | PHP 8.2 | NTS | |
| MacOS | arm64 | PHP 8.2 | ZTS | |
| MacOS | arm64 | PHP 8.3 | NTS | |
| MacOS | arm64 | PHP 8.3 | ZTS | |
| Windows | x86_64 | PHP 8.1 | NTS | |
| Windows | x86_64 | PHP 8.1 | ZTS | |
| Windows | x86_64 | PHP 8.2 | NTS | |
| Windows | x86_64 | PHP 8.2 | ZTS | |
| Windows | x86_64 | PHP 8.3 | NTS | |
| Windows | x86_64 | PHP 8.3 | ZTS | 
Version 4.2.0 (17 March 2024)
Known Issues
- 
CXXCBC-447: This version of the SDK will not be able to connect to a cluster utilizing alternate addressing. The recommendation is to wait to upgrade to a version of the PHP SDK that contains C++ 1.0.0-dp.15 (or later). 
Enhancements
- 
PCBC-970: SDK support added for Scoped Search Indexes (#147). 
- 
PCBC-968: Support addd for maxTTLvalue of -1 for collection 'no expiry' (#144).
- 
PCBC-965: Adedd DocumentNotLockederror to corresponds with the C++ error codecouchbase::errc::key_value::document_not_locked(#142).
- 
PCBC-960: Merge protostellar branch to master, in preparation for couchbase2protocol (#138, #153).
Fixes
- 
PCBC-964: The SDK no longer fires the close operation asynchronously, instead it will now wait until the core instance is completely destroyed Wait until the core connection is closed (#141). 
- 
PCBC-972: Fixed C++ detection on MacOS X, so that the SDK now installs correctly on Sonoma (#145). 
- 
Added missing usestatement in classDecrementOptions(#146).
- 
Updated core and renamed query_index_createfields to keys (#148).
Notable changes in core C++
Since 1.0.0-dp.14
- 
CXXCBC-482: Updated range scan orchestrator to use best effort retry strategy by default (#542). 
- 
CXXCBC-481: Fixed potential crash when parsing search result hits (#541). 
- 
CXXCBC-461: Updated ping operation to not send to nodes that have not completed bootstrap (#540). 
- 
CXXCBC-480: Fixed capabilities check for replica LookupIn operations (#539). 
- 
CXXCBC-479: Fixed capabilities check for replica LookupInoperations (#537).
- 
CXXCBC-336: Updated DNS config to not fallback to 8.8.8.8 if SDK cannot obtain system DNS server (#533). 
Since 1.0.0-dp.13
- 
CXXCBC-456: Updated configuration logic when 0x0d ( EConfigOnly) status code is received to have the SDK request new configuration and send current operation to retry orchestrator (#523).
- 
CXXCBC-191: Index Key Encoding (#519) — in line with the rfc, the fieldsparamaeter is now remamed to keys in the Public API’screate_index(), and each index key provided tocreate_index()is encoded by surrounding them with backticks.
- 
Added full_setoption to view query options (#517).
- 
CXXCBC-345: Added range scan improvements and resolved concurrency issues (#525). 
- 
CXXCBC-284: Updated config polling to not use session that is not bootstrapped (#528). 
- 
CXXCBC-447: Updated bootstrap logic to use addresses from the config to bootstrap bucket (#516). 
- 
CXXCBC-450: Updated bootstrap logic to reset bootstrap handler before re-bootstrap (#524). - 
We do not want any actions from the old bootstrap handler once the session decided to re-bootstrap. For example, bucket could not be selected, but we might still get configuration responses before socket reset. 
 
- 
- 
CXXCBC-452: Updated capabilities and fail fast when selected feature is not available (#522, #513). 
- 
CXXCBC-431: Added check for history retention bucket capability in collection create/update (#502, #505). 
- 
CXXCBC-421: Updated query operation to return feature_not_availableif query preserve expiry is specified but is not supported on the server(#510).
Since 1.0.0-dp.12
- 
CXXCBC-346: Support added for maxTTLvalue of -1 for collection 'no expiry' (#500).
- 
CXXCBC-442: Transcoder support - which was previously limited in the SDK to JSONandRawBinarytranscoders — has now been extended toraw_jsonandraw_stringtranscoders (#514, #515).
- 
CXXCBC-440: Support added for Scoped Search Indexes (#512, #513). 
- 
CXXCBC-284: Updated config polling to not use session that is not bootstrapped, to reduce network traffic when polling for cluster configuration (#504, #528). 
- 
CXXCBC-422: Added insufficient credentials error code to common query error code conversion (#511). 
- 
CXXCBC-421: Updated query operation to return feature_not_availableif query preserve expiry is specified but is not supported on the server(#510).
- 
CXXCBC-426: Under testing, a get with very large projection was returning fields outside of the projection. This has been fixed, with the projections now set correctly, and the SDK should fall back to a full-doc fetch and return a valid projected result (#499). 
Since 1.0.0-dp.11
- 
CXXCBC-404: Fixed unlockoperations to exposeKV_LOCKEDstatus ascas_mismatch(#479).
- 
CXXCBC-403: Updated not_my_vbucketKV response to allow retries (#480).
- 
CXXCBC-368: Added support for subscribing to clustermap notifications to speed up failover (#490). 
- 
CXXCBC-419: Updated MCBP protocol parser to start with clean state. Fixes protocol parsing issues when bootstrap sequence is being retried (#496). 
- 
CXXCBC-409: Added handling for index does not existquery error (#492).
- 
CXXCBC-391: Fixed transactions API inconsistencies (#482): 
- 
Removed kv_timeout,
- 
Renamed expiration_timetotimeout.
New features and enhancements
- 
CXXCBC-100: Added ability to set timeout for ping (#486). 
- 
CXXCBC-412: Added support for the document_not_locked(0x0e) KV status, mapping it to theerrc::key_value::document_not_lockederror code (#491).
Since 1.0.0-dp.10
- 
CXXCBC-383: The subdoc_doc_too_deep(0xc4) KV status now returns a`path_too_deep` error code (#455).
- 
CXXCBC-377: Implemented ExtParallelUnstagingin transactions (#457).
- 
CXXCBC-363: Added examples for bulk operations (#442). 
- 
Added more information to diagnose timeouts on NMV responses (#475). 
Download Links
| Checksum | ||||
| Source | ||||
| Linux | x86_64 | PHP 8.1 | NTS | |
| Linux | x86_64 | PHP 8.1 | ZTS | |
| Linux | x86_64 | PHP 8.2 | NTS | |
| Linux | x86_64 | PHP 8.2 | ZTS | |
| Linux | x86_64 | PHP 8.3 | NTS | |
| Linux | x86_64 | PHP 8.3 | ZTS | |
| Linux | x86_64 (musl) | PHP 8.1 | NTS | |
| Linux | x86_64 (musl) | PHP 8.2 | NTS | |
| Linux | x86_64 (musl) | PHP 8.3 | NTS | |
| MacOS | x86_64 | PHP 8.1 | NTS | |
| MacOS | x86_64 | PHP 8.1 | ZTS | |
| MacOS | x86_64 | PHP 8.2 | NTS | |
| MacOS | x86_64 | PHP 8.2 | ZTS | |
| MacOS | x86_64 | PHP 8.3 | NTS | |
| MacOS | x86_64 | PHP 8.3 | ZTS | |
| MacOS | arm64 | PHP 8.1 | NTS | |
| MacOS | arm64 | PHP 8.1 | ZTS | |
| MacOS | arm64 | PHP 8.2 | NTS | |
| MacOS | arm64 | PHP 8.2 | ZTS | |
| MacOS | arm64 | PHP 8.3 | NTS | |
| MacOS | arm64 | PHP 8.3 | ZTS | 
PHP SDK 4.1 Releases
Version 4.1.6 (10 October 2023)
| Source | |
| Checksum | 
Enhancements
- 
PCBC-956: Updated wrapper-side bucket settings — to now use new BucketSettingsoptional fields in underlying C++ core (#132).
- 
PCBC-950: Added support to bucket settings for no dedup feature (#131). 
- 
PCBC-955: Preventing trailing garbage in encoded CAS value (#134). 
- 
Updates to support PHP 8.3: zend_boolwas removed from 8.3.
Underlying C++ SDK Core Changes
- 
CXXCBC-376: Changed what 'create' and 'update' bucket operations send to the server. Unrequired BucketSettingsfields are now set to optional, and are not sent unless the settings are explicitly specified. (#451).
- 
CXXCBC-374: The SDK should now return a 'bucket_exists' error when the bucket already exists during a 'create' operation. (#449). 
- 
CXXCBC-359: Reduced the default timeout for idle HTTP connections to 1 second. The previous default (4.5 seconds) was too close to the 5-second server-side timeout, and could lead to spurious request failures. (#448). 
- 
CXXCBC-367, CXXCBC-370: Added history retention settings to buckets/collection management (#446). 
- 
CXXCBC-119: Return booleans for subdocument 'exists' operation, instead of error code (#444, #452). 
- 
Detect collection_not_founderror inupdate_collectionresponse (#450).
Version 4.1.5 (21 August 2023)
| Source | |
| Checksum | 
Enhancements
- 
PCBC-939: Added support for query with Read from Replica (#118). 
- 
PCBC-945: Expiry options for increment/decrement are now exposed, as they were before 4.0.0 (#120). 
- 
PCBC-937: Fixed removeMulti, which now correctly removes documents (#123).
- 
PCBC-938: Override exception constructor in PHP Extension, which allows to initialize context in derived classes (#117). 
- 
PCBC-940: Added support for subdoc Read from Replica (#121). 
- 
PCBC-884: Added support for Native KV range scans (#122, #127). 
Underlying C++ SDK Core
- 
CXXCBC-333: Fixed parsing 'resolv.conf' on Linux (#416). - 
The library might not ignore trailing characters when reading nameserver address from the file. 
 
- 
- 
CXXCBC-335: now logging connection options for visibility (#417). 
- 
CXXCBC-343: Continue bootsrap if DNS-SRV resolution fails (#422). 
- 
CXXCBC-242: SDK Support for Native KV Range Scans (#419, #423, #424, #426, #428, #431, #432, #433, #434). 
- 
CXXCBC-339: Disable older TLS protocols (#418). 
Version 4.1.4 (26 May 2023)
API documentation: https://docs.couchbase.com/sdk-api/couchbase-php-client-4.1.4
| Source | |
| Checksum | 
Underlying C++ SDK Core
- 
CXXCBC-327: Bundled Mozilla certificates with the library (#405, #408). Source: https://curl.se/docs/caextract.html. Use the disable_mozilla_ca_certificatesconnection string option to disable the bundled certificates.
- 
CXXCBC-324: Port and network name now checked on session restart, improving performance during rebalance (#401). 
- 
CXXCBC-323: bootstrap_timeoutandresolve_timeoutcan now be used in the connection string (#400).
- 
Introduced dump_configurationoption for debugging. (#398) It logs cluster configuration at trace level.
Version 4.1.3 (13 April 2023)
API documentation: https://docs.couchbase.com/sdk-api/couchbase-php-client-4.1.3
| Source | |
| Checksum | 
Underlying C++ SDK Core
- 
CXXCBC-31: Allow the use of schemaless connection strings (e.g. "cb1.example.com,cb2.example.com") (#394).
- 
CXXCBC-318: Always try TCP if UDP fails in DNS-SRV resolver (#390). 
- 
CXXCBC-320: Negative expiry in atr was leaving docs in a stuck state — this has been fixed, with expiry atr now becoming an int32_t(#393).
- 
CXXCBC-310: Improved shutdown of the LostTxnCleanupthread (#389).
Version 4.1.2 (20 March 2023)
API documentation: https://docs.couchbase.com/sdk-api/couchbase-php-client-4.1.2
| Source | |
| Checksum | 
Underlying C++ SDK Core
- 
CXXCBC-144: Search query on collections no longer requires you to pass in the scope name — it is inferred from the index (#379). 
- 
CXXCBC-145: Search query request, raw option added (#380). 
- 
CXXCBC-194: The SDK now supports the ExtThreadSafetransaction extension (#374, #376).
- 
CXXCBC-316: When a document is removed in a transaction, and then a call made to get_optional, we expect to just get an empty optional. However, the handling was raising atransaction_operation_failedThis has been fixed, and anempty optionalwill now be returned (#385).
- 
CXXCBC-310: Fixed race condition in transaction_context state machine (#386, #378). 
Version 4.1.1 (22 February 2023)
API documentation: https://docs.couchbase.com/sdk-api/couchbase-php-client-4.1.1
| Source | |
| Checksum | 
Fixes
Notable Changes in C++ SDK 1.0.0-dp.4
- 
CXXCBC-275: Update implementation query context fields passed to the server. In future versions of the server versions it will become mandatory to specify context of the statement (bucket, scope and collection). This change ensures that both future and current server releases supported transparently. 
- 
CXXCBC-296: Force PLAIN SASL auth if TLS enabled. Using SCRAM SASL mechanisms over TLS protocol is unnecesary complication, that slows down initial connection bootstrap and potentially limits server ability to improve security and evolve credentials management. 
- 
CXXCBC-295: The get with projectionsopration should not fail if one of the the paths is missing in the document, because the semantics is "get the partial document" and not "get individual fields" like inlookup_inoperation.
- 
CXXCBC-294: In the Public API, if getoperation requested to return expiry time, zero expiry should not be interpreted as absolute expiry timestamp (zero seconds from UNIX epoch), but rather as absense of the expiry.
- 
CXXCBC-291: Allow to disable mutation tokens for Key/Value mutations (use enable_mutation_tokensin connection string).
- 
Resource management and performance improvements: - 
Fix tracer and meter ref-counting (#370) 
- 
Replace minstd_randwithmt19937_64, as it gives less collisions (#356)
- 
CXXCBC-285: Write to sockets from IO threads, to eliminate potential race conditions. (#348) 
- 
Eliminate looping transform in mcbp_parser::next(#347)
- 
CXXCBC-205: Use thread-local UUID generator (#340) 
- 
CXXCBC-293: Performance improvements: 
 
- 
- 
Build system fixes: 
- 
Enhancements: 
Version 4.1.0 (20 January 2023)
Version 4.1.0 brings a number of improvements related to internal connection behavior.
API documentation: https://docs.couchbase.com/sdk-api/couchbase-php-client-4.1.0
| Source | |
| Checksum | 
Fixes
- 
PCBC-889: Fixed behaviour of 'skip' SearchOption. 
- 
Bug fixes: logger and build improvements 
Caveats
There are no pre-built binaries for the Windows platform of PHP SDK 4.1.0. But there are steps in WINDOWS.md, that describe how to build an extension along with PHP interpreter.
PHP SDK 4.0 Releases
PHP SDK 4.0 is written to version 3.3 of the SDK API specification (and matching the features available in Couchbase 7.1 and earlier).
Version 4.0.0 (11 May 2022)
Version 4.0.0 is the first major release of the next generation PHP SDK, built on the Couchbase++ library — featuring multi-document distributed ACID transactions, and bringing a number of improvements related to internal connection behavior.
API documentation: https://docs.couchbase.com/sdk-api/couchbase-php-client-4.0.0
| Source | |
| Checksum | 
Caveats
There are no pre-built binaries for the Windows platform of PHP SDK 4.0.0. But there are steps in WINDOWS.md, that describe how to build an extension along with PHP interpreter.
Older Releases
See:
- 
Although no longer supported, documentation for older releases continues to be available in our docs archive.