Yes, I'm aware of those issues however in our use case they don't cause any
problems.

But ... If there's something better out there I'm really curious: so I'll
keep up with this thread.

2012/5/16 Piavlo <lolitus...@gmail.com>

>  On 05/16/2012 01:24 PM, R. Verlangen wrote:
>
> Hi there,
>
>  I'm using HAProxy for PHP projects to take care of this. It improved
> connection pooling enormous on the client side: with preserving failover
> capabilities. Maybe that is something for you to use in combination with
> PHP.
>
> I already use it exactly like this :)
> But i don't think it's a good solution. And it's totally unaware of
> thrift/cassandra protocol, it's was pretty well discussed here
>
> http://cassandra-user-incubator-apache-org.3065146.n2.nabble.com/Cassandra-amp-HAProxy-td5473144.html
> I even see the plain tcp healchecks failing from time to time for no
> reason.
> I'm planning to make it a bit smarter with localhost http level
> healthchecks - where it would make a cassandra write to CF in
>  keyspace wich has replication of 1, and will write to a key that maps to
> the specific cassandra node being checked by healthcheck (of course  the
> keys need to be recaclulated each time the cluster is rebalanced).
> But IMHO it's very very ugly hack, and not as reliable as real smart proxy
> which is way more superior and efficient (especially if it could do the
> reads/writes coordination itself).
>
> Haproxy also has an issue that then once of the backend ip changes (which
> happens often in clouds) it's has to be restarted to resolve the the
> correct hostname,
> though it looks like Willy is finally seriously considering to implement
> more dynamic for hostnames  lookups (which was not the case about a year
> ago then I asked  for such feature)
> the problem was is discussed here recently -
> http://marc.info/?l=haproxy&m=133559164408814&w=1
>
> haproxy has some more issues - i don't remember off top of my head.
>
> Smart proxy would simply not have all those issues, as it's aware of the
> ring state and the protocol and if smaprt proxy was  the cassandra itself
> then it would have all the needed features tested and reliable at no effort.
>
> Thanks
> Alex
>
>
>  Good luck!
>
> 2012/5/16 Piavlo <lolitus...@gmail.com>
>
>>
>>  Hi,
>>
>> I'm interested in using some smart proxy cassandra process that could act
>> as coordinator node and be aware of cluster state.
>> And run this smart proxy cassandra process on each client side host
>>  where the application(php) with short lived cassandra connections runs.
>> Besides being aware of cluster state if it could act as coordinator node
>> it would save unneeded network trips.
>> And maybe even have an option to take care of hinted handoffs.
>> IMHO the best candidate for this is the cassandra itself (like it's done
>> in elasticsearch
>> http://www.elasticsearch.org/guide/reference/modules/node.html)
>> I also see there was a work done in this direction at
>> https://issues.apache.org/jira/browse/CASSANDRA-535
>> So maybe this is something that is already usable?
>>
>> Or maybe there is some third party project that could be used as smart
>> cassandra proxy?
>>
>> Thanks
>> Alex
>>
>
>
>
>  --
> With kind regards,
>
>  Robin Verlangen
> www.robinverlangen.nl
>
>
>


-- 
With kind regards,

Robin Verlangen
www.robinverlangen.nl

Reply via email to