[Engine-devel] What type of DB inheritance to use?

Itamar Heim iheim at redhat.com
Mon May 13 06:29:05 UTC 2013


On 05/13/2013 09:27 AM, Mike Kolesnik wrote:
> ----- Original Message -----
>> On 05/13/2013 08:33 AM, Mike Kolesnik wrote:
>>> ----- Original Message -----
>>>> On 05/12/2013 04:31 PM, Mike Kolesnik wrote:
>>>>>
>>>>> ----- Original Message -----
>>>>>> On 05/12/2013 03:16 PM, Mike Kolesnik wrote:
>>>>>>> ----- Original Message -----
>>>>>>>> On 05/12/2013 12:42 PM, Mike Kolesnik wrote:
>>>>>>>>> Hi All,
>>>>>>>>>
>>>>>>>>> I would like to have your opinions on which inheritance type to use
>>>>>>>>> in
>>>>>>>>> the DB.
>>>>>>>>> We are adding an "external provider" entity to the system which will
>>>>>>>>> be
>>>>>>>>> able to provide various resources (networks, hosts, etc).
>>>>>>>>>
>>>>>>>>> These providers will be distinguishable by "type".
>>>>>>>>> The basic definition of a provider contains:
>>>>>>>>>
>>>>>>>>>       * name
>>>>>>>>>       * description
>>>>>>>>>       * url
>>>>>>>>>       * type
>>>>>>>>>
>>>>>>>>> Some providers might need additional properties such as:
>>>>>>>>>
>>>>>>>>>       * user
>>>>>>>>>       * password
>>>>>>>>
>>>>>>>> what type of provider won't require authentication?
>>>>>>>
>>>>>>> Quantum provider in the 1st implementation will not require these
>>>>>>> fields.
>>>>>>> It will eventually require some sort of authentication, but not
>>>>>>> necessarily
>>>>>>> these fields, or only these fields.
>>>>>>
>>>>>> I'm not talking about a POC.
>>>>>> unless we pass through credentials of users for some actions, how do you
>>>>>> use a provider without user/password (or client cert, etc. - i.e., all
>>>>>> authentication methods are usually similar on the info you need to
>>>>>> persist)?
>>>>>
>>>>> I did not say that we will use Quantum without auth, only that these
>>>>> fields
>>>>> may or
>>>>> may not necessarily be in the Quantum provider entity.
>>>>>
>>>>> I think this is regardless of the main discussion here of inheritance,
>>>>> which I
>>>>> think will happen regardless of how Quantum provider is implemented. If
>>>>> you
>>>>> wish
>>>>> to discuss these details I'll be happy do it on a new thread, so that
>>>>> this
>>>>> one
>>>>> can stay focused on the subject of DB inheritance.
>>>>
>>>> how many discrepancies do we expect between the various providers, to be
>>>> actually defined at provider level rather than consumption level?
>>>
>>> I expect at least a few, there has to be some divergence.
>>>
>>> For instance, if we model Glance as a provider then it may require a
>>> "tenant name"
>>> field which is not something Quantum provider requires.
>>
>> actually, since these are both openstack services, why would one need a
>> tenant name and the other wouldn't?
>
> I don't know why this is the case since I'm not familiar with Glance, but
> from what I heard this is one of the fields it needs.
> Either way, we can't expect all OpenStack providers to be modelled the same
> until we model them, and then we will know if they have the same fields or not.
>
>>
>>> Both these providers will be probably linked to a keystone entity, while a
>>> host
>>> provider (such as Foreman) will not be since it doesn't work with keystone.
>>>
>>> We can't expect all providers to be the same, some divergence is bound to
>>> occur.
>>
>> true, but keystone is one of the few authentication aspects which are
>> going to be common to multiple providers, hence don't make sense to be
>> provider specific.
>
> It will be common for OpenStack based providers.
> How about UCSM for instance, should we want to integrate it as a provider?

i'm sure it will require user/password as well.
if we model authentication of providers outside of the providers table, 
it should be a general credentials solution for the various types of 
authentication, not provider specific.

>
>>
>>>
>>>>
>>>>>
>>>>>>
>>>>>>>
>>>>>>>>
>>>>>>>>>
>>>>>>>>> In Java this is easily represented by inheritance.
>>>>>>>>>
>>>>>>>>> In the DB however, there are 3 approaches that we can take:
>>>>>>>>>
>>>>>>>>>      1. No inheritance.
>>>>>>>>>         This means that each type will wit in his own table, with no
>>>>>>>>>         relation or re-use.
>>>>>>>>>      2. Single table inheritance.
>>>>>>>>>         All types sit in a single table, and each has his
>>>>>>>>>         corresponding
>>>>>>>>>         columns.
>>>>>>>>>      3. Multiple table inheritance.
>>>>>>>>>         Each type sists in his own table, where the PK is FK for the
>>>>>>>>>         most
>>>>>>>>>         basic table (providers).
>>>>>>>>>
>>>>>>>>>
>>>>>>>>> Pros for each approach:
>>>>>>>>>
>>>>>>>>>      1. None that I can think of.
>>>>>>>>>      2. No joins:
>>>>>>>>>              Better performance
>>>>>>>>>              Easier for developer to see the DB info
>>>>>>>>>              Facilitate column reuse
>>>>>>>>>      3. Constraints can be set on each column
>>>>>>>>>
>>>>>>>>> Cons for each approach:
>>>>>>>>>
>>>>>>>>>      1. No reuse of DB entities + no compliance for column types
>>>>>>>>>         Most cumbersome to query all providers
>>>>>>>>>      2. Can't put some constraints on non-base columns (esp. not null)
>>>>>>>>>      3. Joins are needed - opposite of the pros of 2.
>>>>>>>>>
>>>>>>>>>      From personal experience, I find #2 to be better and easier to
>>>>>>>>>      work
>>>>>>>>> with & maintain.
>>>>>>>>>
>>>>>>>>> What are your thoughts?
>>>>>>>>>
>>>>>>>>> Regards,
>>>>>>>>> Mike
>>>>>>>>>
>>>>>>>>>
>>>>>>>>>
>>>>>>>>> _______________________________________________
>>>>>>>>> Engine-devel mailing list
>>>>>>>>> Engine-devel at ovirt.org
>>>>>>>>> http://lists.ovirt.org/mailman/listinfo/engine-devel
>>>>>>>>>
>>>>>>>>
>>>>>>>>
>>>>>>
>>>>>>
>>>>
>>>>
>>
>>




More information about the Devel mailing list