[Lustre-devel] [HPDD-discuss] Removal of SOM code
andreas.dilger at intel.com
Sat Feb 7 17:56:18 PST 2015
On 2015/02/06, 5:08 PM, "Meghan McClelland"
<meghan.mcclelland at seagate.com> wrote:
>Oh no! I had just been talking about using this feature :(
>Even in it's current form which I agree isn't ideal, I think it could
>be helpful for a project like fssstats. Fsstats was an open effort to
>gather and collect filesystems data (see
>http://www.pdsi-scidac.org/fsstats/). It has unfortunately somewhat
>died off due to loss of funding, but I think was a good idea that
>helped the community, especially researchers.
Meghan, I am also a fan of fsstats, though I'm not sure how that is
related to this change, unless you had some mechanism to fetch the stats
directly from the MDT?
>I'd really like to try and revive the open data initiative, and saw
>som as a possible avenue to start collecting the data.
Ah, so you would fetch the stats directly from the MDT?
> I don't think statahead will provide the information needed but haven't
>had a chance to look at it.
It would be possible to store a "lazy size on the MDS", which is updated
on a best-effort basis (and could be repaired in the background by LFSCK).
This would be sufficient for most operations like filesystem stats, purge
policies, etc. since it won't matter one way or the other in a histogram
if the size of some files is off by a few KB, but that matters a great
deal for reading the data.
Implementing a "lazy size on MDS" would be pretty straight forward I think
- the client just sends its current file size at close time, and the MDS
picks the largest one (as it does with atimes). If there is a truncate
the MDS will get an RPC for this also, so the only risk is during a crash
and that can be fixed up by LFSCK.
The main difference with the current SOM code is that it wouldn't have any
complexity during recovery, and it doesn't need to care too much if the
client crashed or was later evicted by an OST before it wrote all the data
>On Fri, Feb 6, 2015 at 3:33 PM, Dilger, Andreas
><andreas.dilger at intel.com> wrote:
>> The Size on MDT (SOM) feature has been in a prototype state for several
>> years, with no signs of moving beyond this prototype stage.
>> Several problems exist in the code today, primarily that recovery is not
>> really implemented, yet the existing code adds complexity on the clients
>> and servers. Without proper recovery, the current code risks file data
>> loss if the SOM data isn't updated on the MDS consistently with data
>> writes to the OST.
>> We're planning to remove the SOM code from the master branch as a
>> tracked under
>> Some of the performance improvements of SOM have been implemented by
>> I think a case could be made for a very stripped down SOM to be
>> implemented in the future, that only deals with single-client writers
>> synchronously invalidates the file size on open-for-write, which isn't
>> bad with flash storage for the MDT as is typical today. The size of
>> that do not get set at initial write or are invalidated by an open can
>> updated asynchronously by LFSCK doing a periodic scan in the background.
>> Since this stripped-down implementation would have very little to do
>> the current implementation, there isn't much benefit to even trying to
>> the current code in place.
>> I definitely prefer presenting about new features going into Lustre,
>> also think it is important that people are aware when a semi-feature
>> this is being removed. I don't believe that anyone is actually using
>> feature today, and the reduction in code maintenance and complexity will
>> help both ongoing maintenance and bug fixing, as well as make it a that
>> much easier for new developers to understand the code.
>> Cheers, Andreas
>> Andreas Dilger
>> Lustre Software Architect
>> Intel High Performance Data Division
>> HPDD-discuss mailing list
>> HPDD-discuss at lists.01.org
>Meghan McClelland · Senior Product Manager
>Seagate Technology, LLC
>mobile: +1 (505) 695 0065
Lustre Software Architect
Intel High Performance Data Division
More information about the lustre-devel