Here is an Example of my code:
Properties props = new Properties(); props.setProperty(KeystoneProperties.CREDENTIAL_TYPE, CredentialTypes.API_ACCESS_KEY_CREDENTIALS); context = ContextBuilder.newBuilder("hpcloud-objectstorage") .overrides(props) .credentials(api_key, api_secret) .buildView(BlobStoreContext.class); store = context.getBlobStore(); // this works Blob blob1 = store.blobBuilder("file1") .payload("") .build(); String blobName1 = store.putBlob(remoteFolderName, blob1); // this crashes with the message, you can see below Blob blob2 = store.blobBuilder("file2") .payload("a") .build(); String blobName1 = store.putBlob(remoteFolderName, blob2);
the exception message I get after executing this code is following:
Nov 07, 2012 7:08:44 PM org.jclouds.logging.jdk.JDKLogger logError Schwerwiegend: Cannot retry after server error, command has exceeded retry limit 5: [method=HPCloudObjectStorageAsyncApi.putObject, request=PUT https://region-a.geo-1.objects.hpcloudsvc.com/v1/82797321453196/cloudstoretest/file2 HTTP/1.1]
an here is the stacktrace:
org.jclouds.http.HttpResponseException: Unexpected end of file from server connecting to PUT https://region-a.geo-1.objects.hpcloudsvc.com/v1/82797321453196/cloudstoretest/tada%21 HTTP/1.1 at org.jclouds.http.internal.BaseHttpCommandExecutorService$HttpResponseCallable.call(BaseHttpCommandExecutorService.java:179) at org.jclouds.http.internal.BaseHttpCommandExecutorService$HttpResponseCallable.call(BaseHttpCommandExecutorService.java:135) ...
I dont have any clue, what the problem could be. I'm searching for 2 days for possible solutions, but without any result. I would be very happy, if someone has an idea, what i am doing wrong...
looks like the name of your blob is literally "tada!" based on the url encoded "tada%21"
it is quite possible that the openstack swift implementation doesn't support blobs with names including a trailing '!'. Can you try other naming conventions and see if you have the same error?