This is an automated email from the ASF dual-hosted git repository.
tison pushed a commit to branch master
in repository https://gitbox.apache.org/repos/asf/pulsar.git
The following commit(s) were added to refs/heads/master by this push:
new 13d3e1d39b8 [improve][doc] Add documents for C++ client 3.0.0 or later
(#18574)
13d3e1d39b8 is described below
commit 13d3e1d39b80183f4c70956277668fcdc18cf945
Author: Yunze Xu <[email protected]>
AuthorDate: Thu Nov 24 10:36:04 2022 +0800
[improve][doc] Add documents for C++ client 3.0.0 or later (#18574)
Co-authored-by: tison <[email protected]>
Co-authored-by: momo-jun <[email protected]>
---
site2/docs/client-libraries-cpp.md | 49 +++++++++++++++++++++++++++++++++++++-
1 file changed, 48 insertions(+), 1 deletion(-)
diff --git a/site2/docs/client-libraries-cpp.md
b/site2/docs/client-libraries-cpp.md
index 11ae9383d78..29ae1d53013 100644
--- a/site2/docs/client-libraries-cpp.md
+++ b/site2/docs/client-libraries-cpp.md
@@ -11,6 +11,47 @@ import TabItem from '@theme/TabItem';
You can use a Pulsar C++ client to create producers, consumers, and readers.
For Pulsar features that C++ clients support, see [Client Feature
Matrix](https://docs.google.com/spreadsheets/d/1YHYTkIXR8-Ql103u-IMI18TXLlGStK8uJjDsOOA0T20/edit#gid=1784579914).
For complete examples, refer to [C++ client
examples](https://github.com/apache/pulsar-client-cpp/tree/main/examples).
+## Changes for version 3.0.0 or later
+
+The new version of the Pulsar C++ client starts from 3.0.0 and has been no
longer consistent with Pulsar since 2.10.x. For the latest releases, see the
[Download](/download/) page.
+
+Take the [3.0.0
release](https://archive.apache.org/dist/pulsar/pulsar-client-cpp-3.0.0/) for
example, there are following subdirectories:
+- apk-arm64: the Alpine Linux packages for ARM64 architectures
+- apk-x86_64: the Alpine Linux packages for x64 architectures
+- deb-arm64: the Debian-based Linux packages for ARM64 architectures
+- deb-x86_64: the Debian-based Linux packages for x64 architectures
+- rpm-arm64: the RedHat-based Linux packages for ARM64 architectures
+- rpm-x86_64: the RedHat-based Linux packages for x64 architectures
+
+These Linux packages above all contain the C++ headers installed under
`/usr/include` and the following libraries installed under `/usr/lib`:
+- libpulsar.so: the shared library that links 3rd party dependencies statically
+- libpulsar.a: the static library
+- libpulsarwithdeps.a: the fat static library that includes all 3rd party
dependencies
+
+Here is an example to link these libraries for a C++ source file named
`main.cc`:
+
+```bash
+# Link to libpulsar.so
+g++ -std=c++11 main.cc -lpulsar
+# Link to libpulsarwithdeps.a
+g++ -std=c++11 main.cc /usr/lib/libpulsarwithdeps.a -lpthread -ldl
+# Link to libpulsar.a
+g++ -std=c++11 main.cc /usr/lib/libpulsar.a \
+ -lprotobuf -lcurl -lssl -lcrypto -lz -lzstd -lsnappy -lpthread -ldl
+```
+
+:::caution
+
+Linking to `libpulsar.a` can be difficult for beginners because the 3rd party
dependencies must be compatible. For example, the protobuf version must be
3.20.0 or higher for Pulsar C++ client 3.0.0. It's better to link to
`libpulsarwithdeps.a` instead.
+
+:::
+
+:::danger
+
+Before 3.0.0, there was a `libpulsarnossl.so`, which is removed now.
+
+:::
+
## Installation
Use one of the following methods to install a Pulsar C++ client.
@@ -104,6 +145,12 @@ If you get an error like "libpulsar.so: cannot open shared
object file: No such
:::
+### APK
+
+```bash
+apk add --allow-untrusted ./apache-pulsar-client-*.apk
+```
+
## Connection URLs
To connect to Pulsar using client libraries, you need to specify a [Pulsar
protocol](developing-binary-protocol.md) URL.
@@ -398,4 +445,4 @@ client.subscribe("my-topic", "my-sub", conf, consumer);
## Schema
-To work with [Pulsar schema](schema-overview.md) using C++ clients, see
[Schema - Get started](schema-get-started.md). For specific schema types that
C++ clients support, see
[code](https://github.com/apache/pulsar-client-cpp/blob/main/include/pulsar/Schema.h).
\ No newline at end of file
+To work with [Pulsar schema](schema-overview.md) using C++ clients, see
[Schema - Get started](schema-get-started.md). For specific schema types that
C++ clients support, see
[code](https://github.com/apache/pulsar-client-cpp/blob/main/include/pulsar/Schema.h).