Juju Charm - Ceph RADOS Gateway
Go to file
2015-04-17 16:02:24 +01:00
files Update apache to listen on 70 rather than 80 to avoid clashing with haproxy 2015-01-15 11:10:34 +00:00
hooks auto sync charmhelpers 2015-04-16 21:32:59 +00:00
templates Enable haproxy 2015-01-14 16:48:07 +00:00
tests auto disable kilo amulet tests (until later confirmed as functional) 2015-04-16 21:36:22 +00:00
unit_tests [gnuoy,r=hopem] 2015-03-30 18:04:31 +01:00
.bzrignore Exclude .converage from bzr 2014-11-15 09:33:21 -06:00
.coveragerc Finsh unit tests and fix lint 2015-02-10 10:30:13 +00:00
.project Add pydev stuff 2014-01-24 17:20:33 +00:00
.pydevproject Add pydev stuff 2014-01-24 17:20:33 +00:00
charm-helpers-hooks.yaml Enable haproxy 2015-01-14 16:48:07 +00:00
charm-helpers-tests.yaml Move charm-helpers-sync.yaml to charm-helpers-hooks.yaml and 2014-09-27 02:57:08 +00:00
config.yaml Merged 'next' in 2015-01-14 13:27:02 +00:00
copyright Minor tweak to copyright 2012-10-08 16:58:16 +01:00
icon.svg Adding Ceph icon. 2013-07-17 00:23:14 -05:00
Makefile auto Makefile test target (amulet): bump juju test timeout to 2700s (same value as the juju-deployer default). Also remove explicit test names, which will cause all +x files in ./tests to be executed (as bundletester does by default). 2015-04-16 21:32:01 +00:00
metadata.yaml Add ha support to ceph-radosgw 2014-09-19 11:00:18 +00:00
README.md Removed typos from README file. 2013-05-10 10:25:06 +01:00
revision [hopem] Added use-syslog cfg option to allow logging to syslog 2014-03-25 18:44:22 +00:00
TODO Added cephx support 2012-10-09 13:35:06 +01:00

Overview

Ceph is a distributed storage and network file system designed to provide excellent performance, reliability and scalability.

This charm deploys the RADOS Gateway, a S3 and Swift compatible HTTP gateway for online object storage on-top of a ceph cluster.

Usage

In order to use this charm, it is assumed that you have already deployed a ceph storage cluster using the 'ceph' charm with something like this::

juju deploy -n 3 --config ceph.yaml ceph

To deploy the RADOS gateway simple do::

juju deploy ceph-radosgw juju add-relation ceph-radosgw ceph

You can then directly access the RADOS gateway by exposing the service::

juju expose ceph-radosgw

The gateway can be accessed over port 80 (as show in juju status exposed ports).

Access

Note that you will need to login to one of the service units supporting the ceph charm to generate some access credentials::

juju ssh ceph/0
'sudo radosgw-admin user create --uid="ubuntu" --display-name="Ubuntu Ceph"'

For security reasons the ceph-radosgw charm is not set up with appropriate permissions to administer the ceph cluster.

Keystone Integration

Ceph >= 0.55 integrates with Openstack Keystone for authentication of Swift requests.

This is enabled by relating the ceph-radosgw service with keystone::

juju deploy keystone juju add-relation keystone ceph-radosgw

If you try to relate the radosgw to keystone with an earlier version of ceph the hook will error out to let you know.

Scale-out

Its possible to scale-out the RADOS Gateway itself::

juju add-unit -n 2 ceph-radosgw

and then stick a HA loadbalancer on the front::

juju deploy haproxy juju add-relation haproxy ceph-radosgw

Should give you a bit more bang on the front end if you really need it.

Contact Information

Author: James Page james.page@ubuntu.com Report bugs at: http://bugs.launchpad.net/charms/+source/ceph-radosgw/+filebug Location: http://jujucharms.com/charms/ceph-radosgw

Bootnotes

The Ceph RADOS Gateway makes use of a multiverse package libapache2-mod-fastcgi. As such it will try to automatically enable the multiverse pocket in /etc/apt/sources.list. Note that there is noting 'wrong' with multiverse components - they typically have less liberal licensing policies or suchlike.