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

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟&nbsp;开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚&nbsp;第一站:海量资源,应有尽有 走进“智听

在cscode中通过maven创建java项目

在cscode中创建java项目 可以通过博客完成maven的导入 建立maven项目 使用快捷键 Ctrl + Shift + P 建立一个 Maven 项目 1 Ctrl + Shift + P 打开输入框2 输入 "> java create"3 选择 maven4 选择 No Archetype5 输入 域名6 输入项目名称7 建立一个文件目录存放项目,文件名一般为项目名8 确定