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

相关文章

SpringBoot集成图片验证码框架easy-captcha的详细过程

《SpringBoot集成图片验证码框架easy-captcha的详细过程》本文介绍了如何将Easy-Captcha框架集成到SpringBoot项目中,实现图片验证码功能,Easy-Captcha是... 目录SpringBoot集成图片验证码框架easy-captcha一、引言二、依赖三、代码1. Ea

Springboot控制反转与Bean对象的方法

《Springboot控制反转与Bean对象的方法》文章介绍了SpringBoot中的控制反转(IoC)概念,描述了IoC容器如何管理Bean的生命周期和依赖关系,它详细讲解了Bean的注册过程,包括... 目录1 控制反转1.1 什么是控制反转1.2 SpringBoot中的控制反转2 Ioc容器对Bea

Spring Cloud Hystrix原理与注意事项小结

《SpringCloudHystrix原理与注意事项小结》本文介绍了Hystrix的基本概念、工作原理以及其在实际开发中的应用方式,通过对Hystrix的深入学习,开发者可以在分布式系统中实现精细... 目录一、Spring Cloud Hystrix概述和设计目标(一)Spring Cloud Hystr

Spring Boot整合消息队列RabbitMQ的实现示例

《SpringBoot整合消息队列RabbitMQ的实现示例》本文主要介绍了SpringBoot整合消息队列RabbitMQ的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的... 目录RabbitMQ 简介与安装1. RabbitMQ 简介2. RabbitMQ 安装Spring

springMVC返回Http响应的实现

《springMVC返回Http响应的实现》本文主要介绍了在SpringBoot中使用@Controller、@ResponseBody和@RestController注解进行HTTP响应返回的方法,... 目录一、返回页面二、@Controller和@ResponseBody与RestController

JAVA集成本地部署的DeepSeek的图文教程

《JAVA集成本地部署的DeepSeek的图文教程》本文主要介绍了JAVA集成本地部署的DeepSeek的图文教程,包含配置环境变量及下载DeepSeek-R1模型并启动,具有一定的参考价值,感兴趣的... 目录一、下载部署DeepSeek1.下载ollama2.下载DeepSeek-R1模型并启动 二、J

springboot rocketmq配置生产者和消息者的步骤

《springbootrocketmq配置生产者和消息者的步骤》本文介绍了如何在SpringBoot中集成RocketMQ,包括添加依赖、配置application.yml、创建生产者和消费者,并展... 目录1. 添加依赖2. 配置application.yml3. 创建生产者4. 创建消费者5. 使用在

Spring Retry 实现乐观锁重试实践记录

《SpringRetry实现乐观锁重试实践记录》本文介绍了在秒杀商品SKU表中使用乐观锁和MybatisPlus配置乐观锁的方法,并分析了测试环境和生产环境的隔离级别对乐观锁的影响,通过简单验证,... 目录一、场景分析 二、简单验证 2.1、可重复读 2.2、读已提交 三、最佳实践 3.1、配置重试模板

Spring中@Lazy注解的使用技巧与实例解析

《Spring中@Lazy注解的使用技巧与实例解析》@Lazy注解在Spring框架中用于延迟Bean的初始化,优化应用启动性能,它不仅适用于@Bean和@Component,还可以用于注入点,通过将... 目录一、@Lazy注解的作用(一)延迟Bean的初始化(二)与@Autowired结合使用二、实例解

SpringBoot使用Jasypt对YML文件配置内容加密的方法(数据库密码加密)

《SpringBoot使用Jasypt对YML文件配置内容加密的方法(数据库密码加密)》本文介绍了如何在SpringBoot项目中使用Jasypt对application.yml文件中的敏感信息(如数... 目录SpringBoot使用Jasypt对YML文件配置内容进行加密(例:数据库密码加密)前言一、J