ceph java_java操作ceph之rbd基本操作

2023-10-14 21:10

本文主要是介绍ceph java_java操作ceph之rbd基本操作,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、安装librados和librbd

Ceph存储集群提供了基本的存储服务,允许Ceph在一个统一的系统中唯一地传送对象,块和文件存储。 但是,不限于使用RESTful,块或POSIX接口。 基于RADOS,Librados API使您能够创建自己的Ceph存储群集接口。Librados API使您能够与Ceph存储集群中的两种守护程序进行交互:

1)Ceph监视器,其维护集群映射的主副本。

2)Ceph OSD守护程序(OSD),它将数据作为对象存储在存储节点上。

要安装librados-dev和librbd-dev,因为java的Rados类需要用到librados-dev,而Rbd类需要用到librbd-dev

,需要执行以下步骤:

1)安装librados和librbd。

对于Debian / Ubuntu,执行:

apt-get install librados-dev

apt-get install librbd-dev

对于 CentOS/RHEL,执行:

yum install librados2-devel

yum install librbd1-devel

为开发人员安装库后,可以在/usr/include/rados下找到C / C ++所需的头文件

也可以下载下面的4个rmp包:

wget http://vault.centos.org/7.2.1511/storage/x86_64/ceph-hammer/librados2-0.94.5-1.el7.x86_64.rpm

wget http://vault.centos.org/7.2.1511/storage/x86_64/ceph-hammer/librados2-devel-0.94.5-1.el7.x86_64.rpm

wget http://vault.centos.org/7.2.1511/storage/x86_64/ceph-hammer/librbd1-0.94.5-1.el7.x86_64.rpm

wget http://vault.centos.org/7.2.1511/storage/x86_64/ceph-hammer/librbd1-devel-0.94.5-1.el7.x86_64.rpm

然后执行:

yum install librados2-0.94.5-1.el7.x86_64.rpm librados2-devel-0.94.5-1.el7.x86_64.rpm -y

yum install librbd1-0.94.5-1.el7.x86_64.rpm librbd1-devel-0.94.5-1.el7.x86_64.rpm -y

2)克隆rados-java工程:

git clone https://github.com/ceph/rados-java.git

3)构建rados-java工程:

cd rados-java-master

mvn install-Dmaven.test.skip=true

JAR文件位于rados-java-master/target下

4)新建一个maven工程cephDemo,用来调用ceph

工程目录如下所示:

12dc4f6b8204edc379caed9b5b168af0.png

下面引用的rados-0.4.0-SNAPSHOT.jar是由上面的mvn install后生成的jar包,实情情况版本可能有变

pom.xml配置如下:

4.0.0

com.ceph.test

cephDemo

0.0.1-SNAPSHOT

cephDemo

com.ceph

rados

0.4.0-SNAPSHOT

二、应用程序调用ceph原理

下图提供了初始连接的高级流程。

017bf47baadf7bf23759c1ba1f24db4a.png

以下是java对ceph中image的基本操作示例:

packagecom.ceph.rbd;importjava.io.File;importjava.util.Arrays;importjava.util.List;importcom.ceph.rados.IoCTX;importcom.ceph.rados.Rados;importcom.ceph.rados.exceptions.RadosException;importcom.ceph.rbd.jna.RbdImageInfo;importcom.ceph.rbd.jna.RbdSnapInfo;public classRbdDao {private staticRados rados;private staticIoCTX ioctx;private staticRbd rbd;/*** 连接上ceph环境*/

public static voidconnectCeph(){try{

rados= new Rados("admin");//rados.confSet("mon_host", "10.111.131.125");//rados.confSet("key", "AQBngfhYpHvLKhAAtmVZTyR3NJxx1WOVeLo5pQ==");

rados.confSet("mon_host", "172.16.60.41");

rados.confSet("key", "AQCdP9pYGI4jBBAAc96J8/OconCkVKWPBNU2vg==");

rados.connect();

ioctx= rados.ioCtxCreate("rbd");

rbd= newRbd(ioctx);

System.out.println("successs connetc");

}catch(Exception e) {

e.printStackTrace();//TODO: handle exception

}

}/*** 返回所有的image,并展示其详细信息

*@return

*/

public static ListimageList(){

List imageList=null;try{

imageList=Arrays.asList(rbd.list());for(String s:imageList){

showDetailOfImage(s);

}

}catch(RbdException e) {//TODO Auto-generated catch block

e.printStackTrace();

}returnimageList;

}/*** 显示image的详细信息

*@paramimageName*/

public static voidshowDetailOfImage(String imageName){

RbdImage image;try{

image=rbd.open(imageName);

RbdImageInfo info=image.stat();

System.out.println("=================================================================");

System.out.println("imageName: "+imageName);

System.out.println("imageSize: "+info.size);

System.out.println("order: "+info.order);

rbd.close(image);

}catch(RbdException e) {//TODO Auto-generated catch block

e.printStackTrace();

}

}/*** 以格式1创建image

*@paramimageName 名称

*@paramimageSize 大小*/

public static void createRbd_format1(String imageName, longimageSize){try{

rbd.create(imageName, imageSize);

RbdImage image=rbd.open(imageName);boolean oldFormat =image.isOldFormat();

System.out.println("imageFormat:==========================="+oldFormat);

rbd.close(image);

}catch(RbdException e) {

System.out.println(e.getMessage()+ ": " +e.getReturnValue());

}

}/*** 以格式2创建image,ceph 仅支持克隆 format 2 映像(即用 rbd create –format 2 创建的),而且内核 rbd 模块还不支持。

所以现在你 只能用 QEMU/KVM 或 librbd直接访问克隆品

*@paramimageName 名称

*@paramimageSize 大小*/

public static void createRbd_format2(String imageName, longimageSize){try{int features = (1<<0);

System.out.println("features=============="+features);

rbd.create(imageName, imageSize,features,0);

RbdImage image=rbd.open(imageName);boolean oldFormat =image.isOldFormat();

System.out.println("imageFormat:==========================="+oldFormat);

rbd.close(image);

image.flatten();

}catch(RbdException e) {

System.out.println(e.getMessage()+ ": " +e.getReturnValue());

}

}/*** 方法创建一个image并对重设置大小为初始化大小的2倍

*@paramimageName*/

public static voidresizeImage(String imageName){long initialSize = 10485760;long newSize = initialSize * 2;try{int features = (1<<0);

System.out.println("features=============="+features);

rbd.create(imageName, initialSize,features,0);

RbdImage image=rbd.open(imageName);

image.resize(newSize);

rbd.close(image);

}catch(RbdException e) {

System.out.println(e.getMessage()+ ": " +e.getReturnValue());

}

}/*** 创建映像的快照

*@paramimageName 映像名称

*@paramsnapName 快照名称*/

public static voidcreateSnap(String imageName,String snapName){try{

RbdImage image=rbd.open(imageName);//创建快照

image.snapCreate(snapName);//保护快照可以防止快照被删除

image.snapProtect(snapName);//返回一个image的所有快照

List snaps =image.snapList();for(RbdSnapInfo rbds:snaps){

System.out.println("快照名称:"+rbds.name);

System.out.println("快照大小:"+rbds.size);

}

}catch(RbdException e) {//TODO Auto-generated catch block

e.printStackTrace();

}

}/*** 通过快照克隆出新的image

*@paramparentImageName 快照对应的image名称

*@paramsnapName 快照的名称

*@paramnewImageName 生成的新的image的名称*/

public static voidcopySnapToNewImage(String parentImageName,String snapName,String newImageName){int features = (1<<0);try{

rbd.clone(parentImageName, snapName, ioctx, newImageName, features,0);

}catch(RbdException e) {//TODO Auto-generated catch block

e.printStackTrace();

}

}/*** 删除某个image的名叫 snapName的快照,需要注意的是要删除快照,必须保证快照没有copy的子image,否则会删除失败。

*@paramimageName

*@paramsnapName*/

public static voiddeleteSnap(String imageName,String snapName){try{

RbdImage image=rbd.open(imageName);

image.snapUnprotect(snapName);

image.snapRemove(snapName);

}catch(RbdException e) {//TODO Auto-generated catch block

e.printStackTrace();

}

}/*** 删除某一个image

*@paramr

*@paramio

*@paramimageName

*@throwsRadosException

*@throwsRbdException*/

public static voidcleanupImage(Rados r, IoCTX io, String imageName) {try{if (r != null) {if (io != null) {

Rbd rbd= newRbd(ioctx);

RbdImage image=rbd.open(imageName);

rbd.close(image);

rbd.remove(imageName);

}

}

}catch(Exception e) {//TODO: handle exception

}

}public static voidmain(String[] args){

connectCeph();//createRbd_format1("mysql-hzb-2",10737418240l);//createRbd_format2("imageformat2",10485760);//cleanupImage(rados,ioctx,"mysql-hzb");//resizeImage("mysql-hzb");//createSnap("imageformat3","imageformat3-snap");//copySnapToNewImage("imageformat3","imageformat3-snap","imageformat3-copy");//deleteSnap("imageformat3","imageformat3-snap");

imageList();

}

}

这篇关于ceph java_java操作ceph之rbd基本操作的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/213167

相关文章

Java 实用工具类Spring 的 AnnotationUtils详解

《Java实用工具类Spring的AnnotationUtils详解》Spring框架提供了一个强大的注解工具类org.springframework.core.annotation.Annot... 目录前言一、AnnotationUtils 的常用方法二、常见应用场景三、与 JDK 原生注解 API 的

Java controller接口出入参时间序列化转换操作方法(两种)

《Javacontroller接口出入参时间序列化转换操作方法(两种)》:本文主要介绍Javacontroller接口出入参时间序列化转换操作方法,本文给大家列举两种简单方法,感兴趣的朋友一起看... 目录方式一、使用注解方式二、统一配置场景:在controller编写的接口,在前后端交互过程中一般都会涉及

Java中的StringBuilder之如何高效构建字符串

《Java中的StringBuilder之如何高效构建字符串》本文将深入浅出地介绍StringBuilder的使用方法、性能优势以及相关字符串处理技术,结合代码示例帮助读者更好地理解和应用,希望对大家... 目录关键点什么是 StringBuilder?为什么需要 StringBuilder?如何使用 St

使用Java将各种数据写入Excel表格的操作示例

《使用Java将各种数据写入Excel表格的操作示例》在数据处理与管理领域,Excel凭借其强大的功能和广泛的应用,成为了数据存储与展示的重要工具,在Java开发过程中,常常需要将不同类型的数据,本文... 目录前言安装免费Java库1. 写入文本、或数值到 Excel单元格2. 写入数组到 Excel表格

Java并发编程之如何优雅关闭钩子Shutdown Hook

《Java并发编程之如何优雅关闭钩子ShutdownHook》这篇文章主要为大家详细介绍了Java如何实现优雅关闭钩子ShutdownHook,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起... 目录关闭钩子简介关闭钩子应用场景数据库连接实战演示使用关闭钩子的注意事项开源框架中的关闭钩子机制1.

Python中pywin32 常用窗口操作的实现

《Python中pywin32常用窗口操作的实现》本文主要介绍了Python中pywin32常用窗口操作的实现,pywin32主要的作用是供Python开发者快速调用WindowsAPI的一个... 目录获取窗口句柄获取最前端窗口句柄获取指定坐标处的窗口根据窗口的完整标题匹配获取句柄根据窗口的类别匹配获取句

Maven中引入 springboot 相关依赖的方式(最新推荐)

《Maven中引入springboot相关依赖的方式(最新推荐)》:本文主要介绍Maven中引入springboot相关依赖的方式(最新推荐),本文给大家介绍的非常详细,对大家的学习或工作具有... 目录Maven中引入 springboot 相关依赖的方式1. 不使用版本管理(不推荐)2、使用版本管理(推

Java 中的 @SneakyThrows 注解使用方法(简化异常处理的利与弊)

《Java中的@SneakyThrows注解使用方法(简化异常处理的利与弊)》为了简化异常处理,Lombok提供了一个强大的注解@SneakyThrows,本文将详细介绍@SneakyThro... 目录1. @SneakyThrows 简介 1.1 什么是 Lombok?2. @SneakyThrows

在 Spring Boot 中实现异常处理最佳实践

《在SpringBoot中实现异常处理最佳实践》本文介绍如何在SpringBoot中实现异常处理,涵盖核心概念、实现方法、与先前查询的集成、性能分析、常见问题和最佳实践,感兴趣的朋友一起看看吧... 目录一、Spring Boot 异常处理的背景与核心概念1.1 为什么需要异常处理?1.2 Spring B

Python位移操作和位运算的实现示例

《Python位移操作和位运算的实现示例》本文主要介绍了Python位移操作和位运算的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 位移操作1.1 左移操作 (<<)1.2 右移操作 (>>)注意事项:2. 位运算2.1