Sin descripción

Daniele Alessandri 3edcdc5a4f Fixed a dangerous oversight in the test suite (seriously, testing FLUSHALL was indeed stupid). hace 15 años
examples 6df1d02e4c Initial support for optional parameters when creating a Client instance. Optional authorization and database selection are now performed automatically upon connection. hace 15 años
lib 7fa935f827 Implemented a factory method for creating server profiles instances. hace 15 años
test 3edcdc5a4f Fixed a dangerous oversight in the test suite (seriously, testing FLUSHALL was indeed stupid). hace 15 años
CHANGELOG 1be9bef159 Updated CHANGELOG hace 15 años
LICENSE 15c81fca6f Bumping year in the LICENSE file. hace 15 años
README.markdown e01feda91f Updated the README. hace 15 años
TODO e5c3123d88 Updated TODO. hace 15 años

README.markdown

Predis

About

Predis is a flexible and feature-complete PHP client library for the Redis key-value database.

Predis is currently a work-in-progress and it comes in two flavors:

  • the mainline client library, which targets PHP 5.3.x and leverages a lot of the features introduced in this new version of the PHP interpreter.
  • a backport to PHP 5.2.x for those who can not upgrade their environment yet (it admittedly has a lower priority compared to the mainline library, although we try to keep the two versions aligned as much as possible).

Please refer to the TODO file to see which issues are still pending and what is due to be implemented soon in Predis.

Features

  • Client-side sharding (support for consistent hashing of keys)
  • Command pipelining on single and multiple connections (transparent)
  • Lazy connections (connections to Redis instances are only established just in time)
  • Flexible system to define and register your own set of commands to a client instance

Quick examples

See the official wiki of the project for a more complete coverage of all the features available in Predis.

Connecting to a local instance of Redis

You don't have to specify a tcp host and port when connecting to Redis instances running on the localhost on the default port:

$redis = new Predis\Client();
$redis->set('library', 'predis');
$value = $redis->get('library');

Pipelining multiple commands to a remote instance of Redis

Pipelining helps with performances when there is the need to issue many commands to a server in one go:

$redis   = new Predis\Client('redis://10.0.0.1:6379/');
$replies = $redis->pipeline(function($pipe) {
    $pipe->ping();
    $pipe->incrby('counter', 10);
    $pipe->incrby('counter', 30);
    $pipe->get('counter');
});

Pipelining multiple commands to multiple instances of Redis (sharding)

Predis supports data sharding using consistent-hashing on keys on the client side. Furthermore, a pipeline can be initialized on a cluster of redis instances in the same exact way they are created on single connection. Sharding is still transparent to the user:

$redis = Predis\Client::create(
    array('host' => '10.0.0.1', 'port' => 6379),
    array('host' => '10.0.0.2', 'port' => 6379)
);

$replies = $redis->pipeline(function($pipe) {
    for ($i = 0; $i < 1000; $i++) {
        $pipe->set("key:$i", str_pad($i, 4, '0', 0));
        $pipe->get("key:$i");
    }
});

Definition and runtime registration of new commands on the client

Let's suppose Redis just added the support for a brand new feature associated with a new command. If you want to start using the above mentioned new feature right away without messing with Predis source code or waiting for it to find its way into a stable Predis release, then you can start off by creating a new class that matches the command type and its behaviour and then bind it to a client instance at runtime. Actually, it is easier done than said:

class BrandNewRedisCommand extends \Predis\InlineCommand {
    public function getCommandId() { return 'NEWCMD'; }
}

$redis = new Predis\Client();
$redis->getProfile()->registerCommand('BrandNewRedisCommand', 'newcmd');
$redis->newcmd();

Development

Predis is fully backed up by a test suite which tries to cover all the aspects of the client library and the interaction of every single command with a Redis server. If you want to work on Predis, it is highly recommended that you first run the test suite to be sure that everything is OK, and report strange behaviours or bugs.

The recommended way to contribute to Predis is to fork the project on GitHub, fix or add features on your newly created repository and then submit issues on the Predis issue tracker with a link to your repository. Obviously, you can use any other Git hosting provider of you preference. Diff patches will be accepted too, even though they are not the preferred way to contribute to Predis.

When modifying Predis please be sure that no warnings or notices are emitted by PHP by running the interpreter in your development environment with the "error_reporting" variable set to E_ALL.

Dependencies

  • PHP >= 5.3.0 (for the mainline client library)
  • PHP >= 5.2.6 (for the backported client library)
  • PHPUnit (needed to run the test suite)

Links

Project

Related

Author

Daniele Alessandri

License

The code for Predis is distributed under the terms of the MIT license (see LICENSE).