Sage Weil
bdf405cd02
todos
2009-01-23 16:47:21 -08:00
Sage Weil
9a63cb13be
paxos: ignore LAST message if pn is old
...
And old PN means that it's from a prior COLLECT attempt.
2009-01-23 16:47:21 -08:00
Sage Weil
6e2728eb9c
mds: increase ino prealloc limit to 1000
...
Ideally this should self-tune, somehow...
2009-01-23 16:44:42 -08:00
Sage Weil
4df3be7ed1
osd: remove RepGather::put() debug print
2009-01-23 16:44:41 -08:00
Sage Weil
fd55dc6ad6
crush: remote list builder printf
2009-01-23 16:44:40 -08:00
Sage Weil
d3591be52b
dstart: mount btrfs with new options
2009-01-23 16:44:40 -08:00
Sage Weil
cfdd83d741
kclient: statfs_request_tree alloc context is NOFS, not ATOMIC
2009-01-23 16:43:09 -08:00
Yehuda Sadeh
59369fb9c4
config: added include, misc stuff
2009-01-23 15:37:12 -08:00
Sage Weil
c4760afe68
kclient: do sync writepages if FILE_WRBUFFER is being revoked
...
This doesn't capture the case where we already started writeout
and _then_ the MDS tries to revoke, but that's probably not worth
the complexity.
2009-01-23 14:50:13 -08:00
Sage Weil
26cac11150
mds: fix max_size update
...
Force wrlock if client is issued WR cap; whether they are flushing
dirty data is irrelevant to whether we can safely force a wrlock.
2009-01-23 14:40:26 -08:00
Sage Weil
311d3a49ff
kclient: initiate a sync when doing writepages for O_SYNC writers
...
Include 'startsync' osd op in write if there are any O_SYNC writers
pending on the inode.
We should eventually do the same if our WRBUFFER cap is being
revoked.
2009-01-23 14:18:16 -08:00
Sage Weil
63c2e9ea49
mds: set straydn.first properly for rename overwrite
...
Also reorder unlink_local a bit to match rename_prepare pattern.
2009-01-23 13:43:17 -08:00
Sage Weil
8239bedecc
mds: only update cap wanted if seq matches
2009-01-23 13:23:22 -08:00
Sage Weil
37348a1a79
kclient: fix osd writes
...
Fixes commit 9664adfcb2
.
2009-01-23 12:52:19 -08:00
Sage Weil
a4a1d5424f
mds: take straydn.first form inode.first during unlink
2009-01-23 12:43:14 -08:00
Sage Weil
9664adfcb2
kclient: resend osd ops when pg membership changes
...
Previously we resent only when the primary OSD changed. See
f49f78d03b
.
2009-01-23 12:43:14 -08:00
Yehuda Sadeh
46696ade9c
config: read configuration file before parsing command line
...
also does not write configuration unless specified
2009-01-23 12:40:16 -08:00
Yehuda Sadeh
a92400c82f
mount.ceph: fix segfault when port is not specified
2009-01-23 12:38:29 -08:00
Yehuda Sadeh
b929f12baa
confutils: complete config.cc configuration and adjustments
2009-01-23 09:31:42 -08:00
Yehuda Sadeh
331d1c4c38
confutils: cleanup, bug fixes
2009-01-23 09:31:42 -08:00
Yehuda Sadeh
44550ae7d3
confutils: can flush config, preliminary config.cc integration
2009-01-23 09:31:42 -08:00
Yehuda Sadeh
0ba80f81b4
confutils: some cleanup
2009-01-23 09:31:42 -08:00
Yehuda Sadeh
78d12c824c
confutils: encoding/decoding using templates
2009-01-23 09:31:42 -08:00
Yehuda Sadeh
68a144514f
confutils: going forward
2009-01-23 09:31:42 -08:00
Yehuda Sadeh
1acf016c51
confutils: adding missing file
2009-01-23 09:31:42 -08:00
Yehuda Sadeh
1481960516
confutils: some more
...
Signed-off-by: Yehuda Sadeh <yehuda@hq.newdream.net>
2009-01-23 09:31:42 -08:00
Yehuda Sadeh
9a103e5b76
confutils: some more changes
...
Signed-off-by: Yehuda Sadeh <yehuda@hq.newdream.net>
2009-01-23 09:31:42 -08:00
Yehuda Sadeh
dbc6141999
config: some more changes
...
Signed-off-by: Yehuda Sadeh <yehuda@hq.newdream.net>
2009-01-23 09:31:42 -08:00
Yehuda Sadeh
18fdf6ea1c
confutils: still not usable
2009-01-23 09:31:42 -08:00
Sage Weil
0af200da88
config: remove some old cruft
2009-01-22 16:17:04 -08:00
Sage Weil
f49f78d03b
osd: reset peering, in-flight repops on every pg change
...
Instead of complicated (and flawed) logic for letting in-progress rep ops
complete while the PG changes (but primary remains the same), reset the
pg state entirely. Apply any ops we have in hand, but drop everything
else, including PUSH/PULL ops.
This vastly simplifies the logic in the OSD and makes it easy to reason
about things.
Fix clients (Objecter, osd_client) to resubmit ops when PG membership
changes (not just on primary change).
2009-01-22 16:14:52 -08:00
Sage Weil
4b224b9b8d
mds: eval_cap_gather in handle_client_caps even if no update
...
We may have recalled caps and journaled an update for some but
not all locks. We should check for cap gathers even if something
(else) is journaled.
2009-01-22 11:22:04 -08:00
Sage Weil
2564622a32
script: find high latency requests in mds log
2009-01-22 11:04:54 -08:00
Sage Weil
4c75e0a8b7
mds: fix xattr projection
2009-01-21 16:44:21 -08:00
Sage Weil
1c2d62486f
mds: drop rdlocks _after_ journaling; use new journal_and_reply helper
...
If we drop locks earlier we may run contexts that journal _other_
items out of order. Badness.
2009-01-21 16:23:00 -08:00
Sage Weil
0c6ffaa905
mds: make cdentry debug print nicer
2009-01-21 15:34:47 -08:00
Sage Weil
004898a73e
mds: unique (per mds) cap_id
...
A new cap_id is issued each time an MDS creates a new capability,
and is checked when releasing a capability to ensure it is the same
capability instance. This specifically avoids a race like:
1- mds issues cap
2- mds sends cap message
3- mds and client time out cap
4- client receives cap message, sends release
5- mds reissues cap on same inode
6- mds receives release, doesn't realize the release is for the
old capability
Checking seq numbers isn't enough because the MDS may reissue the
cap any number of times between 3 and 6.
2009-01-21 15:34:31 -08:00
Sage Weil
62e5b801bc
mds: set straydn.first correctly during unlink
...
We need to do this in _unlink_local, not get_or_create_stray, just
as we set dn->first elsewhere in Server.cc.
2009-01-21 14:52:38 -08:00
Sage Weil
10943447a5
mds: make straydn.first match the inode
2009-01-21 11:47:04 -08:00
Sage Weil
7a0abc3776
uclient: flush/release buffered data on umount
2009-01-21 10:42:57 -08:00
Sage Weil
74f2a9c88d
uclient: update caps code to match kclient logic
2009-01-21 10:38:06 -08:00
Sage Weil
33f44435fd
kclient: some caps cleanup
2009-01-21 10:37:26 -08:00
Sage Weil
001771274b
kclient: improve snap locking scheme
...
Because snap_rwsem is taken for read on every write, we want to
minimize contention. We:
- allow cap removal to occur without snap_rwsem (read or write)
- allow fill_trace and add_cap with snap_rwsem (read)
- require write really only for update_snap_trace and on snap
updates from the mds.
Dropping realm references without snap_rwsem gets a bit tricky. We
keep an empty (nref==0) realm list and purge it periodically to
avoid contention in the general case.
2009-01-20 16:35:43 -08:00
Sage Weil
a4c752df71
v0.6
2009-01-20 11:52:50 -08:00
Sage Weil
584f8311a6
Merge branch 'unstable'
2009-01-20 11:19:42 -08:00
Sage Weil
00577b5441
kclient: rename lookup_mds_session get_mds_session
...
Since it bumps the ref count.
2009-01-20 11:08:23 -08:00
Yehuda Sadeh
b078856cd5
kclient: realm create does not take a ref count
2009-01-20 11:04:25 -08:00
Yehuda Sadeh
70365be770
kclient: split get_snap_realm to lookup and create
2009-01-20 10:52:04 -08:00
Sage Weil
c784a5431a
objectcacher: fix object trimming
...
Do not trim object until it fully commits.
2009-01-19 17:03:05 -08:00
Sage Weil
26cec48ebb
mds: count in-flight updates per cap, not release attempts. do not expire if updating.
2009-01-19 17:02:02 -08:00