文档章节

基于OpenStack4j进行OpenStack开发

xhHuang
 xhHuang
发布于 2017/08/11 10:55
字数 395
阅读 435
收藏 0

一、说明

项目通过Maven(3.x)进行构建,然后使用的是openstack JAVA版的SDK工具openstack4j。

注意:开发前,必须在主机的hosts文件中添加openstack控制节点的主机信息,如下图所示是在windows系统下修改hosts文件(文件地址:C:\Windows\System32\drivers\etc\hosts)

二、pom.xml设置

pom文件中添加对slf4j-api、slf4j-log4j12和openstack4j的依赖,由于本人开发环境使用的jdk是1.7,所以使用的openstack4j版本为2.x,如果jdk是1.8的话,则可以使用3.x

<!-- https://mvnrepository.com/artifact/org.slf4j/slf4j-api -->
    <dependency>
      <groupId>org.slf4j</groupId>
      <artifactId>slf4j-api</artifactId>
      <version>1.7.21</version>
    </dependency>
    <!-- https://mvnrepository.com/artifact/org.slf4j/slf4j-log4j12 -->
    <dependency>
      <groupId>org.slf4j</groupId>
      <artifactId>slf4j-log4j12</artifactId>
      <version>1.7.21</version>
    </dependency>    
    
    <!-- OpenStack4j -->
    <dependency>
	  <groupId>org.pacesys</groupId>
	  <artifactId>openstack4j</artifactId>
	  <version>2.20</version>
	  <classifier>withdeps</classifier>
	</dependency>

三、测试代码

写的java的测试代码如下,实现以下功能:1)创建OSClient实例;2)获取Swfit中container信息;3)新建一个名为xhhuangContainer的container

package com.xhhuang.openstack;

import java.util.HashMap;
import java.util.List;
import java.util.Map;

import org.openstack4j.model.identity.User;
import org.openstack4j.model.storage.object.SwiftAccount;
import org.openstack4j.model.storage.object.SwiftContainer;
import org.openstack4j.model.storage.object.options.CreateUpdateContainerOptions;
import org.openstack4j.openstack.OSFactory;
import org.openstack4j.api.OSClient;

/**
 * Hello world!
 *
 */
public class App 
{
    public static void main( String[] args )
    {
    	// 开始认证
    	System.out.println("开始认证:");
        OSClient os = OSFactory.builder()
        						.endpoint("http://10.3.1.123:5000/v2.0")
        						.credentials("pipsCloud", "pipsCloudTeam")
        						.tenantName("pipsCloud")
        						.authenticate();
        System.out.println("完成认证:"+os.toString());
        
        System.out.println("获取Swift账户:");
        SwiftAccount swiftAccount = os.objectStorage().account().get();
        System.out.println(swiftAccount);
        
        System.out.println("获取对象存储元数据信息:");
        Map<String, String> metadata = new HashMap<String, String>();
        boolean result = os.objectStorage().account().updateMetadata(metadata);
        System.out.println(result);
        
        System.out.println("获取容器信息:");
        List<? extends SwiftContainer> containers = os.objectStorage().containers().list();
        int containerCount = (int) swiftAccount.getContainerCount();
        
        for(int i=0; i<containerCount; i++){
        	System.out.println(containers.get(i).getName()+containers.get(i).getTotalSize()+"\n");
        }
        
        System.out.println("新建容器:");
        os.objectStorage().containers().create("xhhuangContainer", CreateUpdateContainerOptions.create()
        																					.accessAnybodyRead()
        																					);
        
        
    }
}

测试结果如下:

  • (console端)

  • openstack container查看

 

© 著作权归作者所有

共有 人打赏支持
下一篇: Ambari卸载脚本
xhHuang
粉丝 7
博文 36
码字总数 28921
作品 0
武汉
程序员
私信 提问
加载中

评论(2)

xhHuang
xhHuang

引用来自“对象已抛出”的评论

我用fuel+virtualbox搭建的Openstack M版,现在想用openstack4j开发,eclipse是在本机还是在节点
eclipse在本机还是节点都可以 因为在代码的一开始就要连接上openstack。我开发的时候eclipse是在自己的电脑上,而openstack是在机房的
对象已抛出
对象已抛出
我用fuel+virtualbox搭建的Openstack M版,现在想用openstack4j开发,eclipse是在本机还是在节点
【华为】基于OpenStack4j实现云服务(CTS/DMS/KMS/MaaS/SMN)的SDK

【背景】 基于OpenStack4j实现华为云服务(CTS/DMS/KMS/MaaS/SMN)的SDK 定义: 1. OpenStack4j:开源OpenStackSDK项目,提供Java语言的SDK,需要基于此提供华为的SDK扩展。Github: https://g...

华为众包
2017/07/11
0
0
【华为】基于OpenStack4j实现华为云服务(ELB/DNS/MRS)的SDK

【技术要求】 基于OpenStack4j实现.(java) 【需求文档】 详细见附件。 【项目背景】 基于OpenStack社区的java语言SDK项目OpenStack4j。需要基于此提供华为的SDK扩展。 【应用场景】 详细见附...

华为众包
2017/06/20
1
0
【华为】基于OpenStack4j实现华为云服务(VBS/CES/AS)的SDK

【项目背景】 基于OpenStack社区的SDK项目OpenStack4j。提供Java语言的SDK,需要基于此提供华为的SDK扩展。 【应用场景】 详细见附件工作任务说明书。 【周期规划】 25天(自然日,含验收测试...

华为众包
2017/06/20
1
0
【华为】基于OpenStack4j实现(RDS/AntiDDos)的SDK

【背景】 基于OpenStack4j实现华为云服务(RDS/AntiDDos)的SDK 定义: 1. OpenStack4j:开源OpenStackSDK项目,提供Java语言的SDK,需要基于此提供华为的SDK扩展。Github: https://github.co...

华为众包
2017/07/11
0
0
开放基础架构新浪潮:互联网巨头背后的OpenStack

2018年5月21-24日,第十七届OpenStack峰会在温哥华盛大开幕,今年峰会的主题为“Open Infrastructure”。凸显出OpenStack基金会积极拥抱变化,主动求变的态度更加清晰,也是OpenStack基金会开...

云科技时代
05/25
0
0

没有更多内容

加载失败,请刷新页面

加载更多

EOS官方钱包keosd

EOS官方钱包的名称是keosd,它负责管理你的私钥,并且帮你进行交易的签名。 不过不幸的是,keosd钱包对普通用户并不友好,它是一个命令行程序,目前还没有像以太坊的mist那样的图形化界面,而...

汇智网教程
今天
25
0
ArrayList的实现原理以及实现线程安全

一、ArrayList概述 ArrayList是基于数组实现的,是一个动态的数字,可以自动扩容。 ArrayList不是线程安全的,效率比较高,只能用于单线程的环境中,在多线程环境中可以使用Collections.syn...

一看就喷亏的小猿
今天
33
0
Netty 备录 (一)

入职新公司不久,修修补补1个月的bug,来了点实战性的技术---基于netty即时通信 还好之前对socket有所使用及了解,入手netty应该不是很难吧,好吧,的确有点难,刚看这玩意的时候,可能都不知道哪里...

_大侠__
昨天
39
0
Django简单介绍和用户访问流程

Python下有许多款不同的 Web 框架。Django是重量级选手中最有代表性的一位。许多成功的网站和APP都基于Django。 Django是一个开放源代码的Web应用框架,由Python写成。 Django遵守BSD版权,初...

枫叶云
昨天
51
0
Spring Cloud Stream消费失败后的处理策略(四):重新入队(RabbitMQ)

应用场景 之前我们已经通过《Spring Cloud Stream消费失败后的处理策略(一):自动重试》一文介绍了Spring Cloud Stream默认的消息重试功能。本文将介绍RabbitMQ的binder提供的另外一种重试...

程序猿DD
昨天
24
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部