[infinispan-issues] [JBoss JIRA] (ISPN-3175) Upgrade the java hotrod client to support remote querying

Pedro Ruivo (JIRA) jira-events at lists.jboss.org
Thu Aug 22 19:31:30 EDT 2013


     [ https://issues.jboss.org/browse/ISPN-3175?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]

Pedro Ruivo updated ISPN-3175:
------------------------------

    Fix Version/s: 6.0.0.Beta1
                       (was: 6.0.0.Alpha3)

    
> Upgrade the java hotrod client to support remote querying
> ---------------------------------------------------------
>
>                 Key: ISPN-3175
>                 URL: https://issues.jboss.org/browse/ISPN-3175
>             Project: Infinispan
>          Issue Type: Sub-task
>            Reporter: Mircea Markus
>            Assignee: Adrian Nistor
>            Priority: Blocker
>              Labels: jdg62
>             Fix For: 6.0.0.Beta1, 6.0.0.Final
>
>
> Once we'll have ISPN-3169(define query fluent API), ISPN-3173(add a new query operation over hotrod) and ISPN-3174(String-based query language) in place, this is about connecting the dots: invoke the remote query on the server and present the result to the user.
> h3.On the client side
> As described in ISPN-3173, the query is sent as a byte[] to the server: the payload.
> The request payload is query specific (not defined in the HR protocol) and at this stage has the following format: [Q_TYPE] [QUERY_ST] [FIRST_INDEX] [PAGE_SIZE]. This format accommodates the remote query requirements as defined in ISPN-3169.
> - Q_TYPE (protobuf's byte) and query identifier, 1 for JPAQL (this is the query type we'll support). In future we'll add different query types as well.
> - QUERY_STRING (protobuf's string)- JPAQL string generated by the fluent API (ISPN-3169). Parameters are encoded in this string (vs being sent separately)
> - FIRST_INDEX + PAGE_SIZE (protobuf's int)- used for paginating/iterating over the result set.
> HR response: [HR_SUCESS_FLAG] [payload]
> PAYLOAD = [NUM_EL] [PROJ_SIZE] [ELEMENTS]
> - even though at this stage we don't support projections (see ISPN-3169) PROJ_SIZE is added for future compatibility when projection will be supported.
> Note that the payload for both request and response should be marshalled with protobuf as this information is read/written over multiple clients. 
> h3.On the server side
> - the server module reads the query operation and the payload (byte[])
> - invokes QueryFacade.query(byte[]) : byte[]
>    - QueryFacade is an interface defined in the server modules
>    - has an implementation in the remote-query module (new modules)
>    - the reason for adding this module: RemoteQueryImpl cannot be in the server modules (ASL) as it has a dependency on the query module (LGPL) which would "contaminate" the server module. Another option would be to merge it in the query module itself, but doesn't feel like a natural fit as its responsibility is serializing data (protobuf). OTOH if it is small we can merge it there so that we don't add a new module to the system?
>         
> For an overview on the remote querying see https://community.jboss.org/wiki/QueryingDesignInInfinispan

--
This message is automatically generated by JIRA.
If you think it was sent incorrectly, please contact your JIRA administrators
For more information on JIRA, see: http://www.atlassian.com/software/jira


More information about the infinispan-issues mailing list