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 <mailto: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 <http://www.robinverlangen.nl>


Reply via email to