On 21 June 2017 at 23:50, Daniel Gryniewicz <dang@xxxxxxxxxx> wrote: >>> >> My original thinking was that when we reassign an object to a new >> placement, we only touch its tail which is incompatible with that. >> However, thinking about it some more I don't see why we need to have >> this limitation, so it's probably possible to keep the data in the >> head in one case, and modify the object and have the data in the tail >> (object's head will need to be rewritten anyway because we modify the >> manifest). >> I think that the decision whether we keep data in the head could be a >> property of the zone. Yes, I guess we also need to check the zone placement rule config when pull the realm in the multisite env, to make sure the sync peer has the same storage class support, multisite sync should also respect object storage class. >> In any case, once an object is created changing >> this property will only affect newly created objects, and old objects >> could still be read correctly. Having data in the head is an >> optimization that supposedly reduces small objects latency, and I >> still think it's useful in a mixed pools situation. The thought is >> that the bulk of the data will be at the tail anyway. However, we >> recently changed the default head size from 512k to 4M, so this might >> not be true any more. Anyhow, I favour having this as a configurable >> (which should be simple to add). >> >> Yehuda >> > > > I would be strongly against keeping data in the head when the head is in a > lower-level storage class. That means that the entire object is violating > the constraints of the storage class. Agreed. The default behavior of storage class require us to keep the data in the head as the same pool as the tail. Even if we made this as a configureable option, we should disable this kind of inline by default to match the default behavior of storage class. > > Of course, having the head in a lower storage class (data or not) is > probably a violation. Maybe we'd have to require that all heads go in the > highest storage class. > > Daniel On 21 June 2017 at 23:50, Daniel Gryniewicz <dang@xxxxxxxxxx> wrote: > On 06/21/2017 11:14 AM, Yehuda Sadeh-Weinraub wrote: >> >> On Wed, Jun 21, 2017 at 7:46 AM, Daniel Gryniewicz <dang@xxxxxxxxxx> >> wrote: >>> >>> On 06/21/2017 10:04 AM, Matt Benjamin wrote: >>>> >>>> >>>> Hi, >>>> >>>> Looks very coherent. >>>> >>>> My main question is about... >>>> >>>> ----- Original Message ----- >>>>> >>>>> >>>>> From: "Jiaying Ren" <mikulely@xxxxxxxxx> >>>>> To: "Yehuda Sadeh-Weinraub" <ysadehwe@xxxxxxxxxx> >>>>> Cc: "ceph-devel" <ceph-devel@xxxxxxxxxxxxxxx> >>>>> Sent: Wednesday, June 21, 2017 7:39:24 AM >>>>> Subject: RGW: Implement S3 storage class feature >>>>> >>>> >>>>> >>>>> * Todo List >>>>> >>>>> + the head of rgw-object should only contains the metadata of >>>>> rgw-object,the first chunk of rgw-object data should be stored in >>>>> the same pool as the tail of rgw-object >>>> >>>> >>>> >>>> Is this always desirable? >>>> >>> >>> Well, unless the head pool happens to have the correct storage class, >>> it's >>> necessary. And I'd guess that verification of this is complicated, >>> although >>> maybe not. >>> >>> Maybe we can use the head pool if it has >= the correct storage class? >>> >> My original thinking was that when we reassign an object to a new >> placement, we only touch its tail which is incompatible with that. >> However, thinking about it some more I don't see why we need to have >> this limitation, so it's probably possible to keep the data in the >> head in one case, and modify the object and have the data in the tail >> (object's head will need to be rewritten anyway because we modify the >> manifest). >> I think that the decision whether we keep data in the head could be a >> property of the zone. In any case, once an object is created changing >> this property will only affect newly created objects, and old objects >> could still be read correctly. Having data in the head is an >> optimization that supposedly reduces small objects latency, and I >> still think it's useful in a mixed pools situation. The thought is >> that the bulk of the data will be at the tail anyway. However, we >> recently changed the default head size from 512k to 4M, so this might >> not be true any more. Anyhow, I favour having this as a configurable >> (which should be simple to add). >> >> Yehuda >> > > > I would be strongly against keeping data in the head when the head is in a > lower-level storage class. That means that the entire object is violating > the constraints of the storage class. > > Of course, having the head in a lower storage class (data or not) is > probably a violation. Maybe we'd have to require that all heads go in the > highest storage class. > > Daniel -- To unsubscribe from this list: send the line "unsubscribe ceph-devel" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html