当前位置: 首页 > news >正文

springboot整合couchbase(集群)

springboot整合couchbase

  • 1、Couchbase
    • 1.1、介绍
    • 1.2、Bucket
    • 1.3、Couchbase SDK
  • 2、(key,value)写入couchbase集群
    • 2.1、总体图
    • 2.2、依赖
    • 2.3、CouchbaseConfig 配置文件
    • 2.4、代码使用

1、Couchbase

1.1、介绍

在这里插入图片描述
在这里插入图片描述

1.2、Bucket

在 Couchbase 中,bucket 是一个重要的概念,类似于传统数据库中的数据库或表。它是 Couchbase 存储数据的基本单位,主要用于组织和管理数据。

  • Bucket 是 Couchbase 中存储文档的容器。每个 bucket 可以包含多个文档,文档可以是 JSON 格式的数据。

1.3、Couchbase SDK

  • Couchbase SDK(Software Development Kit)是一个用于与 Couchbase数据库进行交互的开发工具包。
  • 它提供了一组 API 和工具,允许开发者通过编程语言(如 Java、Python 等)与Couchbase数据库进行连接、数据操作、查询、集群管理等操作。

2、(key,value)写入couchbase集群

2.1、总体图

在这里插入图片描述

2.2、依赖

couchbase服务器的版本是4.0

 <dependency>
            <groupId>com.fasterxml.jackson.datatype</groupId>
            <artifactId>jackson-datatype-jsr310</artifactId>
            <version>2.13.0</version> 
        </dependency>

        <dependency>
            <groupId>com.couchbase.client</groupId>
            <artifactId>java-client</artifactId>
            <version>2.7.23</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.data</groupId>
            <artifactId>spring-data-couchbase</artifactId>
            <version>4.2.0</version> 
</dependency>

2.3、CouchbaseConfig 配置文件

package com.baafs.amtiot.couchbase;

import com.baafs.amtiot.Models.VehiclePosition;
import com.couchbase.client.java.Bucket;
import com.couchbase.client.java.CouchbaseCluster;
import com.couchbase.client.java.document.JsonDocument;
import com.couchbase.client.java.document.json.JsonObject;
import com.fasterxml.jackson.datatype.jsr310.JavaTimeModule;
import com.fasterxml.jackson.databind.ObjectMapper;

public class CouchbaseUtils {

    private static final ObjectMapper objectMapper = new ObjectMapper()
            .registerModule(new JavaTimeModule());

    public static void couchbaseVehiclePosition(String vmeid, VehiclePosition vehiclePosition) {
        // 创建 cluster
// 连接 couchbase集群
  //<couchbase> C#中couchbase集群配置文件,免密码登录
        // 重点 =====   ip:端口:池   buckets
  //   <servers>
  //     <add uri="http://192.168.23.37:8091/pools" />
  //     <add uri="http://192.168.23.38:8091/pools" />
  //   </servers>
  //   <buckets>
  //     <add name="default" useSsl="false">
  //     </add>
  //   </buckets>
  //</couchbase>
// 1、自动选择端口(池):CouchbaseCluster.create() 会自动使用 8091 端口与集群进行通信,不需要显式指定端口号或 pools
///2、集群发现和负载均衡:Couchbase SDK 会自动进行集群拓扑发现并且会自动负载均衡。
        CouchbaseCluster cluster = CouchbaseCluster.create("192.168.23.37,192.168.23.38");

        // 连接 bucket 并打开
        Bucket bucket = cluster.openBucket("default");
        System.out.println("Connected to bucket: " + bucket.name());

        try {
            // 将 VehiclePosition 对象转换为 JSON
            JsonObject content = JsonObject.fromJson(objectMapper.writeValueAsString(vehiclePosition));
            JsonDocument inserted = bucket.upsert(JsonDocument.create(vmeid, content));

            // 确认插入成功,获取一下
            System.out.println("Document inserted with ID: " + inserted.id());
            // content
            JsonDocument found = bucket.get("SA21009005");
            System.out.println("Couchbase is the best database in the " + found.content().toString());

        } catch (Exception e) {
            System.out.println("Error processing vehicle position: " + e.getMessage());
        } finally {
            cluster.disconnect();
        }
    }
}

2.4、代码使用

在这里插入图片描述

相关文章:

  • 3. 轴指令(omron 机器自动化控制器)——>MC_GearOut
  • 计算机二级WPS Office第七套WPS演示
  • C++vector常用接口和模拟实现
  • 缺省路由配置出接口不能ping通对面路由器的环回接口,但是配置下一跳可以的原因
  • 【Hugging Face 开源库】Diffusers 库 —— 扩散模型
  • 消息队列保证最终一致性的优势
  • Rust 学习笔记(一)
  • NanoGraphrag原理和数据流讲解
  • OkHttps工具类的简单使用
  • Linux上位机开发实践(开源框架和开源算法)
  • 【大模型学习】什么是具身智能
  • 力扣刷题22. 括号生成
  • 抓包工具fiddler的基础知识
  • 【雅思播客09】Turn Left here.
  • AI:昆仑万维 MusiCoT 技术介绍
  • 【深度学习与实战】2.1、线性回归模型与梯度下降法先导案例--最小二乘法(向量形式求解)
  • 使用 Cursor、MCP 和 Figma 实现工程化项目自动化,提升高达 200% 效率
  • LeetCode 2760 最长奇偶性
  • 英伟达与通用汽车深化合作,澳特证券am broker助力科技投资
  • NotePad++与Navicat工具的下载 完全免费无套路
  • 深圳下调公积金利率,209万纯公积金贷款总利息减少9.94万
  • 古龙逝世四十周年|中国武侠文学学会与多所高校联合发起学术纪念活动
  • 甘怀真:天下是神域,不是全世界
  • 巴基斯坦所有主要城市宣布进入紧急状态,学校和教育机构停课
  • 涉个人信息收集使用问题,15款App和16款SDK被通报
  • 五一假期上海境外来沪消费4.55亿元,同比增长211.6%