]> git.apps.os.sepia.ceph.com Git - ceph.git/log
ceph.git
13 years agoosd: fix requeue order for waiting_for_ondisk
Sage Weil [Tue, 21 Aug 2012 17:35:37 +0000 (10:35 -0700)]
osd: fix requeue order for waiting_for_ondisk

We are calling requeue_ops() on each individual op, which means we need
to requeue in reverse order (newest first, oldest last).

Fixes: #2947
Signed-off-by: Sage Weil <sage@inktank.com>
Reviewed-by: Samuel Just <sam.just@inktank.com>
13 years agorgw: dump content_range using 64 bit formatters
Yehuda Sadeh [Sat, 18 Aug 2012 00:34:23 +0000 (17:34 -0700)]
rgw: dump content_range using 64 bit formatters

Fixes: #2961
Also make sure that size is 64 bit.

backport: argonaut
Signed-off-by: Yehuda Sadeh <yehuda@inktank.com>
13 years agoRevert "rgw: dump content_range using 64 bit formatters"
Sage Weil [Tue, 21 Aug 2012 17:48:12 +0000 (10:48 -0700)]
Revert "rgw: dump content_range using 64 bit formatters"

This reverts commit cc435e99802f77b3d4b21abe022665ac9df259cf.

Wrong fix; fcgi doesn't do %lld

13 years agorgw: dump content_range using 64 bit formatters
Yehuda Sadeh [Sat, 18 Aug 2012 00:34:23 +0000 (17:34 -0700)]
rgw: dump content_range using 64 bit formatters

Fixes: #2961
Also make sure that size is 64 bit.

backport: argonaut
Signed-off-by: Yehuda Sadeh <yehuda@inktank.com>
Reviewed-by: Sage Weil <sage@inktank.com>
13 years agoosd: fix requeue order of dup ops
Sage Weil [Mon, 20 Aug 2012 19:33:08 +0000 (12:33 -0700)]
osd: fix requeue order of dup ops

The waiting_for_ondisk (and ack) maps get dups of ops that are in progress.
If we have a peering change in which the role does not change, we will
requeue the in-progress ops but leave these in the waiting_for_ondisk
maps, which will then trigger an assert the next time we examine that map
and find it didn't match up with what we expected.

Fix this by requeuing these on any peering reset in on_change().  This
keeps the two queues in sync.

Fixes: #2956
Signed-off-by: Sage Weil <sage@inktank.com>
13 years agoosd: make notify debug output less noisy
Sage Weil [Mon, 20 Aug 2012 20:23:21 +0000 (13:23 -0700)]
osd: make notify debug output less noisy

Signed-off-by: Sage Weil <sage@inktank.com>
13 years agomds: do not return null dentry lease on getattr
Sage Weil [Fri, 17 Aug 2012 16:02:10 +0000 (09:02 -0700)]
mds: do not return null dentry lease on getattr

Specifically, /foo may exist and client may try to mount /foo/bar.  That
GETATTR request is on #1/foo/bar, but we cannot return a null dentry on bar
because the client is not prepared to handle it and will crash in
fill_trace().

Fixes: #2959
Reported-by: Yan Zheng <zheng.z.yan@intel.com>
Signed-off-by: Sage Weil <sage@inktank.com>
13 years agoosd: explicitly requeue waiting_for_map in on_change()
Sage Weil [Thu, 16 Aug 2012 00:19:22 +0000 (17:19 -0700)]
osd: explicitly requeue waiting_for_map in on_change()

Since we are requeuing stuff anyway, do it all in the correct order. This
fixes a bug where take_waiters() comes along later (at activate_map time)
and puts waiting_for_map events at the front of the queue, in front of
e.g. waiting_for_missing.  This breaks ordering from the client's
perspective.

The convention should be: whenever you requeue, requeuing everything
that logically follows it first.

Fixes: #2947
Signed-off-by: Sage Weil <sage@inktank.com>
Reviewed-by: Samuel Just <sam.just@inktank.com>
13 years agoosd: simplify how in-progress ops are requeued
Sage Weil [Thu, 16 Aug 2012 00:19:11 +0000 (17:19 -0700)]
osd: simplify how in-progress ops are requeued

Requeue them explicity from apply_and_flush_repops() and call it last, so
that the overall ordering is preserved.

Signed-off-by: Sage Weil <sage@inktank.com>
Reviewed-by: Samuel Just <sam.just@inktank.com>
13 years agoosd: rename op_waiters -> waiting_for_map
Sage Weil [Thu, 16 Aug 2012 00:18:57 +0000 (17:18 -0700)]
osd: rename op_waiters -> waiting_for_map

That's what it is used for; make the name descriptive.

Signed-off-by: Sage Weil <sage@inktank.com>
Reviewed-by: Samuel Just <sam.just@inktank.com>
13 years agoobsync: add missing package specifier to format_exc
Matthew Wodrich [Wed, 1 Aug 2012 02:13:03 +0000 (19:13 -0700)]
obsync: add missing package specifier to format_exc

Fixes: #2873
Signed-off-by: Matthew Wodrich <matthew.wodrich@dreamhost.com>
Reviewed-by: Dan Mick <dan.mick@inktank.com>
13 years agofix keyring generation for mds and osd
Danny Kukawka [Thu, 16 Aug 2012 10:56:58 +0000 (12:56 +0200)]
fix keyring generation for mds and osd

    [ The following text is in the "UTF-8" character set. ]
    [ Your display is set for the "ANSI_X3.4-1968" character set.  ]
    [ Some characters may be displayed incorrectly. ]

Fix config keys for OSD/MDS data dirs. As in documentation and other
places of the scripts the keys are 'osd data'/'mds data' and not
'osd_data'

In case if MDS: if 'mds data' doesn't exist, create it.

Signed-off-by: Danny Kukawka <danny.kukawka@bisect.de>
13 years agofix ceph osd create help
Danny Kukawka [Thu, 16 Aug 2012 10:56:32 +0000 (12:56 +0200)]
fix ceph osd create help

    [ The following text is in the "UTF-8" character set. ]
    [ Your display is set for the "ANSI_X3.4-1968" character set.  ]
    [ Some characters may be displayed incorrectly. ]

Change ceph osd create <osd-id> to ceph osd create <uuid>, since this
is what the command is really doing.

Signed-off-by: Danny Kukawka <danny.kukawka@bisect.de>
13 years agoobjectcacher: fix bh leak on discard
Sage Weil [Thu, 16 Aug 2012 01:42:56 +0000 (18:42 -0700)]
objectcacher: fix bh leak on discard

Fixes: #2950
Signed-off-by: Sage Weil <sage@inktank.com>
13 years agoMerge branch 'testing' into next
Sage Weil [Thu, 16 Aug 2012 00:56:41 +0000 (17:56 -0700)]
Merge branch 'testing' into next

13 years agomkcephfs: fix mon data empty check
Sage Weil [Thu, 16 Aug 2012 00:56:35 +0000 (17:56 -0700)]
mkcephfs: fix mon data empty check

'read' needs an arg on dash.

Fixes #2922, again.
Signed-off-by: Sage Weil <sage@inktank.com>
13 years agoMerge branch 'testing' into next
Samuel Just [Wed, 15 Aug 2012 22:19:02 +0000 (15:19 -0700)]
Merge branch 'testing' into next

13 years agoPG,Message: move intrusive_ptr_* into top namespace
Samuel Just [Wed, 15 Aug 2012 21:40:17 +0000 (14:40 -0700)]
PG,Message: move intrusive_ptr_* into top namespace

gcc 4.7 requires that the intrusive_ptr_* functions be in
the same namespace as the templated class.

Signed-off-by: Samuel Just <sam.just@inktank.com>
13 years agoMerge branch 'testing' into next
Sage Weil [Tue, 14 Aug 2012 23:53:48 +0000 (16:53 -0700)]
Merge branch 'testing' into next

13 years agomkcephfs: fix mon_data check
Sage Weil [Tue, 14 Aug 2012 23:53:18 +0000 (16:53 -0700)]
mkcephfs: fix mon_data check

* check the right path <facepalm>
* behave if the directory doesn't exist at all yet

Fixes: #2922
Signed-off-by: Sage Weil <sage@inktank.com>
13 years agov0.50 v0.50
Sage Weil [Mon, 13 Aug 2012 16:49:24 +0000 (09:49 -0700)]
v0.50

13 years agoMerge tag 'v0.50'
Sage Weil [Mon, 13 Aug 2012 16:48:49 +0000 (09:48 -0700)]
Merge tag 'v0.50'

v0.50

13 years agoMonMap: return error on failure in build_initial
Josh Durgin [Wed, 8 Aug 2012 22:24:57 +0000 (15:24 -0700)]
MonMap: return error on failure in build_initial

If mon_host fails to parse, return an error instead of success.
This avoids failing later on an assert monmap.size() > 0 in the
monmap in MonClient.

Fixes: #2913
Signed-off-by: Josh Durgin <josh.durgin@inktank.com>
13 years agoaddr_parsing: report correct error message
Josh Durgin [Wed, 8 Aug 2012 22:10:27 +0000 (15:10 -0700)]
addr_parsing: report correct error message

getaddrinfo uses its return code to report failures.

Signed-off-by: Josh Durgin <josh.durgin@inktank.com>
13 years agorgw: modify some error messages
Yehuda Sadeh [Thu, 9 Aug 2012 20:54:15 +0000 (13:54 -0700)]
rgw: modify some error messages

Make them more correct, clearer.

Signed-off-by: Yehuda Sadeh <yehuda@inktank.com>
13 years agoMerge remote-tracking branch 'origin/wip-rgw-admin'
Yehuda Sadeh [Thu, 9 Aug 2012 20:39:20 +0000 (13:39 -0700)]
Merge remote-tracking branch 'origin/wip-rgw-admin'

13 years agorgw: use multiple notification objects
Yehuda Sadeh [Mon, 18 Jun 2012 20:25:44 +0000 (13:25 -0700)]
rgw: use multiple notification objects

Issue #2504. This makes us listen and notify on more than
a single object, which reduces the contention of cache
notifications.

NOTE: This change requires that any radosgw and radosgw-admin
use the same 'rgw num control oids' config value. A config value
of 0 will maintain old compatibility, and will allow an upgraded
process run in conjuction with an old one. Setting value other
than 0 (or using the non-zero default) will require upgrading
and restarting all the gateways together. Failing to do so
might lead to inconsistent user and buckets metadata (which
will be resolved once gateways are restarted).

Signed-off-by: Yehuda Sadeh <yehuda@inktank.com>
13 years agoradosgw-admin.rst: Misc doccumentation update.
caleb miles [Wed, 25 Jul 2012 19:56:59 +0000 (12:56 -0700)]
radosgw-admin.rst: Misc doccumentation update.

Signed-off-by: caleb miles <caleb.miles@inktank.com>
13 years agorgw_admin.cc: Allow removal of a user's buckets during user removal.
caleb miles [Thu, 9 Aug 2012 20:27:21 +0000 (13:27 -0700)]
rgw_admin.cc: Allow removal of a user's buckets during user removal.

Allow the buckets, and any child objects, of a user to be deleted when the
user is deleted through radosgw-admin. In reference to feature request
2499: http://tracker.newdream.net/issues/2499.

Signed-off-by: caleb miles <caleb.miles@inktank.com>
13 years agorgw_admin.cc: Allow for deletion of objects through radosgw-admin.
caleb miles [Thu, 9 Aug 2012 16:55:27 +0000 (09:55 -0700)]
rgw_admin.cc: Allow for deletion of objects through radosgw-admin.

Allow objects to be deleted through radosgw-admin with an optional flag
to delete the tail of that object during the processing of the intent log.

Signed-off-by: caleb miles <caleb.miles@inktank.com>
13 years agodoc: New example usage.
John Wilkins [Thu, 9 Aug 2012 16:21:38 +0000 (09:21 -0700)]
doc: New example usage.

Signed-off-by: John Wilkins <john.wilkins@inktank.com>
13 years agorgw: fix usage trim call encoding
Yehuda Sadeh [Wed, 1 Aug 2012 20:22:38 +0000 (13:22 -0700)]
rgw: fix usage trim call encoding

Fixes: #2841.
Usage trim operation was encoding the wrong op structure (usage read).
Since the structures somewhat overlapped it somewhat worked, but user
info wasn't encoded.

Backport: argonaut
Signed-off-by: Yehuda Sadeh <yehuda@inktank.com>
13 years agocls_rgw: fix rgw_cls_usage_log_trim_op encode/decode
Yehuda Sadeh [Wed, 8 Aug 2012 22:21:53 +0000 (15:21 -0700)]
cls_rgw: fix rgw_cls_usage_log_trim_op encode/decode

It was not encoding user, adding that and reset version
compatibility.
This changes affects command interface, makes use of
radosgw-admin usage trim incompatible. Use of old
radosgw-admin usage trim should be avoided, as it may
remove more data than requested. In any case, upgraded
server code will not handle old client's trim requests.

backport: argonaut
Signed-off-by: Yehuda Sadeh <yehuda@inktank.com>
13 years agorgw: expand date format support
Yehuda Sadeh [Tue, 31 Jul 2012 23:17:22 +0000 (16:17 -0700)]
rgw: expand date format support

Relaxing the date format parsing function to allow UTC
instead of GMT.

Signed-off-by: Yehuda Sadeh <yehuda@inktank.com>
13 years agorgw: complete multipart upload can handle chunked encoding
Yehuda Sadeh [Thu, 2 Aug 2012 18:13:05 +0000 (11:13 -0700)]
rgw: complete multipart upload can handle chunked encoding

Fixes: #2878
We now allow complete multipart upload to use chunked encoding
when sending request data. With chunked encoding the HTTP_LENGTH
header is not required.

Backport: argonaut
Signed-off-by: Yehuda Sadeh <yehuda@inktank.com>
13 years agorgw_xml: xml_handle_data() appends data string
Yehuda Sadeh [Wed, 1 Aug 2012 18:19:32 +0000 (11:19 -0700)]
rgw_xml: xml_handle_data() appends data string

Fixes: #2879.
xml_handle_data() appends data to the object instead of just
replacing it. Parsed data can arrive in pieces, specifically
when data is escaped.

Backport: argonaut
Signed-off-by: Yehuda Sadeh <yehuda@inktank.com>
13 years agorgw: ETag is unquoted in multipart upload complete
Yehuda Sadeh [Wed, 1 Aug 2012 20:09:41 +0000 (13:09 -0700)]
rgw: ETag is unquoted in multipart upload complete

Fixes #2877.
Removing quotes from ETag before comparing it to what we
have when completing a multipart upload.

Backport: argonaut
Signed-off-by: Yehuda Sadeh <yehuda@inktank.com>
13 years agodoc: Added debug and logging reference.
John Wilkins [Wed, 8 Aug 2012 22:06:57 +0000 (15:06 -0700)]
doc: Added debug and logging reference.

Signed-off-by: John Wilkins <john.wilkins@inktank.com>
13 years agomkcephfs: use default osd_data, _journal values
Sage Weil [Wed, 8 Aug 2012 21:01:53 +0000 (14:01 -0700)]
mkcephfs: use default osd_data, _journal values

Signed-off-by: Sage Weil <sage@inktank.com>
Reviewed-by: Greg Farnum <greg@inktank.com>
13 years agomkcephfs: use new default keyring locations
Sage Weil [Wed, 8 Aug 2012 21:01:35 +0000 (14:01 -0700)]
mkcephfs: use new default keyring locations

The ceph-conf command only parses the conf; it does not apply default
config values.  This breaks mkcephfs if values are not specified in the
config.

Let ceph-osd create its own key, fix copying, and fix creation/copying for
the mds.

Fixes: #2845
Reported-by: Florian Haas <florian@hastexo.com>
Signed-off-by: Sage Weil <sage@inktank.com>
Reviewed-by: Greg Farnum <greg@inktank.com>
13 years agoMerge remote-tracking branch 'gh/next'
Sage Weil [Wed, 8 Aug 2012 20:05:12 +0000 (13:05 -0700)]
Merge remote-tracking branch 'gh/next'

13 years agobuffer: make release() private
Sage Weil [Wed, 8 Aug 2012 15:09:59 +0000 (08:09 -0700)]
buffer: make release() private

This should only be called by ~ptr or when we are replacing the current
target with something new.  It is not suitable for external consumption
Because it doesn't reset length and offset.

Signed-off-by: Sage Weil <sage@inktank.com>
13 years agorados.py: add binding for rados_trunc
Evan Felix [Sat, 4 Aug 2012 00:56:25 +0000 (17:56 -0700)]
rados.py: add binding for rados_trunc

Fixes: #2909
Signed-off-by: Evan Felix <evan.felix@pnnl.gov>
Signed-off-by: Josh Durgin <josh.durgin@inktank.com>
13 years agodoc: Explicitly state mount.ceph two first arguments are fixed.
Tommi Virtanen [Thu, 2 Aug 2012 23:03:19 +0000 (16:03 -0700)]
doc: Explicitly state mount.ceph two first arguments are fixed.

I've hurt myself too many times with this.

Signed-off-by: Tommi Virtanen <tv@inktank.com>
13 years agodoc: mount.ceph is also needed for cephx.
Tommi Virtanen [Thu, 2 Aug 2012 23:00:15 +0000 (16:00 -0700)]
doc: mount.ceph is also needed for cephx.

Signed-off-by: Tommi Virtanen <tv@inktank.com>
13 years agodoc: Fix toctree structure for man obsync(1).
Tommi Virtanen [Thu, 2 Aug 2012 22:56:57 +0000 (15:56 -0700)]
doc: Fix toctree structure for man obsync(1).

Signed-off-by: Tommi Virtanen <tv@inktank.com>
13 years agorgw_admin.cc: Disallow addition of S3 keys with subuser creation
caleb miles [Fri, 27 Jul 2012 18:26:21 +0000 (11:26 -0700)]
rgw_admin.cc: Disallow addition of S3 keys with subuser creation

Fixes: #1855
It is no longer possible to create a subuser and new S3 key associated
with that user through the radosgw-admin utility. In reference to Bug 1855
http://tracker.newdream.net/issues/1855.

Reviewed-by: Yehuda Sadeh <yehuda@inktank.com>
Signed-off-by: caleb miles <caleb.miles@inktank.com>
13 years agoceph-authtool: Fix usage, it's --print-key not --print.
Tommi Virtanen [Thu, 2 Aug 2012 20:02:04 +0000 (13:02 -0700)]
ceph-authtool: Fix usage, it's --print-key not --print.

Signed-off-by: Tommi Virtanen <tv@inktank.com>
13 years agoRevert "osd: peering: detect when log source osd goes down"
Samuel Just [Thu, 2 Aug 2012 17:58:31 +0000 (10:58 -0700)]
Revert "osd: peering: detect when log source osd goes down"

This reverts commit 0d3d75ec0d17e2f6bc5d42058f51eb2ff19ffb71.

Accidental double push.

13 years agodoc: cd to repository before running git status.
Tommi Virtanen [Thu, 2 Aug 2012 15:31:26 +0000 (08:31 -0700)]
doc: cd to repository before running git status.

Signed-off-by: Tommi Virtanen <tv@inktank.com>
13 years agodoc: Say what to do if submodules are out of date.
Tommi Virtanen [Thu, 2 Aug 2012 15:29:50 +0000 (08:29 -0700)]
doc: Say what to do if submodules are out of date.

Signed-off-by: Tommi Virtanen <tv@inktank.com>
13 years agodoc: Simplify submodules explanation.
Tommi Virtanen [Thu, 2 Aug 2012 15:27:55 +0000 (08:27 -0700)]
doc: Simplify submodules explanation.

``git clone --recursive`` does ``init`` & ``update`` for us. Also
avoids incorrect language; there never were submodules called ``init``
and ``update``.

Signed-off-by: Tommi Virtanen <tv@inktank.com>
13 years agodoc: Correct Git URL for clone
Wido den Hollander [Thu, 2 Aug 2012 10:48:26 +0000 (12:48 +0200)]
doc: Correct Git URL for clone

Using git@github.com would mean SSHing in, and your average open
source consumer probably won't have a Github account.

Using HTTPS offers the best combination of resisting man-in-the-middle
attacks and passing through corporate firewalls.

Signed-off-by: Wido den Hollander <wido@widodh.nl>
Signed-off-by: Tommi Virtanen <tv@inktank.com>
13 years agoosd: peering: detect when log source osd goes down
Sage Weil [Tue, 31 Jul 2012 21:01:57 +0000 (14:01 -0700)]
osd: peering: detect when log source osd goes down

The Peering state has a generic check based on the prior set osds that
will restart peering if one of them goes down (or one of the interesting
down ones comes up).  The GetLog state, however, can pull the log from
a peer that is not in the prior set if it got a notify from them (e.g., an
osd in an old interval that was down when the prior set was calculated).
If that osd goes down, we don't detect it and will block forward.

Fix by adding a simple check in GetLog for the newest_update_osd going
down.

(BTW GetMissing does not suffer from this problem because
peer_missing_requested is a subset of the prior set, so the Peering check
is sufficient.)

Signed-off-by: Sage Weil <sage@inktank.com>
Reviewed-by: Samuel Just <sam.just@inktank.com>
13 years agoosd: peering: detect when log source osd goes down
Sage Weil [Tue, 31 Jul 2012 21:01:57 +0000 (14:01 -0700)]
osd: peering: detect when log source osd goes down

The Peering state has a generic check based on the prior set osds that
will restart peering if one of them goes down (or one of the interesting
down ones comes up).  The GetLog state, however, can pull the log from
a peer that is not in the prior set if it got a notify from them (e.g., an
osd in an old interval that was down when the prior set was calculated).
If that osd goes down, we don't detect it and will block forward.

Fix by adding a simple check in GetLog for the newest_update_osd going
down.

(BTW GetMissing does not suffer from this problem because
peer_missing_requested is a subset of the prior set, so the Peering check
is sufficient.)

Signed-off-by: Sage Weil <sage@inktank.com>
Reviewed-by: Samuel Just <sam.just@inktank.com>
13 years agowireshark: update patch
Yehuda Sadeh [Tue, 17 Jul 2012 18:37:30 +0000 (11:37 -0700)]
wireshark: update patch

Update to latest source tree (svn 43768).

Signed-off-by: Yehuda Sadeh <yehuda@inktank.com>
13 years agoReplicatedPG: clear waiting_for_ack when we send the commit
Samuel Just [Mon, 30 Jul 2012 23:58:56 +0000 (16:58 -0700)]
ReplicatedPG: clear waiting_for_ack when we send the commit

Otherwise, we might send the ack anyway later, after a subsequent
commit is sent resulting in an out-of-order op.

This resulted in a a crash when the client encountered out of
order ops.

Signed-off-by: Samuel Just <sam.just@inktank.com>
13 years agoMerge remote-tracking branch 'upstream/wip-leveldb-iterators'
Samuel Just [Tue, 31 Jul 2012 20:51:49 +0000 (13:51 -0700)]
Merge remote-tracking branch 'upstream/wip-leveldb-iterators'

13 years agorbd: fix off-by-one error in key name
Sylvain Munaut [Tue, 31 Jul 2012 18:55:56 +0000 (11:55 -0700)]
rbd: fix off-by-one error in key name

Fixes: #2846
Signed-off-by: Sylvain Munaut <tnt@246tNt.com>
13 years agosecret: return error on empty secret
Sylvain Munaut [Tue, 31 Jul 2012 18:54:29 +0000 (11:54 -0700)]
secret: return error on empty secret

Signed-off-by: Sylvain Munaut <tnt@246tNt.com>
13 years agoPG,ReplicatedPG: clarify scrub state clearing
Samuel Just [Mon, 30 Jul 2012 20:43:51 +0000 (13:43 -0700)]
PG,ReplicatedPG: clarify scrub state clearing

scrub_clear_state takes care of clearing the SCRUB and REPAIR
flags.  Thus, PG::scrub() needn't clear them again since
any change that would have caused that if block to occur
would have triggered ReplicatedPG::on_change(), which also
clears the scrub reservations.

Signed-off-by: Samuel Just <sam.just@inktank.com>
13 years agoPG::mark_clean(): queue_snap_trim if snap_trimq is not empty
Samuel Just [Mon, 30 Jul 2012 20:38:08 +0000 (13:38 -0700)]
PG::mark_clean(): queue_snap_trim if snap_trimq is not empty

Currently, we won't queue for snap trim until the next map
update.

Noticed while reviewing another patch, this would result in
snaps not being trimmed until the next map update.

Signed-off-by: Samuel Just <sam.just@inktank.com>
13 years agoReplicatedPG::snap_trimmer: requeue if scrub_block_writes
Samuel Just [Mon, 30 Jul 2012 20:36:39 +0000 (13:36 -0700)]
ReplicatedPG::snap_trimmer: requeue if scrub_block_writes

Otherwise, we do not continue snap_trimming once scrub is
complete.

Noticed while revewing another patch.  This would result
in snaps not being trimmed again until the next map
update.

Signed-off-by: Samuel Just <sam.just@inktank.com>
13 years agoMerge branch 'wip-osd'
Sage Weil [Mon, 30 Jul 2012 17:49:44 +0000 (10:49 -0700)]
Merge branch 'wip-osd'

Reviewed-by: Samuel Just <sam.just@inktank.com>
13 years agoosd: initialize send_notify on pg load
Sage Weil [Sat, 28 Jul 2012 16:19:03 +0000 (09:19 -0700)]
osd: initialize send_notify on pg load

When the PG is loaded, we need to set send_notify if we are not the
primary.  Otherwise, if the PG does not go through
start_peering_interval() or experience a role change, we will not set
the flag and tell the primary that we exist.  This can cause problems
for example if we have unfound objects that the primary needs, although
I'm sure there are other bad implications as well.

Fixes: #2866
Signed-off-by: Sage Weil <sage@inktank.com>
13 years agoosd: replace STRAY bit with bool
Sage Weil [Sat, 28 Jul 2012 16:17:34 +0000 (09:17 -0700)]
osd: replace STRAY bit with bool

We were setting a bit in pg->state that is private to the non-primary
PG.  The other bits get shared with the mon etc, but this one didn't.

Replace it with a simple bool.

Signed-off-by: Sage Weil <sage@inktank.com>
13 years agotest: test_keyvaluedb_iterators: Test KeyValueDB implementations iterators
Joao Eduardo Luis [Wed, 18 Jul 2012 21:26:29 +0000 (22:26 +0100)]
test: test_keyvaluedb_iterators: Test KeyValueDB implementations iterators

This set of tests focus on testing the expected behavior of LevelDBStore's
and KeyValueDBMemory's iterators.

We test a grand total of six use cases, each one with several test
units, being tested for both the LevelDBStore and the in-memory mock
(totalling 48 test units, plus two disabled by default):

 * Removing keys:
  - Using both the whole-space iterator and the whole-space snapshot
    iterator
  - Tests key removal while iterating the store, either by prefix or by
    removing specific (prefix,key) pairs

 * Setting keys:
  - Using both the whole-space iterator and the whole-space snapshot
    iterator
  - Tests key insertion while iterating the store
  - Tests value update while iterating the store
  - This use case has two disabled tests: one when setting keys, other
    when updating values, both on LevelDBStore and using the whole-space
    iterator; this is because they will fail, unlike when using the
    in-memory mock implementation, because leveldb implicitely creates
    an iterator that will read from a snapshot instead of directly from
    the underlying store.

 * Using Upper/Lower Bounds:
  - Using the whole-space iterator (we don't modify the store's state,
    so there is no need to also test the whole-space snapshot iterator)
  - Tests upper/lower bounds when the key, the prefix or both are empty
  - Tests upper/lower bounds when both the key and the prefix are set

 * Seeking:
  - Using the whole-space iterator (we don't modify the store's state,
    so there is no need to also test the whole-space snapshot iterator)
  - Tests seeking to first and to last
  - Tests seeking to first and to last using a prefix

 * Key-Space Iteration:
  - Using the whole-space iterator (we don't modify the store's state,
    so there is no need to also test the whole-space snapshot iterator)
  - Tests forward and backward iteration over the key-space

 * Empty Store:
  - Using the whole-space iterator (we don't modify the store's state,
    so there is no need to also test the whole-space snapshot iterator)
  - Tests seeking and using bounds functions when the store is empty

Signed-off-by: Joao Eduardo Luis <joao.luis@inktank.com>
13 years agoos: KeyValueDB: implement snapshot iterators
Joao Eduardo Luis [Mon, 23 Jul 2012 10:56:50 +0000 (11:56 +0100)]
os: KeyValueDB: implement snapshot iterators

Create a set of functions, to be implemented by derivative classes of
KeyValueDB, responsible for returning an iterator with strong
read-consistency guarantees. How this iterator is implemented, or by what
is it backed up, is implementation specific, but it must guarantee that
all reads made using this iterator are as if there were no subsequent
writes to the store since we created the iterator.

For instance, LevelDBStore will back this iterator with a leveldb Snapshot,
while KeyValueDBMemory will perform a copy of its in-memory map.

Signed-off-by: Joao Eduardo Luis <joao.luis@inktank.com>
13 years agoos: KeyValueDB: re-implement (prefix) iter in terms of whole-space iter
Joao Eduardo Luis [Mon, 23 Jul 2012 10:47:00 +0000 (11:47 +0100)]
os: KeyValueDB: re-implement (prefix) iter in terms of whole-space iter

In-a-nutshell-version: Create a whole-space iterator interface, and
implement the already existing, prefix-based iterator in terms of the
new whole-space iterator;

This patch introduces a significant change on the architecture of
KeyValueDB's iterator, although its interface remains the same.

Before this patch, KeyValueDB simply defined an interface for a
prefix-based interface, to be implemented by derivative classes. Being
constrained by a prefix-based approach to iterate over the store only makes
sense when we know which prefixes we want to iterate over, but for that we
must know about the prefixes beforehand. This approach didn't work when one
wanted to iterate over the whole key space, without any previous awareness
about the keys and their prefixes.

This patch introduces a new interface for a whole-space iterator, to be
implemented by derivative classes, which is prefix-independent. We also
define an abstract function to obtain this iterator, which must also be
implemented by the derivative class. With this interface in place, we are
then able to implement a prefix-dependent iterator in terms of the
whole-space iterator, which will be offered by the KeyValueDB class itself.

Furthermore, we implement these changes on LevelDBStore and KeyValueDBMemory,
the in-memory mock store, which leads to significant changes on both:

  * LevelDBStore
    - Substitute the previously existing LevelDBIteratorImpl, which
      followed a prefix-based iteration, for
      LevelDBWholeSpaceIteratorImpl, which now iterates over the whole
      key space of the store;

  * KeyValueDBMemory:
    - Substitute the previously existing MemIterator, which followed a
      prefix-based iteration, for WholeSpaceMemIterator, which now
      iterates over the whole key space of the in-memory mock store;
    - Change the in-memory mock store data structure. Previously, we
      used a map-of-maps, mapping prefixes to a key/value map; now we
      keep a single map, mapping (prefix,key) pairs to values.

Signed-off-by: Joao Eduardo Luis <joao.luis@inktank.com>
13 years agotest: workloadgen: Don't linearly iterate over a map to obtain a collection
Joao Eduardo Luis [Tue, 24 Jul 2012 20:53:20 +0000 (21:53 +0100)]
test: workloadgen: Don't linearly iterate over a map to obtain a collection

We were iterating over the collections map a certain amount of times, in
order to obtain the collection in that position. To avoid this kind of
behavior in a function that may be called a large amount of times, and
that may iterate over a rather large map, we now keep the collection ids
in a vector. In order to obtain a given collection on position X, we will
simply look for the collection id on position X of the vector, and then
obtain the collection from the map using its collection id.

Signed-off-by: Joao Eduardo Luis <joao.luis@inktank.com>
13 years agoosd: peering: make Incomplete a Peering substate
Sage Weil [Fri, 27 Jul 2012 23:03:26 +0000 (16:03 -0700)]
osd: peering: make Incomplete a Peering substate

This allows us to still catch changes in the prior set that would affect
our conclusions (that we are incomplete) and, when they happen, restart
peering.

Consider:
 - calc prior set, osd A is down
 - query everyone else, no good info
 - set down, go to Incomplete (previously WaitActingChange) state.
 - osd A comes back up (we do nothing)
 - osd A sends notify message with good info (we ignore)

By making this a Peering substate, we catch the Peering AdvMap reaction,
which will notice a prior set down osd is now up and move to Reset.

Fixes: #2860
Signed-off-by: Sage Weil <sage@inktank.com>
13 years agoosd: peering: move to Incomplete when.. incomplete
Sage Weil [Fri, 27 Jul 2012 22:39:40 +0000 (15:39 -0700)]
osd: peering: move to Incomplete when.. incomplete

PG::choose_acting() may return false and *not* request an acting set change
if it can't find any suitable peers with enough info to recover.  In that
case, we should move to Incomplete, not WaitActingChange, just like we do
a bit lower in GetLog() if we have non-contiguous logs.  The state name is
more accurate, and this is also needed to fix bug #2860.

Signed-off-by: Sage Weil <sage@inktank.com>
13 years agoMerge remote-tracking branch 'gh/wip-msgr-masterbits'
Sage Weil [Sat, 28 Jul 2012 14:21:05 +0000 (07:21 -0700)]
Merge remote-tracking branch 'gh/wip-msgr-masterbits'

Reviewed-by: Greg Farnum <greg@inktank.com>
13 years agoconfig: send warnings to a ostream* argument
Sage Weil [Sat, 28 Jul 2012 14:39:27 +0000 (07:39 -0700)]
config: send warnings to a ostream* argument

We shouldn't always send these to stderr.  (Among other things, the
warning: prefix breaks the gitbuilder error detection.)

Signed-off-by: Sage Weil <sage@inktank.com>
13 years agovstart.sh: apply extra conf after the defaults
Sage Weil [Fri, 27 Jul 2012 21:28:04 +0000 (14:28 -0700)]
vstart.sh: apply extra conf after the defaults

This let's you do e.g., -o 'debug ms = 100' and it will apply after
the default logging levels.

Signed-off-by: Sage Weil <sage@inktank.com>
13 years agoconf: make dup lines override previous value
Sage Weil [Fri, 20 Jul 2012 15:55:21 +0000 (08:55 -0700)]
conf: make dup lines override previous value

If you put

[some section]
 foo = 1
 ...
 foo = 2

in a .conf file, make the second key override the first.

Generate a warning if a value is overridden to sidestep some user hangbanging.

Signed-off-by: Sage Weil <sage@inktank.com>
13 years agomon: remove superfluous "can't delete except on master" comments
Sage Weil [Mon, 23 Jul 2012 21:39:10 +0000 (14:39 -0700)]
mon: remove superfluous "can't delete except on master" comments

That's what 'return false' means for preprocess_*().

Signed-off-by: Sage Weil <sage@inktank.com>
13 years agomon: make pool snap creation ops idempotent
Sage Weil [Mon, 23 Jul 2012 23:04:00 +0000 (16:04 -0700)]
mon: make pool snap creation ops idempotent

Return 0 if the snap already exists, or is already deleted.

Also, avoid updating the pg_pool if we are just waiting for the current
round to commit.

Signed-off-by: Sage Weil <sage@inktank.com>
13 years agoobjecter: return ENOENT/EEXIST on pool snap delete/create
Sage Weil [Mon, 23 Jul 2012 23:01:14 +0000 (16:01 -0700)]
objecter: return ENOENT/EEXIST on pool snap delete/create

Do these checks on the client to mask monitor idempotency from the user.

Signed-off-by: Sage Weil <sage@inktank.com>
13 years agolibrados: make snap create/destroy handle client-side errors
Sage Weil [Mon, 23 Jul 2012 23:29:07 +0000 (16:29 -0700)]
librados: make snap create/destroy handle client-side errors

Signed-off-by: Sage Weil <sage@inktank.com>
13 years agomon: check for invalid pool snap creates in preprocess_op, too
Sage Weil [Fri, 20 Jul 2012 00:35:57 +0000 (17:35 -0700)]
mon: check for invalid pool snap creates in preprocess_op, too

This avoids waiting for a paxos commit just to return an error.

Signed-off-by: Sage Weil <sage@inktank.com>
13 years agoqa: simple tests for 'ceph osd create|rm' commands
Sage Weil [Fri, 20 Jul 2012 05:04:29 +0000 (22:04 -0700)]
qa: simple tests for 'ceph osd create|rm' commands

Signed-off-by: Sage Weil <sage@inktank.com>
13 years agomon: make 'osd rm ...' idempotent
Sage Weil [Fri, 20 Jul 2012 00:10:57 +0000 (17:10 -0700)]
mon: make 'osd rm ...' idempotent

Signed-off-by: Sage Weil <sage@inktank.com>
13 years agoqa: simple test for pool create/delete commands
Sage Weil [Fri, 20 Jul 2012 04:56:56 +0000 (21:56 -0700)]
qa: simple test for pool create/delete commands

Signed-off-by: Sage Weil <sage@inktank.com>
13 years agomon: make pool creation idempotent
Sage Weil [Mon, 23 Jul 2012 23:03:46 +0000 (16:03 -0700)]
mon: make pool creation idempotent

Return success if the pool already exists.  Part of #2638.

Also, fix this so we wait until a creating pool is created before we reply.

Signed-off-by: Sage Weil <sage@inktank.com>
13 years agomon: make pool removal idempotent
Sage Weil [Mon, 23 Jul 2012 23:03:36 +0000 (16:03 -0700)]
mon: make pool removal idempotent

Return success if pool does not exist.  Part of #2638.

Signed-off-by: Sage Weil <sage@inktank.com>
13 years agoobjecter: make pool create/delete return EEXIST/ENOENT
Sage Weil [Mon, 23 Jul 2012 22:37:06 +0000 (15:37 -0700)]
objecter: make pool create/delete return EEXIST/ENOENT

Do these checks on the client side to mask monitor idempotency from
the user.

Signed-off-by: Sage Weil <sage@inktank.com>
13 years agolibrados: make pool create/destroy handle client-side errors
Sage Weil [Mon, 23 Jul 2012 23:23:20 +0000 (16:23 -0700)]
librados: make pool create/destroy handle client-side errors

Add tests!

Signed-off-by: Sage Weil <sage@inktank.com>
13 years agoobjecter: fix mon command resends
Sage Weil [Mon, 23 Jul 2012 21:41:17 +0000 (14:41 -0700)]
objecter: fix mon command resends

The monitor session is lossy.  Send these when the op is initiated, or
when we reconnect.  The timeout/cutoff was preventing ops from getting
resent if there was an ill-timed mon reset.

Backport: testing, stable/argonaut
Signed-off-by: Sage Weil <sage@inktank.com>
13 years agomutex: assert we are unlocked by the same thread that locked
Sage Weil [Tue, 17 Jul 2012 20:52:57 +0000 (13:52 -0700)]
mutex: assert we are unlocked by the same thread that locked

This only works for non-recursive locks.  (Which is probably all of them?)

Signed-off-by: Sage Weil <sage@inktank.com>
13 years agocond: reorder asserts
Sage Weil [Tue, 17 Jul 2012 20:52:00 +0000 (13:52 -0700)]
cond: reorder asserts

Make the more specific checks assert before the less specific ones, so we
are more likely to crash with useful information.

Signed-off-by: Sage Weil <sage@inktank.com>
13 years agoosd: fixing sharing of past_intervals on backfill restart
Sage Weil [Thu, 26 Jul 2012 23:35:00 +0000 (16:35 -0700)]
osd: fixing sharing of past_intervals on backfill restart

We need to share past_intervals whenever we instantiate the PG on a peer.
In the PG activation case, this is based on whether our peer_info[] value
for that peer is dne().  However, the backfill code was updating the
peer info (history) in the block preceeding the dne() check, which meant
we never shared past_intervals in this case and the peer would have to
chew through a potentially large number of maps if the PG has not been
clean recently.

Fix by checking dne() prior to the backfill block.  We still need to fill
in the message later because it isn't yet instantiated.

Fixes: #2849
Signed-off-by: Sage Weil <sage@inktank.com>
Reviewed-by: Yehuda Sadeh <yehuda@inktank.com>
13 years agofilestore: check for EIO in read path
Sage Weil [Fri, 27 Jul 2012 04:55:00 +0000 (21:55 -0700)]
filestore: check for EIO in read path

Check for EIO in read methods and helpers.  Try to do checks in low-level
methods (e.g., lfn_*()) to avoid duplication in higher-level methods.

The transaction apply function already checks for EIO on writes, and will
generate a nicer error message, so we can largely ignore the write path,
as long as errors get passed up correctly.

Signed-off-by: Sage Weil <sage@inktank.com>
Reviewed-by: Yehuda Sadeh <yehuda@inktank.com>
13 years agofilestore: add 'filestore fail eio' option, default true
Sage Weil [Thu, 26 Jul 2012 16:07:46 +0000 (09:07 -0700)]
filestore: add 'filestore fail eio' option, default true

By default we will assert/fail/crash on EIO from the underlying fs.  We
already do this in the write path, but not the read path, or in various
internal infrastructure.

Signed-off-by: Sage Weil <sage@inktank.com>
Conflicts:

src/os/FileStore.cc

13 years agolibrbd: fix id initialization in new format
Josh Durgin [Thu, 26 Jul 2012 22:27:49 +0000 (15:27 -0700)]
librbd: fix id initialization in new format

48bd839b1e25b063c675416a8f6233463f1af115 should have included this.
I misread it due to the use of bid instead of id when generating
the object prefix.

Signed-off-by: Josh Durgin <josh.durgin@inktank.com>
13 years agolibrbd: fix id initialization in new format
Josh Durgin [Thu, 26 Jul 2012 22:27:49 +0000 (15:27 -0700)]
librbd: fix id initialization in new format

48bd839b1e25b063c675416a8f6233463f1af115 should have included this.
I misread it due to the use of bid instead of id when generating
the object prefix.

Signed-off-by: Josh Durgin <josh.durgin@inktank.com>
13 years agomon: set a configurable max osd cap
Yehuda Sadeh [Thu, 26 Jul 2012 20:14:40 +0000 (13:14 -0700)]
mon: set a configurable max osd cap

Don't allow setting a higher osd num through the
ceph control util.

Fixes: #2752
Signed-off-by: Yehuda Sadeh <yehuda@inktank.com>
13 years agodoc: updates to fix problem with ceph-cookbooks appearing in chef-server.
John Wilkins [Wed, 25 Jul 2012 22:57:58 +0000 (15:57 -0700)]
doc: updates to fix problem with ceph-cookbooks appearing in chef-server.

Signed-off-by: John Wilkins <john.wilkins@inktank.com>
13 years agoosd: generate past intervals in parallel on boot
Sage Weil [Wed, 25 Jul 2012 17:57:35 +0000 (10:57 -0700)]
osd: generate past intervals in parallel on boot

Even though we aggressively share past_intervals with notifies etc, it is
still possible for an osd to get buried behind a pile of old maps and need
to generate these if it has been out of the cluster for a while.  This has
happened to us in the past but, sadly, we did not merge the work then.
On the bright side, this implementation is much much much cleaner than the
old one because of the pg_interval_t helper we've since switched to.

On bootup, we look at the intervals each pg needs and calclate the union,
and then iterate over that map range.  The inner bit of the loop is
functionally identical to PG::build_past_intervals(), keeping the per-pg
state in the pistate struct.

Backport: argonaut
Signed-off-by: Sage Weil <sage@inktank.com>
Reviewed-by: Yehuda Sadeh <yehuda@inktank.com>
Reviewed-by: Josh Durgin <josh.durgin@inktank.com>
13 years agoosd: move calculation of past_interval range into helper
Sage Weil [Wed, 25 Jul 2012 17:58:07 +0000 (10:58 -0700)]
osd: move calculation of past_interval range into helper

PG::generate_past_intervals() first calculates the range over which it
needs to generate past intervals.  Do this in a helper function.

Signed-off-by: Sage Weil <sage@inktank.com>
Reviewed-by: Yehuda Sadeh <yehuda@inktank.com>
Reviewed-by: Josh Durgin <josh.durgin@inktank.com>
Conflicts:

src/osd/PG.cc