首頁 >後端開發 >C++ >宣布 Couchbase 的 C++ SDK 全面上市

宣布 Couchbase 的 C++ SDK 全面上市

王林
王林原創
2024-07-19 16:37:42727瀏覽

Announcing General Availability of the C++ SDK for Couchbase

我們很高興地宣布 Couchbase 的 C++ SDK 全面可用 (GA)!此版本在我們現有的11 種程式語言的綜合SDK 庫中增加了對本機C++ 語言的支持,標誌著我們致力於為開發人員提供強大、高性能的工具來構建現代、可擴展的應用程序的承諾的一個重要里程碑。事實上,這個 C++ SDK 是我們現有的 Python、NodeJS、Ruby 和 PHP SDK 背後的核心函式庫,並致力於在所有這些程式語言中提供一致、高效能和高效的體驗。

為什麼選擇 C++ SDK?

由於其效能、效率和對系統資源的控制,C++ 對許多開發人員來說仍然是一種至關重要的語言。透過引入 C++ SDK,Couchbase 使開發人員能夠利用這些優勢,同時充分利用 Couchbase 的高階 NoSQL 功能。以下是這個版本改變遊戲規則的一些關鍵原因:

表現

C++ 以其速度和低階記憶體管理而聞名,這使其成為效能至關重要的應用程式的理想選擇。 Couchbase 的 C++ SDK 確保您可以建立高效能應用程序,而無需犧牲速度或效率。

無縫集成

C++ SDK 提供與 Couchbase Server 的無縫集成,使開發者能夠輕鬆執行 KV 操作、SQL++ 查詢和事務等操作。這種緊密整合確保您的應用程式可以有效擴展,同時保持高效能。

現代 API 設計

C++ SDK 具有符合最新 C++ 標準的現代、慣用的 API。這使得它不僅功能強大,而且對於 C++ 開發人員來說也很直觀,減少了學習曲線,讓您可以快速開始建立應用程式。

主要特點

以下是 Couchbase 的 C++ SDK 的一些突出功能:

輕鬆連接管理

C++ SDK 簡化了連線管理,讓您可以輕鬆建立和管理與 Couchbase 叢集的連線。這包括處理連接池、負載平衡和故障轉移,確保您的應用程式保持彈性和效能。這意味著 SDK 可以自動讀取叢集的拓撲,並在拓撲變更(例如叢集大小調整或叢集升級)期間提供無縫連接。下面是連接到 couchbase 資料庫的 C++ 程式碼範例。

// Attempt to connect to the Couchbase cluster
auto [connect_err, cluster] = couchbase::cluster::connect(config.connection_string, options).get();

if (connect_err) {
    // Output the error message if connection fails
    std::cout << "Unable to connect to the cluster. Error code: " << connect_err.message() << "\n";
} else {
    auto collection = cluster.bucket(config.bucket_name)
                             .scope(config.scope_name)
                             .collection(config.collection_name);

    // d something interesting

    cluster.close().get();
}

鍵值(KV)操作支持

C++ SDK 原生支援執行鍵值操作。鍵值操作是 couchbase 所獨有的,可為 couchbase 中儲存的文件提供非常快速的 CRUD 操作。下面是一個 C++ 程式碼範例,用於執行文件的簡單 KV 取得和更新插入。

auto collection = cluster.bucket(config.bucket_name)
                         .scope(config.scope_name)
                         .collection(config.collection_name);

// KV- get
auto record = collection.get(document_id);
std::cout << record.content_as() << "\n";

// create a new document
const std::string document_id{ "minimal_example" };
const tao::json::value basic_doc{
  { "a", 1.0 },
  { "b", 2.0 },
};

// KV 
auto [err, resp] = collection.upsert(document_id, basic_doc, {}).get();
if (err.ec()) {
  std::cout << "ec: " << err.message() << ", ";
} else {
  std::cout << "id: " << document_id << ", CAS: " << resp.cas().value() << "\n";
}

cluster.close().get();

豐富的查詢、搜尋和向量搜尋支持

C++ SDK 支援 SQL++ 查詢、全文搜尋 (FTS) 和向量搜索,為您提供執行複雜資料操作的強大工具。無論您需要執行複雜的查詢還是執行全文搜索,SDK 都能滿足您的需求。

查詢搜尋

以下是執行簡單 SQL++ 查詢以從航空公司集合中取得記錄的程式碼片段:

auto scope = cluster.bucket(config.bucket_name).scope(config.scope_name);
  auto [err, resp] = scope.query("SELECT * FROM airline LIMIT 10").get();
  std::cout << "--- Iterating as JSON objects:\n";
  for (auto row : resp.rows_as_json()) {
    std::cout << "Airline(id: " << row["airline"]["id"] << ", name: \"" << row["airline"]["name"] << "\")\n";
  }

全文搜尋 (FTS)

以下是執行 FTS 查詢的程式碼片段,以對在地標集合上建立的索引「好餐廳」進行全文搜尋:

auto scope = cluster.bucket(config.bucket_name).scope(config.scope_name);
auto [err, resp] = scope
  .search("travel-inventory-landmarks",
     couchbase::search_request(couchbase::query_string_query("nice restaurants")),
     couchbase::search_options{}.fields({ "content" }))
  .get();
for (const auto& row : resp.rows()) {
  auto fields = row.fields_as<couchbase::codec::tao_json_serializer>();
  std::cout << "score: " << row.score() << ", id: \"" << row.id() << "\", content: \"" << fields["content"].get_string() << "\"\n";
}

向量搜尋

下面是執行向量搜尋查詢的程式碼片段:

auto scope = cluster.bucket(config.bucket_name).scope(config.scope_name);

// weights could be retrieved from your llm model or openAI
std::vector<double> weights{ 0.1, 0.2, 0.3, 0.4 };
auto [err, resp] = scope
  .search("travel-inventory-landmarks",
    couchbase::search_request(couchbase::vector_search(
    couchbase::vector_query(field_name, weights))))
  .get();

for (const auto& row : resp.rows()) {
  auto fields = row.fields_as<couchbase::codec::tao_json_serializer>();
  std::cout << "score: " << row.score() << ", id: \"" << row.id() << "\", content: \"" << fields["content"].get_string() << "\"\n";
}

非同步程式設計

SDK 支援非同步程式設計模型,讓您能夠建立響應式、非阻塞的應用程式。這對於保持響應能力至關重要的高吞吐量應用程式特別有用。這是在非同步上下文中運行事務的範例:

std::shared_ptr<async_attempt_context> ctx) -> couchbase::error {
  ctx->get(
    collection,
    some_id,
    // do something in this transaction
}

交易

這個新的 C++ SDK 包括對事務的支持,並透過添加更多效能改進和功能來取代我們現有的 C++ 事務支援。以下是建立事務上下文的範例程式碼片段:

std::shared_ptr<couchbase::transactions::attempt_context> ctx) -> couchbase::error {
  ctx.insert(collection, "doc-a", nlohmann::json({}));
  couchbase::transactions::transaction_get_result doc_a = ctx->get( collection, “doc-a”)
}

強大的錯誤處理

錯誤處理在任何應用程式中都至關重要,C++ SDK 與我們的其他 SDK 一樣,提供全面的錯誤處理功能,包括重試連接遺失、連接池和資訊性錯誤訊息。這確保您可以優雅地處理錯誤並從錯誤中恢復,從而增強應用程式的穩定性和可靠性。

入門

為了幫助您開始使用 Couchbase 的 C++ SDK,我們在我們的文件網站上準備了詳細的入門指南。以下是如何開始的快速概述:

    • 安裝 SDK :請依照文件中的安裝說明在您的開發環境中設定 SDK。
    • 連接到您的叢集:連接到您的 Couchbase 叢集。
    • 執行 CRUD 操作、執行查詢並利用 Couchbase 的強大功能。

社區和支持

我們相信社群和開源開發的力量。 Couchbase 的 C++ SDK 是開源的,我們鼓勵您做出貢獻、提供回饋並加入對話。如需支援,如果您是我們的企業許可客戶,您可以透過支援聯繫,否則,您可以存取我們的綜合文件、加入 Couchbase 論壇或 Couchbase Discord,或透過我們的支援入口網站聯繫。

進一步閱讀

要了解更多信息,請查看我們的文件網站。它更詳細地介紹了 API,特別是圍繞事務和非同步操作,並提供了其他參考資料和示例綁定鏈接,供您深入挖掘:

    • Couchbase C++ SDK 程式碼範例
    • Couchbase C++ SDK 文件
    • 下載並安裝 Couchbase C++ SDK

我們的文件網站上列出了支援的作業系統。

編碼愉快!

Couchbase 團隊

宣布 Couchbase 的 C++ SDK 全面可用的貼文首先出現在 Couchbase 部落格上。

以上是宣布 Couchbase 的 C++ SDK 全面上市的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn