On Mon, Jan 3, 2011 at 10:00 PM, John Dickinson
<john.dickin...@rackspace.com> wrote:
> On Jan 3, 2011, at 6:13 PM, John Purrier wrote:
>>
>> API/Service Protocol: RESTful interfaces specific to each service. Each 
>> service will present a Public API, a Management API, and optionally, a 
>> Notification API. The set and format of the service interface calls define 
>> the Service Protocol.
>
>>  OpenStack Programming Model: The set of functions and calls that OpenStack 
>> Application Developers will interact with. These will be presented through 
>> various language bindings, the only restriction is that consistency between 
>> implementations in maintained.
>
>>  The key concept being proposed is that the developers that will be 
>> interacting with the OpenStack services will not interact directly with the 
>> service API’s, but rather will have a set of published language bindings 
>> that define the programming model. This does not preclude direct service 
>> calls, but this will be discouraged in favor of using the bindings. The 
>> bindings will be considered the “Nova API” for all intents and purposes.
>
> Based on our experience with Cloud Files (HTTP API + 5 language bindings), I 
> don't agree.
>
> I think that language bindings are very important, but they add extra baggage 
> to the project. I would think that we should encourage openstack users (ie 
> devs) to use provided bindings, but see them as second-class citizens in 
> relation to the direct API. Language bindings will provide a good basis for 
> most projects, but the direct API approach will allow the user (dev) to get 
> better performance or newer features.
>
> Problems with a "language bindings as primary" approach:
>
> 1) Features are delayed because they must be added to all bindings before 
> being officially release/supported. This slows down development
>
> 2) The project requires active devs with good knowledge of many languages 
> across the dev team. As devs come and go, this makes it difficult to keep 
> good language bindings.
>
> 3) Different languages generally have different ways of doing things. This 
> leads to differentiation between the bindings and difficulty in keeping 
> consistency. For example, how should one implement concurrency with Python, 
> Java, PHP, and C language bindings? threads? processes? coroutines? This 
> extends to the different libraries and toolkits available in different 
> languages. Even within one language you can have highly passionate views on 
> how to do it The Right Way (eg twisted vs eventlet in Python).
>
> I would suggest that Openstack projects should have language bindings and 
> these bindings should be written well and maintained. But the direct API to 
> the service (HTTP or otherwise) should always take precedence. I know the 
> example was for nova, but since I have experience with swift, I will use an 
> example there. Large files (5GB+) are supported in Bexar, but they are not 
> included in any language bindings. Initially, until the language bindings are 
> updated, the only way to get them is to use the HTTP API directly. This 
> should not prevent the feature from being released in Bexar, nor should Bexar 
> require language binding support for large files in swift before release.

++

HTTP API should be primary development focus for new features and
binding maintainers can/should update bindings after the canonical
HTTP API is enhanced.  This is how the vast majority of open source
projects function -- i.e. the pick a canonical API (typically
REST/HTTP for webby-type projects and C API for non webby-type
projects) and then update language bindings afterwards.

-jay

_______________________________________________
Mailing list: https://launchpad.net/~openstack
Post to     : openstack@lists.launchpad.net
Unsubscribe : https://launchpad.net/~openstack
More help   : https://help.launchpad.net/ListHelp

Reply via email to