<div dir="ltr">Hi, <br><br>In Portland, we discussed a somewhat related issue of having multiple replication levels in one Swift cluster. <br>It may be that a provider would not wish to expose the use of EC or the level of replication used. For example a provider may offer a predefined set of services such as "Gold", "Silver" and "Bronze", "Aluminum" which a user can choose from. The provider may decide how each level is implemented (As a silly example: Gold is 4 way replication, Silver is a 3 way replication, Bronze is EC, Aluminum is single replica without EC). <br>
<br>Does it make sense to consider EC as an implementation of a certain service level (the same as for example the choice of the number of replicas)? <br><br>Now we are back to the question of what is the right unit in which we define this 'level of service' ("Gold", "Silver"...).<br>
Should the level of service be defined when the account is created or should we allow a user to state:<br>"I would like to have a container with Gold to keep my work, Bronze to keep my family pictures and videos and Aluminum to keep a copy of all my music files".<br>
<br>If we choose to enable container service levels, we need to enable billing per level of service such that a single account could be billed for the actual use it has done per each level of service. Maybe we even need to have all statistics gathered to be grouped by service level.<br>
I am not sure if we can escape that even with account service levels. <br><br>DH<br><br><div class="gmail_quote">On Thu, Jul 18, 2013 at 9:37 PM, John Dickinson <span dir="ltr"><<a href="mailto:me@not.mn" target="_blank">me@not.mn</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Yes, and I'd imagine that the normal default would be for replicated data.<br>
<br>
Moving the granularity from a container to account-based, as Chmouel and Chuck said, is interesting too.<br>
<span class="HOEnZb"><font color="#888888"><br>
--John<br>
</font></span><div class="HOEnZb"><div class="h5"><br>
On Jul 18, 2013, at 11:32 AM, Christian Schwede <<a href="mailto:info@cschwede.de">info@cschwede.de</a>> wrote:<br>
<br>
> A solution to this might be to set the default policy as a configuration<br>
> setting in the proxy. If you want a replicated swift cluster just allow<br>
> this policy in the proxy and set it to default. The same for EC cluster,<br>
> just set the allowed policy to EC. If you want both (and let your users<br>
> decide which policy to use) simply configure a list of allowed policies<br>
> with the first one in the list as the default policy in case they don't<br>
> set a policy during container creation.<br>
><br>
> Am 18.07.13 20:15, schrieb Chuck Thier:<br>
>> I think you are missing the point.  What I'm talking about is who<br>
>> chooses what data is EC and what is not.  The point that I am trying to<br>
>> make is that the operators of swift clusters should decide what data is<br>
>> EC, not the clients/users.  How the data is stored should be totally<br>
>> transparent to the user.<br>
>><br>
>> Now if we want to down the road offer user defined classes of storage<br>
>> (like how S3 does reduced redundancy), I'm cool with that, just that it<br>
>> should be orthogonal to the implementation of EC.<br>
>><br>
>> --<br>
>> Chuck<br>
>><br>
>><br>
>> On Thu, Jul 18, 2013 at 12:57 PM, John Dickinson <<a href="mailto:me@not.mn">me@not.mn</a><br>
>> <mailto:<a href="mailto:me@not.mn">me@not.mn</a>>> wrote:<br>
>><br>
>>    Are you talking about the parameters for EC or the fact that<br>
>>    something is erasure coded vs replicated?<br>
>><br>
>>    For the first, that's exactly what we're thinking: a deployer sets<br>
>>    up one (or more) policies and calls them Alice, Bob, or whatever,<br>
>>    and then the API client can set that on a particular container.<br>
>><br>
>>    This allows users who know what they are doing (ie those who know<br>
>>    the tradeoffs and their data characteristics) to make good choices.<br>
>>    It also allows deployers who want to have an automatic policy to set<br>
>>    one up to migrate data.<br>
>><br>
>>    For example, a deployer may choose to run a migrator process that<br>
>>    moved certain data from replicated to EC containers over time (and<br>
>>    drops a manifest file in the replicated tier to point to the EC data<br>
>>    so that the URL still works).<br>
>><br>
>>    Like existing features in Swift (eg large objects), this gives users<br>
>>    the ability to flexibly store their data with a nice interface yet<br>
>>    still have the ability to get at some of the pokey bits underneath.<br>
>><br>
>>    --John<br>
>><br>
>><br>
>><br>
>>    On Jul 18, 2013, at 10:31 AM, Chuck Thier <<a href="mailto:cthier@gmail.com">cthier@gmail.com</a><br>
>>    <mailto:<a href="mailto:cthier@gmail.com">cthier@gmail.com</a>>> wrote:<br>
>><br>
>>> I'm with Chmouel though.  It seems to me that EC policy should be<br>
>>    chosen by the provider and not the client.  For public storage<br>
>>    clouds, I don't think you can make the assumption that all<br>
>>    users/clients will understand the storage/latency tradeoffs and<br>
>>    benefits.<br>
>>><br>
>>><br>
>>> On Thu, Jul 18, 2013 at 8:11 AM, John Dickinson <<a href="mailto:me@not.mn">me@not.mn</a><br>
>>    <mailto:<a href="mailto:me@not.mn">me@not.mn</a>>> wrote:<br>
>>> Check out the slides I linked. The plan is to enable an EC policy<br>
>>    that is then set on a container. A cluster may have a replication<br>
>>    policy and one or more EC policies. Then the user will be able to<br>
>>    choose the policy for a particular container.<br>
>>><br>
>>> --John<br>
>>><br>
>>><br>
>>><br>
>>><br>
>>> On Jul 18, 2013, at 2:50 AM, Chmouel Boudjnah<br>
>>    <<a href="mailto:chmouel@enovance.com">chmouel@enovance.com</a> <mailto:<a href="mailto:chmouel@enovance.com">chmouel@enovance.com</a>>> wrote:<br>
>>><br>
>>>> On Thu, Jul 18, 2013 at 12:42 AM, John Dickinson <<a href="mailto:me@not.mn">me@not.mn</a><br>
>>    <mailto:<a href="mailto:me@not.mn">me@not.mn</a>>> wrote:<br>
>>>>>   * Erasure codes (vs replicas) will be set on a per-container<br>
>>    basis<br>
>>>><br>
>>>> I was wondering if there was any reasons why it couldn't be as<br>
>>>> per-account basis as this would allow an operator to have different<br>
>>>> type of an account and different pricing (i.e: tiered storage).<br>
>>>><br>
>>>> Chmouel.<br>
>>><br>
>>><br>
>>> _______________________________________________<br>
>>> OpenStack-dev mailing list<br>
>>> <a href="mailto:OpenStack-dev@lists.openstack.org">OpenStack-dev@lists.openstack.org</a><br>
>>    <mailto:<a href="mailto:OpenStack-dev@lists.openstack.org">OpenStack-dev@lists.openstack.org</a>><br>
>>> <a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev" target="_blank">http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev</a><br>
>>><br>
>>><br>
>>> _______________________________________________<br>
>>> OpenStack-dev mailing list<br>
>>> <a href="mailto:OpenStack-dev@lists.openstack.org">OpenStack-dev@lists.openstack.org</a><br>
>>    <mailto:<a href="mailto:OpenStack-dev@lists.openstack.org">OpenStack-dev@lists.openstack.org</a>><br>
>>> <a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev" target="_blank">http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev</a><br>
>><br>
>><br>
>>    _______________________________________________<br>
>>    OpenStack-dev mailing list<br>
>>    <a href="mailto:OpenStack-dev@lists.openstack.org">OpenStack-dev@lists.openstack.org</a><br>
>>    <mailto:<a href="mailto:OpenStack-dev@lists.openstack.org">OpenStack-dev@lists.openstack.org</a>><br>
>>    <a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev" target="_blank">http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev</a><br>
>><br>
>><br>
>><br>
>><br>
>> _______________________________________________<br>
>> OpenStack-dev mailing list<br>
>> <a href="mailto:OpenStack-dev@lists.openstack.org">OpenStack-dev@lists.openstack.org</a><br>
>> <a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev" target="_blank">http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev</a><br>
>><br>
><br>
><br>
> _______________________________________________<br>
> OpenStack-dev mailing list<br>
> <a href="mailto:OpenStack-dev@lists.openstack.org">OpenStack-dev@lists.openstack.org</a><br>
> <a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev" target="_blank">http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev</a><br>
<br>
</div></div><br>_______________________________________________<br>
OpenStack-dev mailing list<br>
<a href="mailto:OpenStack-dev@lists.openstack.org">OpenStack-dev@lists.openstack.org</a><br>
<a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev" target="_blank">http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev</a><br>
<br></blockquote></div><br></div>