我有一个Cassandra的客户端/服务器设置,当通过Perl访问时可以工作。我现在正试图用PHP重做这个过程。如果不出现"TSocket read 0 bytes"异常,我似乎无法针对安装调用任何函数。以下是一个应该非常简单的示例:
$GLOBALS['THRIFT_ROOT'] = '/usr/local/src/thrift-0.8.0/lib/php/src';
require_once $GLOBALS['THRIFT_ROOT'].'/packages/cassandra/Cassandra.php';
require_once $GLOBALS['THRIFT_ROOT'].'/packages/cassandra/cassandra_types.php';
require_once $GLOBALS['THRIFT_ROOT'].'/transport/TSocket.php';
require_once $GLOBALS['THRIFT_ROOT'].'/protocol/TBinaryProtocol.php';
require_once $GLOBALS['THRIFT_ROOT'].'/transport/TFramedTransport.php';
require_once $GLOBALS['THRIFT_ROOT'].'/transport/TBufferedTransport.php';
try {
$socket = new TSocket( '10.127.24.19', 9160 );
$transport = new TBufferedTransport( $socket, 1024, 1024 );
$protocol = new TBinaryProtocolAccelerated( $transport );
$client = new cassandra_CassandraClient( $protocol );
$transport->open();
$keyspace = 'some_data';
$client->set_keyspace( $keyspace );
}
catch (TException $tx)
{
error_log( print_r( $tx, true ));
}
这是节俭0.8.0,Cassandra 1.0,PHP 5.3.1。
不要使用原始节俭,而是使用库:
- https://github.com/thobbs/phpcassa
- http://code.google.com/a/apache-extras.org/p/cassandra-pdo/
否则,你会遇到一个没完没了的清单。