如何在Ceph对象存储中存储对象

时间:2018-07-02 12:42:18

标签: java ceph

我已经在3个节点上部署了Ceph集群,并创建了msdrgw。我有3台名为ceph1,ceph2和ceph3的机器。

  • ceph1运行osd,mon,mds和rwg
  • ceph2运行osd
  • ceph3运行osd

我已经使用radosgw-admin user create命令创建了一个用户。

现在,我想使用swift api访问ceph集群并创建一个容器。为此,我编写了以下Java代码:

import org.javaswift.joss.client.factory.AccountConfig;
import org.javaswift.joss.client.factory.AccountFactory;
import org.javaswift.joss.client.factory.AuthenticationMethod;
import org.javaswift.joss.model.Account;
import org.javaswift.joss.model.Container;
import org.javaswift.joss.model.StoredObject;
import java.io.File;
import java.io.IOException;
import java.util.*;

public class Example {

public static void main(String[] args) {

    String username = "sahoo";
    String password = "IM8K5GAQIXHFRAKYS761";
    String authUrl  = "http://ceph1:7480/";

    AccountConfig config = new AccountConfig();
    config.setUsername(username);
    config.setPassword(password);
    config.setAuthUrl(authUrl);
    config.setAuthenticationMethod(AuthenticationMethod.BASIC);

    Account account = new AccountFactory(config).createAccount();
    Container container = account.getContainer("container-name");
    container.create();
}
}

但是在运行代码时,出现以下异常:

Exception in thread "main" java.lang.NullPointerException
at org.javaswift.joss.command.impl.identity.BasicAuthenticationCommandImpl.getReturnObject(BasicAuthenticationCommandImpl.java:35)
at org.javaswift.joss.command.impl.identity.BasicAuthenticationCommandImpl.getReturnObject(BasicAuthenticationCommandImpl.java:18)
at org.javaswift.joss.command.impl.core.AbstractCommand.call(AbstractCommand.java:51)
at org.javaswift.joss.client.impl.ClientImpl.createAccount(ClientImpl.java:97)
at org.javaswift.joss.client.impl.ClientImpl.createAccount(ClientImpl.java:27)
at org.javaswift.joss.client.core.AbstractClient.authenticate(AbstractClient.java:35)
at org.javaswift.joss.client.factory.AccountFactory.createAccount(AccountFactory.java:30)
at Example.main(Example.java:24)

任何人都可以帮助我说明为什么我会得到例外的原因以及我们需要传递给config.setAuthUrl()的确切信息。

1 个答案:

答案 0 :(得分:1)

首先,您需要创建子用户才能使用swift API。

sudo radosgw-admin subuser create radosgw-admin subuser create --uid={uid} --subuser={uid} --access=[ read | write | readwrite | full ]

REF:http://docs.ceph.com/docs/giant/radosgw/admin/

  

要为该用户创建子用户(Swift界面),必须指定用户ID(--uid = {username}),子用户ID以及该子用户的访问级别。

然后,我们需要将Ceph RGW的URL传递到config.setAuthUrl()。最好快速使用swift命令进行测试。

例如,如果您可以通过以下命令确认创建容器:

# swift -V 1.0 -A http://ceph.example.com/auth/v1 -U foo:swift -K testsecret post test-container

然后,您可以指定以下变量:

  • config.setUsername()... foo:swift
  • config.setPassword()... testsecret
  • config.setAuthUrl()... http://ceph.example.com/auth/v1