Re: radosgw authentication problems

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Thu, Jun 7, 2012 at 12:03 AM, John Axel Eriksson <john@xxxxxxxxx> wrote:
> Hi I'm new to the list.
>
> We've been looking at Ceph as a possible replacement for our current
> distributed storage system. In particular
> we're interested in the object storage, so I started researching the
> radosgw. It did take me some time to get setup
> and the docs/wiki is missing lots of information (not pointing any
> fingers, just describing my experience).
>
> Anyway, I can't seem to actually do anything with the radosgw using
> any S3-client I've tried. The one I tried first
> was Fog (used in Chef for example). Fog is the "The Ruby cloud
> services library", available here https://github.com/fog/fog.
> Fog has support for many different cloud service providers.
>
> Anyway with Fog I get this in RadosGW logs:
>
> ##############################
>
> 2012-06-07 06:22:33.642827 7f638bfff700  2 req 4:0.000108:s3:GET /::getting op
> 2012-06-07 06:22:33.642831 7f638bfff700  2 req 4:0.000113:s3:GET
> /:list_buckets:authorizing
> 2012-06-07 06:22:33.642854 7f638bfff700 20 get_obj_state:
> rctx=0x7f637c0051e0 obj=.users:A state=0x7f637c005298
> s->prefetch_data=0
> 2012-06-07 06:22:33.642863 7f638bfff700 10 moving .users+A to cache LRU end
> 2012-06-07 06:22:33.642866 7f638bfff700 10 cache get: name=.users+A : hit
> 2012-06-07 06:22:33.642872 7f638bfff700 20 get_obj_state: s->obj_tag
> was set empty
> 2012-06-07 06:22:33.642877 7f638bfff700 10 moving .users+A to cache LRU end
> 2012-06-07 06:22:33.642879 7f638bfff700 10 cache get: name=.users+A : hit
> 2012-06-07 06:22:33.642920 7f638bfff700 10 get_canon_resource(): dest=/
> 2012-06-07 06:22:33.642923 7f638bfff700 10 auth_hdr:
> GET
>
>
> Thu, 07 Jun 2012 06:22:33 +0000
> /
> 2012-06-07 06:22:33.642942 7f638bfff700 15 b64=zeK7YoQr63ajV6BRW6Z/UB1c4nM=
> 2012-06-07 06:22:33.642944 7f638bfff700 15
> auth_sign=I9+abkuIjC89me95FoxmqApdrPs=
> 2012-06-07 06:22:33.642946 7f638bfff700 15 compare=-49
> 2012-06-07 06:22:33.642949 7f638bfff700 10 failed to authorize request
> 2012-06-07 06:22:33.642954 7f638bfff700 10 --> Status: 403
>
> So for some reason it fails to authorize the request.
>
> ###############################
>
> Then I moved to trying RightAws which is a different Cloud Services
> Library in Ruby. Here I get a little further (because I first get a
> 200 response):
>
> 2012-06-07 06:24:46.006867 7fde21d66700 10 cache get: name=.users+A : miss
> 2012-06-07 06:24:46.008245 7fde21d66700 10 cache put: name=.users+A
> 2012-06-07 06:24:46.008266 7fde21d66700 10 adding .users+A to cache LRU end
> 2012-06-07 06:24:46.008276 7fde21d66700 20 get_obj_state: s->obj_tag
> was set empty
> 2012-06-07 06:24:46.008283 7fde21d66700 10 moving .users+A to cache LRU end
> 2012-06-07 06:24:46.008291 7fde21d66700 10 cache get: name=.users+A :
> type miss (requested=1, cached=6)
> 2012-06-07 06:24:46.008301 7fde21d66700 20 get_obj_state:
> rctx=0x7fde040055b0 obj=.users:A state=0x7fde040068b8
> s->prefetch_data=0
> 2012-06-07 06:24:46.008308 7fde21d66700 10 moving .users+A to cache LRU end
> 2012-06-07 06:24:46.008311 7fde21d66700 10 cache get: name=.users+A : hit
> 2012-06-07 06:24:46.008315 7fde21d66700 20 get_obj_state: s->obj_tag
> was set empty
> 2012-06-07 06:24:46.008320 7fde21d66700 20 get_obj_state:
> rctx=0x7fde040055b0 obj=.users:A state=0x7fde040068b8
> s->prefetch_data=0
> 2012-06-07 06:24:46.008324 7fde21d66700 20 state for obj=.users:A is
> not atomic, not appending atomic test
> 2012-06-07 06:24:46.008327 7fde21d66700 20 rados->read obj-ofs=0
> read_ofs=0 read_len=16384
> 2012-06-07 06:24:46.008864 7fde21d66700 20 rados->read r=0 bl.length=126
> 2012-06-07 06:24:46.008898 7fde21d66700 10 cache put: name=.users+A
> 2012-06-07 06:24:46.008901 7fde21d66700 10 moving .users+A to cache LRU end
> 2012-06-07 06:24:46.008964 7fde21d66700 10 get_canon_resource(): dest=/
> 2012-06-07 06:24:46.008968 7fde21d66700 10 auth_hdr:
> GET
>
>
> Thu, 07 Jun 2012 06:24:46 GMT
> /
> 2012-06-07 06:24:46.009059 7fde21d66700 15 b64=jpZmnXpUiWZq8IHBmsTKwKz4+Z4=
> 2012-06-07 06:24:46.009063 7fde21d66700 15
> auth_sign=jpZmnXpUiWZq8IHBmsTKwKz4+Z4=
> 2012-06-07 06:24:46.009065 7fde21d66700 15 compare=0
> 2012-06-07 06:24:46.009069 7fde21d66700  2 req 1:0.002478:s3:GET
> /:list_buckets:reading permissions
> 2012-06-07 06:24:46.009087 7fde21d66700  2 req 1:0.002496:s3:GET
> /:list_buckets:verifying op permissions
> 2012-06-07 06:24:46.009099 7fde21d66700  2 req 1:0.002509:s3:GET
> /:list_buckets:verifying op params
> 2012-06-07 06:24:46.009103 7fde21d66700  2 req 1:0.002513:s3:GET
> /:list_buckets:executing
> 2012-06-07 06:24:46.009750 7fde21d66700 10 --> Status: 200
>
> 2012-06-07 06:24:46.009799 7fde21d66700 10 --> Content-Length: 318
>
> 2012-06-07 06:24:46.009803 7fde21d66700 10 --> Accept-Ranges: bytes
>
> 2012-06-07 06:24:46.009807 7fde21d66700 10 --> Content-type: application/xml
>
> 2012-06-07 06:24:46.009825 7fde21d66700  5 nothing to log for operation
> 2012-06-07 06:24:46.009832 7fde21d66700  2 req 1:0.003241:s3:GET
> /:list_buckets:http status=200
>
> And now I do a PUT:
>
> 2012-06-07 06:24:46.018316 7fde097fa700  2 req 2:0.000171:s3:PUT
> /johnkey::getting op
> 2012-06-07 06:24:46.018322 7fde097fa700  2 req 2:0.000177:s3:PUT
> /johnkey:create_bucket:authorizing
> 2012-06-07 06:24:46.018346 7fde097fa700 20 get_obj_state:
> rctx=0x7fddfc0058a0 obj=.users:A state=0x7fddfc005958
> s->prefetch_data=0
> 2012-06-07 06:24:46.018356 7fde097fa700 10 moving .users+A to cache LRU end
> 2012-06-07 06:24:46.018360 7fde097fa700 10 cache get: name=.users+A :
> type miss (requested=6, cached=3)
> 2012-06-07 06:24:46.019922 7fde097fa700 10 cache put: name=.users+A
> 2012-06-07 06:24:46.019931 7fde097fa700 10 moving .users+A to cache LRU end
> 2012-06-07 06:24:46.019940 7fde097fa700 20 get_obj_state: s->obj_tag
> was set empty
> 2012-06-07 06:24:46.019948 7fde097fa700 10 moving .users+A to cache LRU end
> 2012-06-07 06:24:46.019951 7fde097fa700 10 cache get: name=.users+A : hit
> 2012-06-07 06:24:46.019999 7fde097fa700 10 get_canon_resource(): dest=/johnkey
> 2012-06-07 06:24:46.020003 7fde097fa700 10 auth_hdr:
> PUT
>
>
> Thu, 07 Jun 2012 06:24:46 GMT
> /johnkey
> 2012-06-07 06:24:46.020026 7fde097fa700 15 b64=RPIY36txOP127RgLYseHC8Ua9kc=
> 2012-06-07 06:24:46.020028 7fde097fa700 15
> auth_sign=h020Ewm8NbfLYebWsXWkWCB6cDI=
> 2012-06-07 06:24:46.020030 7fde097fa700 15 compare=22
> 2012-06-07 06:24:46.020035 7fde097fa700 10 failed to authorize request
> 2012-06-07 06:24:46.020041 7fde097fa700 10 --> Status: 403
>
> #################################
>
> I've also tried s3cmd on the commandline which didn't work either. As
> far as I've understood radosgw is supposed to be compatible with S3.
>

It looks like the clients you're using are trying to access buckets
via the virtual host api: it preprends the bucket name to the service
host name. This requires wildcard dns, and also to have the 'rgw dns
name' config option correctly set in your ceph.conf.

Yehuda
--
To unsubscribe from this list: send the line "unsubscribe ceph-devel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [CEPH Users]     [Ceph Large]     [Information on CEPH]     [Linux BTRFS]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]
  Powered by Linux