[Lustre-discuss] Performance Expectations of Lustre

Nick Jennings nick at creativemotiondesign.com
Mon Jan 26 11:36:02 PST 2009


Thank you very much for this feedback Balagopal, it's extremely useful. 
I will look into the MD1000 and revise my plan.
-Nick

Balagopal Pillai wrote:
> MD3000 series doesn't seem to have raid 6 support, which could be very 
> useful with lots of sata drives.
> Also MD3000i doesn't specify LACP support for the dual or quad Ethernet 
> ports on the enclosure. But
> a pe1950 + perc 6 with MD1000 has raid 6 support and the OSS can benefit 
> from good ethernet bonding support in Linux.
> I have a setup with eight MD1000s on two perc 5's on two OSS.
> 
> 
> Balagopal
> 
> Nick Jennings wrote:
>> Hi Brian! Thanks for the reply, comments below
>>
>> Brian J. Murrell wrote:
>>   
>>>>   Instead of just adding another 1TB server, I need to plan for a more 
>>>> scalable solution. Immediately Lustre came to mind, but I'm wondering 
>>>> about the performance. Basically our company does niche web-hosting for 
>>>> "Creative Professionals" so we need fast access to the data in order to 
>>>> have snappy web services for our clients. Typically these are smaller 
>>>> files (2MB pictures, 50MB videos, .swf files, etc.).
>>>>       
>>> Well, I'm not sure those files would fall within our general
>>> classification of "small files" (wherein we know we don't perform very
>>> well).  Our small-file issues are usually characterized by "kernel
>>> builds" and ~ use, where files are usually much smaller than 1MB.
>>>     
>>   Aha, OK well then that's good to know. There's also some kind of 
>> read-ahead and client side caching right? So files which are accessed a 
>> lot will be faster to access.
>>
>>
>>   
>>>>   Also I'm wondering about the best way set this up in terms of speed 
>>>> and ease of growth. I want the web-servers and the storage pool to be 
>>>> independent of each other. So I can add web-servers as the web traffic 
>>>> increases, and add more storage ass our storage needs grow.
>>>>       
>>> Well, your web-servers would be Lustre clients.  There is no
>>> relationship, or rather requirements in terms of the number of clients
>>> and servers being used.  You use as many servers as your client load
>>> demands.  So you could imagine both ends of the spectrum where only a
>>> relatively few clients could be used to tax quite a few servers or the
>>> opposite where a lot of clients with modest demand requires only a few
>>> servers.
>>>
>>>     
>>>>   I was thinking initially we could start with 2 servers, both attached 
>>>> to the storage array. setup as OSS' and functioning as (load balanced) 
>>>> web-servers as well.
>>>>       
>>> Sounds like you are describing 2 storage servers, which would require at
>>> least 3 servers total.  Don't forget about the MDS.  Also don't forget
>>> about HA if that's a concern for you.  You could make the 2 OSSes
>>> failover partners for each other if you are willing to accept a possibly
>>> lower performance impact when one of the OSSes failing.
>>>
>>> If HA is important to you however, you need to address an MDS failover
>>> with a second server to pick up the MDT should the active MDS fail.
>>>     
>> HA is definitely critical, if the storage pool becomes inaccessible we 
>> loose clients (and all fingers point at me!). However, I need to find a 
>> reasonable balance between cost / scalability / performance. The idea 
>> would be to start small, with the simplest configuration, but allow for 
>> a lot of growth. In a years time, if we are using 5TB of data, we will 
>> be in a very good position financially and can afford a systems expansion.
>>
>> So for starters, what can I get away with here? 1 OSS, 1MDS & 1 Client 
>> node? Is it a smart thing to do to have the MDS and OSS share the same 
>> storage target (just a separate partition for the MDS)? What kind of 
>> system specs are advisable for each type (MDS, OSS & Client node) as far 
>> as RAM, CPU, disk configuration etc? Also, is it possible to add more 
>> OSS' to take over existing OSTs that another OSS was previously 
>> managing? ie. if I have the MD3000i split into 5x1TB volumes (5xOSTs), 
>> and the OSS is getting hammered, I set another OSS up and hand off 2 or 
>> 3 OSTs from the old OSS to the new one, and set it up as failover for 
>> the remaining OSTs. Do-able?
>>
>>
>>
>>   
>>> As for OSSes being web-servers, that would require the OSS/Webservers
>>> also be clients and that is an unsupported configuration due to the risk
>>> of deadlock due to memory pressure.  The recommended architecture would
>>> be to make the webservers Lustre clients.
>>>     
>> I see, so from the get-go I'm going to need an internal gigE network for 
>> OSS/Client communication.
>>
>>
>>   
>>>> performance can I expect, am I out of touch to expect something similar 
>>>> to a directly attached RAID array?
>>>>       
>>> I think our generally talked about numbers are something on the order of
>>> achieving 80% of the raw storage bandwidth (assuming a capable network
>>> and so on).  Maybe somebody who is closer to the benchmarking that we
>>> are constantly doing can comment further on how close-to-raw-disk we are
>>> achieving lately.
>>>     
>> Is it safe to say my bottleneck is going to be the OSS & not the 
>> network? Is there some documentation I can read about typical setups, 
>> usage cases & methods for optimal performance?
>>
>> Thanks!
>> -Nick
>> _______________________________________________
>> Lustre-discuss mailing list
>> Lustre-discuss at lists.lustre.org
>> http://lists.lustre.org/mailman/listinfo/lustre-discuss
>>   
> _______________________________________________
> Lustre-discuss mailing list
> Lustre-discuss at lists.lustre.org
> http://lists.lustre.org/mailman/listinfo/lustre-discuss



More information about the lustre-discuss mailing list