Nessuna descrizione

Daniele Alessandri 89c311d0de Complete redesign of the network connection API, it should make much more sense now. 14 anni fa
bin aec3fcf3e8 Add a script to recreate a single PHP file from the repository. 14 anni fa
examples 9f58d8a663 Register an autoloader function for examples. 14 anni fa
lib 89c311d0de Complete redesign of the network connection API, it should make much more sense now. 14 anni fa
test 89c311d0de Complete redesign of the network connection API, it should make much more sense now. 14 anni fa
CHANGELOG 8e4ef21b41 Update CHANGELOG. 14 anni fa
LICENSE fb2bc5c8e9 Bump year in LICENSE file. 14 anni fa
README.markdown ba4dc10936 Update README. 14 anni fa
TODO 9d6ffcc5f2 Update TODO. 14 anni fa
UNSTABLE 97439a7e08 Update UNSTABLE. 14 anni fa
VERSION 22807e8163 Bump version number. 14 anni fa
phpunit.xml.dist ac1e6e1846 Fix tests for latest changes, added phpunit.xml.dist file and autoloader in test/bootstrap.php 14 anni fa

README.markdown

Predis

About

Predis is a flexible and feature-complete PHP (>= 5.3) client library for the Redis key-value store.

For a version compatible with PHP 5.2 you must use the backported version of latest release in the 0.6.x series. Please refer to the TODO file to see which issues are still pending and what is due to be implemented soon in Predis.

Main features

  • Full support for Redis 1.2, 2.0 and 2.2. Different versions of Redis are supported via server profiles.
  • Client-side sharding (support for consistent hashing and custom distribution strategies).
  • Command pipelining on single and multiple connections.
  • Abstraction for Redis transactions (>= 2.0) with support for CAS operations (>= 2.2).
  • 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.

Loading Predis

Predis relies on the autoloading features of PHP and complies with the PSR-0 standard for interoperability with the major frameworks and libraries. When used in simple projects or scripts you might need to define an autoloader function:

spl_autoload_register(function($class) {
    $file = PREDIS_BASE_PATH . strtr($class, '\\', '/') . '.php';
    if (file_exists($file)) {
        require $file;
        return true;
    }
});

Optionally, you can generate a single PHP file that holds every class (just like older versions of Predis) by launching the createSingleFile.php script from the bin directory of the repository. In this way you can load Predis in your scripts simply by using functions such as require and include.

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 = new Predis\Client(array(
    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\Command {
    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.

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 | E_STRICT.

The recommended way to contribute to Predis is to fork the project on GitHub, create new topic branches on your newly created repository to fix or add features and then open a new pull request with a description of the applied changes. Obviously, you can use any other Git hosting provider of your preference. Diff patches will be accepted too, even though they are not the preferred way to contribute to Predis.

Dependencies

  • PHP >= 5.3.0
  • PHPUnit (needed to run the test suite)

Links

Project

Related

Author

Contributors

License

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